Initial source code
[oam/tr069-adapter.git] / acs / application-booter / src / test / java / org / commscope / tr069adapter / acs / cpe / test / inform / InformAbortPendingReq.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.util.ArrayList;\r
25 import java.util.List;\r
26 \r
27 import javax.servlet.http.Cookie;\r
28 \r
29 import org.apache.activemq.broker.BrokerService;\r
30 import org.apache.commons.httpclient.HttpStatus;\r
31 import org.commscope.tr069adapter.acs.booter.ACSServiceBooter;\r
32 import org.commscope.tr069adapter.acs.common.DeviceInform;\r
33 import org.commscope.tr069adapter.acs.common.DeviceRPCRequest;\r
34 import org.commscope.tr069adapter.acs.common.DeviceRPCResponse;\r
35 import org.commscope.tr069adapter.acs.common.dto.TR069OperationCode;\r
36 import org.commscope.tr069adapter.acs.common.utils.AcsConstants;\r
37 import org.commscope.tr069adapter.acs.cpe.builder.DeviceRPCBuilder;\r
38 import org.commscope.tr069adapter.acs.cpe.handler.DeviceValidator;\r
39 import org.commscope.tr069adapter.acs.cpe.rpc.Inform;\r
40 import org.commscope.tr069adapter.acs.requestprocessor.dao.DeviceRPCRequestRepository;\r
41 import org.commscope.tr069adapter.acs.requestprocessor.entity.TR069DeviceRPCRequestEntity;\r
42 import org.commscope.tr069adapter.acs.requestprocessor.impl.TR069EventNotificationService;\r
43 import org.junit.After;\r
44 import org.junit.Test;\r
45 import org.junit.runner.RunWith;\r
46 import org.mockito.Mockito;\r
47 import org.springframework.beans.factory.annotation.Autowired;\r
48 import org.springframework.boot.test.autoconfigure.web.servlet.AutoConfigureMockMvc;\r
49 import org.springframework.boot.test.context.SpringBootTest;\r
50 import org.springframework.boot.test.mock.mockito.MockBean;\r
51 import org.springframework.http.MediaType;\r
52 import org.springframework.mock.web.MockHttpServletResponse;\r
53 import org.springframework.test.context.ContextConfiguration;\r
54 import org.springframework.test.context.junit4.SpringJUnit4ClassRunner;\r
55 import org.springframework.test.web.servlet.MockMvc;\r
56 import org.springframework.test.web.servlet.MvcResult;\r
57 import org.springframework.test.web.servlet.RequestBuilder;\r
58 import org.springframework.test.web.servlet.request.MockMvcRequestBuilders;\r
59 \r
60 @SpringBootTest(classes = {ACSServiceBooter.class})\r
61 @RunWith(SpringJUnit4ClassRunner.class)\r
62 @AutoConfigureMockMvc\r
63 @ContextConfiguration\r
64 public class InformAbortPendingReq {\r
65 \r
66   @Autowired\r
67   private MockMvc mockMvc;\r
68 \r
69   @MockBean\r
70   private DeviceValidator deviceValidator;\r
71 \r
72   @MockBean\r
73   protected DeviceRPCRequestRepository deviceRPCRequestRepository;\r
74 \r
75   @MockBean\r
76   private TR069EventNotificationService tr069EventNotificationService;\r
77 \r
78   @MockBean\r
79   DeviceRPCBuilder deviceRPCBuilder;\r
80 \r
81   @Autowired\r
82   BrokerService broker;\r
83 \r
84   @Test\r
85   public void processInformPnPByAbortingPendingRequestTest() 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>0005B9519090</SerialNumber></DeviceId><Event xsi:type=\"SOAP-ENC:Array\" SOAP-ENC:arrayType=\"cwmp:EventStruct[1]\"><EventStruct><EventCode>0 BOOTSTRAP</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\">0005B9519090</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           .sendOperationResultToNBI(Mockito.any(DeviceRPCResponse.class));\r
96       Mockito.doNothing().when(tr069EventNotificationService)\r
97           .sendDeviceInformToNBI(Mockito.any(DeviceInform.class));\r
98 \r
99       Mockito\r
100           .when(deviceValidator.isDeviceAuthorized(Mockito.any(Inform.class), Mockito.anyString()))\r
101           .thenReturn(new Boolean(true));\r
102 \r
103       Mockito.when(deviceValidator.validateDevice(Mockito.anyString(), Mockito.anyString(),\r
104           Mockito.anyString())).thenReturn(new Boolean(true));\r
105 \r
106       List<TR069DeviceRPCRequestEntity> deviceRPCRequestEntities =\r
107           new ArrayList<TR069DeviceRPCRequestEntity>();\r
108       TR069DeviceRPCRequestEntity entity = new TR069DeviceRPCRequestEntity();\r
109       entity.setDeviceId("0005B9519090");\r
110       entity.setOperationId(10000L);\r
111       entity.setOpCode(TR069OperationCode.ADD_OBJECT.getOperationCode());\r
112       entity.setRequestTimeOut(1000L);\r
113       deviceRPCRequestEntities.add(entity);\r
114       Mockito.when(deviceRPCRequestRepository.findByDeviceIdAndIsProcessed(Mockito.anyString(),\r
115           Mockito.anyInt())).thenReturn(deviceRPCRequestEntities);\r
116 \r
117       Mockito.when(deviceRPCRequestRepository.findByDeviceIdAndOperationId(Mockito.anyString(),\r
118           Mockito.anyLong())).thenReturn(deviceRPCRequestEntities);\r
119 \r
120       Mockito.when(deviceRPCBuilder.constructDeviceRPC(Mockito.any(DeviceRPCRequest.class)))\r
121           .thenReturn(null);\r
122 \r
123       RequestBuilder requestBuilder = MockMvcRequestBuilders.post("/CPEMgmt/acs")\r
124           .accept(MediaType.TEXT_PLAIN).content(exampleInform).header("Authorization", "basic")\r
125           .contentType(MediaType.TEXT_PLAIN);\r
126 \r
127       MvcResult result = mockMvc.perform(requestBuilder).andReturn();\r
128 \r
129       MockHttpServletResponse response = result.getResponse();\r
130       assertEquals(HttpStatus.SC_OK, response.getStatus());\r
131 \r
132       Cookie cookie = response.getCookie(AcsConstants.ACS_SESSIONID);\r
133       requestBuilder =\r
134           MockMvcRequestBuilders.post("/CPEMgmt/acs").accept(MediaType.TEXT_PLAIN).content("")\r
135               .header("Authorization", "basic").cookie(cookie).contentType(MediaType.TEXT_PLAIN);\r
136 \r
137       result = mockMvc.perform(requestBuilder).andReturn();\r
138 \r
139       response = result.getResponse();\r
140       assertEquals(HttpStatus.SC_NO_CONTENT, response.getStatus());\r
141     } catch (Exception e) {\r
142       fail(e.getMessage());\r
143     }\r
144   }\r
145 \r
146   @After\r
147   public void stopBroker() throws Exception {\r
148     try {\r
149       System.out.println("Tearing down the broker");\r
150       broker.stop();\r
151       broker.waitUntilStopped();\r
152       broker = null;\r
153     } catch (Exception e) {\r
154       e.printStackTrace();\r
155     }\r
156   }\r
157 }\r