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
11 * http://www.apache.org/licenses/LICENSE-2.0
\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
19 package org.commscope.tr069adapter.acs.cpe.test.inform;
\r
21 import static org.junit.Assert.assertEquals;
\r
22 import static org.junit.Assert.fail;
\r
24 import java.io.Serializable;
\r
26 import javax.servlet.http.Cookie;
\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
57 @SpringBootTest(classes = {ACSServiceBooter.class})
\r
58 @RunWith(SpringJUnit4ClassRunner.class)
\r
59 @AutoConfigureMockMvc
\r
60 @ContextConfiguration
\r
61 public class BootInformTest {
\r
64 private MockMvc mockMvc;
\r
67 private DeviceValidator deviceValidator;
\r
70 protected DeviceRPCRequestRepository deviceRPCRequestRepository;
\r
73 private SessionManager sessionManager;
\r
76 private TR069EventNotificationService tr069EventNotificationService;
\r
79 private TimerServiceManagerAPI timerServiceManagerAPI;
\r
82 BrokerService broker;
\r
85 public void processInformPnPTest() throws Exception {
\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>0005B9519091</SerialNumber></DeviceId><Event xsi:type=\"SOAP-ENC:Array\" SOAP-ENC:arrayType=\"cwmp:EventStruct[1]\"><EventStruct><EventCode>1 BOOT</EventCode><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\">0005B9519091</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
94 Mockito.doNothing().when(tr069EventNotificationService)
\r
95 .sendDeviceInformToNBI(Mockito.any(DeviceInform.class));
\r
98 .when(deviceValidator.isDeviceAuthorized(Mockito.any(Inform.class), Mockito.anyString()))
\r
99 .thenReturn(new Boolean(true));
\r
101 Mockito.when(deviceValidator.validateDevice(Mockito.anyString(), Mockito.anyString(),
\r
102 Mockito.anyString())).thenReturn(new Boolean(true));
\r
104 SessionDTO session = new SessionDTO();
\r
105 session.setDeviceId("0005B9519091");
\r
106 session.setSessionId("sessionId1");
\r
107 session.setCurrentOperationId(10000L);
\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
114 Mockito.when(deviceRPCRequestRepository.findByDeviceIdAndIsProcessed(Mockito.anyString(),
\r
115 Mockito.anyInt())).thenReturn(null);
\r
117 Mockito.doNothing().when(timerServiceManagerAPI).startTimer(Mockito.anyString(),
\r
118 Mockito.anyString(), Mockito.anyLong(), Mockito.any(Serializable.class));
\r
119 Mockito.doNothing().when(timerServiceManagerAPI).stopTimer(Mockito.anyString());
\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
125 MvcResult result = mockMvc.perform(requestBuilder).andReturn();
\r
127 MockHttpServletResponse response = result.getResponse();
\r
128 assertEquals(HttpStatus.SC_OK, response.getStatus());
\r
130 Cookie cookie = response.getCookie(AcsConstants.ACS_SESSIONID);
\r
132 MockMvcRequestBuilders.post("/CPEMgmt/acs").accept(MediaType.TEXT_PLAIN).content("")
\r
133 .header("Authorization", "basic").cookie(cookie).contentType(MediaType.TEXT_PLAIN);
\r
135 result = mockMvc.perform(requestBuilder).andReturn();
\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
145 public void stopBroker() throws Exception {
\r
147 System.out.println("Tearing down the broker");
\r
149 broker.waitUntilStopped();
\r
151 } catch (Exception e) {
\r
152 e.printStackTrace();
\r