Initial source code
[oam/tr069-adapter.git] / acs / application-booter / src / test / java / org / commscope / tr069adapter / acs / cpe / test / inform / ValueChangeInformTest.java
1 /*\r
2  * ============LICENSE_START========================================================================\r
3  * ONAP : tr-069-adapter\r
4  * =================================================================================================\r
5  * Copyright (C) 2020 CommScope Inc Intellectual Property.\r
6  * =================================================================================================\r
7  * This tr-069-adapter software file is distributed by CommScope Inc under the Apache License,\r
8  * Version 2.0 (the "License"); you may not use this file except in compliance with the License. You\r
9  * may obtain a copy of the License at\r
10  *\r
11  * http://www.apache.org/licenses/LICENSE-2.0\r
12  *\r
13  * This file is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND,\r
14  * either express or implied. See the License for the specific language governing permissions and\r
15  * limitations under the License.\r
16  * ===============LICENSE_END=======================================================================\r
17  */\r
18 \r
19 package org.commscope.tr069adapter.acs.cpe.test.inform;\r
20 \r
21 import static org.junit.Assert.assertEquals;\r
22 import static org.junit.Assert.fail;\r
23 \r
24 import java.io.Serializable;\r
25 \r
26 import javax.servlet.http.Cookie;\r
27 \r
28 import org.apache.activemq.broker.BrokerService;\r
29 import org.apache.commons.httpclient.HttpStatus;\r
30 import org.commscope.tr069adapter.acs.booter.ACSServiceBooter;\r
31 import org.commscope.tr069adapter.acs.common.DeviceInform;\r
32 import org.commscope.tr069adapter.acs.common.utils.AcsConstants;\r
33 import org.commscope.tr069adapter.acs.cpe.handler.DeviceValidator;\r
34 import org.commscope.tr069adapter.acs.cpe.rpc.Inform;\r
35 import org.commscope.tr069adapter.acs.requestprocessor.dao.DeviceRPCRequestRepository;\r
36 import org.commscope.tr069adapter.acs.requestprocessor.dto.SessionDTO;\r
37 import org.commscope.tr069adapter.acs.requestprocessor.impl.SessionManager;\r
38 import org.commscope.tr069adapter.acs.requestprocessor.impl.TR069EventNotificationService;\r
39 import org.commscope.tr069adapter.common.timer.TimerServiceManagerAPI;\r
40 import org.junit.After;\r
41 import org.junit.Test;\r
42 import org.junit.runner.RunWith;\r
43 import org.mockito.Mockito;\r
44 import org.springframework.beans.factory.annotation.Autowired;\r
45 import org.springframework.boot.test.autoconfigure.web.servlet.AutoConfigureMockMvc;\r
46 import org.springframework.boot.test.context.SpringBootTest;\r
47 import org.springframework.boot.test.mock.mockito.MockBean;\r
48 import org.springframework.http.MediaType;\r
49 import org.springframework.mock.web.MockHttpServletResponse;\r
50 import org.springframework.test.context.ContextConfiguration;\r
51 import org.springframework.test.context.junit4.SpringJUnit4ClassRunner;\r
52 import org.springframework.test.web.servlet.MockMvc;\r
53 import org.springframework.test.web.servlet.MvcResult;\r
54 import org.springframework.test.web.servlet.RequestBuilder;\r
55 import org.springframework.test.web.servlet.request.MockMvcRequestBuilders;\r
56 \r
57 @SpringBootTest(classes = {ACSServiceBooter.class})\r
58 @RunWith(SpringJUnit4ClassRunner.class)\r
59 @AutoConfigureMockMvc\r
60 @ContextConfiguration\r
61 public class ValueChangeInformTest {\r
62 \r
63   @Autowired\r
64   private MockMvc mockMvc;\r
65 \r
66   @MockBean\r
67   private DeviceValidator deviceValidator;\r
68 \r
69   @MockBean\r
70   protected DeviceRPCRequestRepository deviceRPCRequestRepository;\r
71 \r
72   @MockBean\r
73   private SessionManager sessionManager;\r
74 \r
75   @MockBean\r
76   private TR069EventNotificationService tr069EventNotificationService;\r
77 \r
78   @MockBean\r
79   private TimerServiceManagerAPI timerServiceManagerAPI;\r
80 \r
81   @Autowired\r
82   BrokerService broker;\r
83 \r
84   @Test\r
85   public void processInformPnPTest() throws Exception {\r
86 \r
87     String exampleInform =\r
88         "<?xml version=\"1.0\" encoding=\"UTF-8\"?><SOAP-ENV:Envelope xmlns:SOAP-ENV=\"http://schemas.xmlsoap.org/soap/envelope/\" xmlns:SOAP-ENC=\"http://schemas.xmlsoap.org/soap/encoding/\" xmlns:xsi=\"http://www.w3.org/2001/XMLSchema-instance\" xmlns:xsd=\"http://www.w3.org/2001/XMLSchema\" xmlns:cwmp=\"urn:dslforum-org:cwmp-1-0\"><SOAP-ENV:Header><cwmp:ID SOAP-ENV:mustUnderstand=\"1\">1</cwmp:ID></SOAP-ENV:Header><SOAP-ENV:Body SOAP-ENV:encodingStyle=\"http://schemas.xmlsoap.org/soap/encoding/\"><cwmp:Inform><DeviceId><Manufacturer>Airvana</Manufacturer><OUI>0005B9</OUI><ProductClass>LTE_Enterprise_C-RANSC_Cntrl</ProductClass><SerialNumber>0005B9519095</SerialNumber></DeviceId><Event xsi:type=\"SOAP-ENC:Array\" SOAP-ENC:arrayType=\"cwmp:EventStruct[1]\"><EventStruct><EventCode>4 VALUE CHANGE</EventCode><CommandKey></CommandKey></EventStruct></Event><MaxEnvelopes>1</MaxEnvelopes><CurrentTime>2018-04-27T07:09:16</CurrentTime><RetryCount>0</RetryCount><ParameterList xsi:type=\"SOAP-ENC:Array\" SOAP-ENC:arrayType=\"cwmp:ParameterValueStruct[12]\"><ParameterValueStruct><Name>Device.ManagementServer.ParameterKey</Name><Value xsi:type=\"xsd:string\">None</Value></ParameterValueStruct><ParameterValueStruct><Name>Device.ManagementServer.ConnectionRequestURL</Name><Value xsi:type=\"xsd:string\">http://10.210.37.1/acscall</Value></ParameterValueStruct>"\r
89             + "<ParameterValueStruct><Name>Device.DeviceInfo.Manufacturer</Name><Value xsi:type=\"xsd:string\">Airvana</Value></ParameterValueStruct><ParameterValueStruct><Name>Device.DeviceInfo.ManufacturerOUI</Name><Value xsi:type=\"xsd:string\">0005B9</Value></ParameterValueStruct><ParameterValueStruct><Name>Device.DeviceInfo.ProductClass</Name><Value xsi:type=\"xsd:string\">LTE_Enterprise_C-RANSC_Cntrl</Value></ParameterValueStruct><ParameterValueStruct><Name>Device.DeviceInfo.SerialNumber</Name><Value xsi:type=\"xsd:string\">0005B9519095</Value></ParameterValueStruct><ParameterValueStruct><Name>Device.DeviceInfo.HardwareVersion</Name><Value xsi:type=\"xsd:string\">750742.00.04</Value></ParameterValueStruct><ParameterValueStruct><Name>Device.DeviceInfo.SoftwareVersion</Name><Value xsi:type=\"xsd:string\">3.0.00.073</Value></ParameterValueStruct><ParameterValueStruct><Name>Device.DeviceInfo.ProvisioningCode</Name><Value xsi:type=\"xsd:string\"></Value></ParameterValueStruct><ParameterValueStruct><Name>Device.FAP.X_0005B9_RUWhiteList</Name><Value xsi:type=\"xsd:string\"></Value></ParameterValueStruct><ParameterValueStruct><Name>Device.IP.Interface.1.IPv4Enable</Name><Value xsi:type=\"xsd:boolean\">1</Value></ParameterValueStruct><ParameterValueStruct><Name>Device.IP.Interface.1.IPv4Address.1.IPAddress</Name><Value xsi:type=\"xsd:string\">10.210.37.1</Value></ParameterValueStruct>"\r
90             + "</ParameterList></cwmp:Inform></SOAP-ENV:Body></SOAP-ENV:Envelope>";\r
91 \r
92     try {\r
93 \r
94       Mockito.doNothing().when(tr069EventNotificationService)\r
95           .sendDeviceInformToNBI(Mockito.any(DeviceInform.class));\r
96 \r
97       Mockito\r
98           .when(deviceValidator.isDeviceAuthorized(Mockito.any(Inform.class), Mockito.anyString()))\r
99           .thenReturn(new Boolean(true));\r
100 \r
101       Mockito.when(deviceValidator.validateDevice(Mockito.anyString(), Mockito.anyString(),\r
102           Mockito.anyString())).thenReturn(new Boolean(true));\r
103 \r
104       SessionDTO session = new SessionDTO();\r
105       session.setDeviceId("0005B9519095");\r
106       session.setSessionId("sessionId5");\r
107       session.setCurrentOperationId(10000L);\r
108 \r
109       Mockito.when(sessionManager.getSessionBySessionId(Mockito.anyString())).thenReturn(session);\r
110       Mockito.when(sessionManager.getLockedSession(Mockito.anyString())).thenReturn(session);\r
111       Mockito.when(sessionManager.updateSession(Mockito.any(SessionDTO.class))).thenReturn(session);\r
112       Mockito.when(sessionManager.generateUniqueSessionID()).thenReturn("sessionid5");\r
113 \r
114       Mockito.doNothing().when(timerServiceManagerAPI).startTimer(Mockito.anyString(),\r
115           Mockito.anyString(), Mockito.anyLong(), Mockito.any(Serializable.class));\r
116       Mockito.doNothing().when(timerServiceManagerAPI).stopTimer(Mockito.anyString());\r
117 \r
118       Mockito.when(deviceRPCRequestRepository.findByDeviceIdAndIsProcessed(Mockito.anyString(),\r
119           Mockito.anyInt())).thenReturn(null);\r
120 \r
121       RequestBuilder requestBuilder = MockMvcRequestBuilders.post("/CPEMgmt/acs")\r
122           .accept(MediaType.TEXT_PLAIN).content(exampleInform).header("Authorization", "basic")\r
123           .contentType(MediaType.TEXT_PLAIN);\r
124 \r
125       MvcResult result = mockMvc.perform(requestBuilder).andReturn();\r
126 \r
127       MockHttpServletResponse response = result.getResponse();\r
128       assertEquals(HttpStatus.SC_OK, response.getStatus());\r
129 \r
130       Cookie cookie = response.getCookie(AcsConstants.ACS_SESSIONID);\r
131       requestBuilder =\r
132           MockMvcRequestBuilders.post("/CPEMgmt/acs").accept(MediaType.TEXT_PLAIN).content("")\r
133               .header("Authorization", "basic").cookie(cookie).contentType(MediaType.TEXT_PLAIN);\r
134 \r
135       result = mockMvc.perform(requestBuilder).andReturn();\r
136 \r
137       response = result.getResponse();\r
138       assertEquals(HttpStatus.SC_NO_CONTENT, response.getStatus());\r
139     } catch (Exception e) {\r
140       fail(e.getMessage());\r
141     }\r
142   }\r
143 \r
144   @After\r
145   public void stopBroker() throws Exception {\r
146     try {\r
147       System.out.println("Tearing down the broker");\r
148       broker.stop();\r
149       broker.waitUntilStopped();\r
150       broker = null;\r
151     } catch (Exception e) {\r
152       e.printStackTrace();\r
153     }\r
154   }\r
155 \r
156 }\r