bb78c822f79a0ab06e527f31ae78af8e2bbf8c34
[so.git] / mso-api-handlers / mso-api-handler-infra / src / test / java / org / onap / so / apihandlerinfra / ManualTasksTest.java
1 /*-
2  * ============LICENSE_START=======================================================
3  * ONAP - SO
4  * ================================================================================
5  * Copyright (C) 2017 AT&T Intellectual Property. All rights reserved.
6  * ================================================================================
7  * Licensed under the Apache License, Version 2.0 (the "License");
8  * you may not use this file except in compliance with the License.
9  * You may obtain a copy of the License at
10  * 
11  *      http://www.apache.org/licenses/LICENSE-2.0
12  * 
13  * Unless required by applicable law or agreed to in writing, software
14  * distributed under the License is distributed on an "AS IS" BASIS,
15  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
16  * See the License for the specific language governing permissions and
17  * limitations under the License.
18  * ============LICENSE_END=========================================================
19  */
20
21 package org.onap.so.apihandlerinfra;
22
23 import static com.github.tomakehurst.wiremock.client.WireMock.aResponse;
24 import static com.github.tomakehurst.wiremock.client.WireMock.post;
25 import static com.github.tomakehurst.wiremock.client.WireMock.stubFor;
26 import static com.github.tomakehurst.wiremock.client.WireMock.urlPathEqualTo;
27 import static com.shazam.shazamcrest.matcher.Matchers.sameBeanAs;
28 import static org.junit.Assert.assertEquals;
29 import static org.junit.Assert.assertNotNull;
30
31 import static com.shazam.shazamcrest.MatcherAssert.assertThat;
32
33 import java.io.IOException;
34 import java.util.Map;
35
36 import javax.ws.rs.core.MediaType;
37 import javax.ws.rs.core.Response;
38
39 import org.apache.http.HttpStatus;
40 import org.junit.Test;
41 import org.onap.logging.ref.slf4j.ONAPLogConstants;
42 import org.onap.so.apihandlerinfra.tasksbeans.RequestDetails;
43 import org.onap.so.apihandlerinfra.tasksbeans.RequestInfo;
44 import org.onap.so.apihandlerinfra.tasksbeans.TaskRequestReference;
45 import org.onap.so.apihandlerinfra.tasksbeans.TasksRequest;
46 import org.onap.so.apihandlerinfra.tasksbeans.ValidResponses;
47 import org.onap.so.logger.MsoLogger;
48 import org.onap.so.serviceinstancebeans.RequestError;
49 import org.onap.so.serviceinstancebeans.ServiceException;
50 import org.springframework.http.HttpEntity;
51 import org.springframework.http.HttpHeaders;
52 import org.springframework.http.HttpMethod;
53 import org.springframework.http.ResponseEntity;
54 import org.springframework.web.util.UriComponentsBuilder;
55
56 import com.fasterxml.jackson.databind.DeserializationFeature;
57 import com.fasterxml.jackson.databind.ObjectMapper;
58 import com.github.tomakehurst.wiremock.http.Fault;
59
60 import ch.qos.logback.classic.spi.ILoggingEvent;
61
62
63 public class ManualTasksTest extends BaseTest{
64
65     private final String basePath = "/tasks/v1/";
66
67
68
69     @Test
70     public void testCreateOpEnvObjectMapperError() throws IOException {
71         TestAppender.events.clear();
72         stubFor(post(urlPathEqualTo("/sobpmnengine/task/55/complete"))
73                 .willReturn(aResponse().withHeader("Content-Type", "application/json").withStatus(HttpStatus.SC_OK)));
74
75         String taskId = "55";
76         TasksRequest taskReq = new TasksRequest();
77         RequestDetails reqDetail = new RequestDetails();
78         RequestInfo reqInfo = new RequestInfo();
79         reqInfo.setRequestorId("testId");
80         reqInfo.setSource("testSource");        
81         reqInfo.setResponseValue(ValidResponses.skip);
82         reqDetail.setRequestInfo(reqInfo);
83         taskReq.setRequestDetails(reqDetail);
84
85         //expected response
86         TaskRequestReference expectedResponse = new TaskRequestReference();
87         expectedResponse.setTaskId(taskId);     
88         HttpHeaders headers = new HttpHeaders();
89         headers.set("Accept", MediaType.APPLICATION_JSON);
90         headers.set("Content-Type", MediaType.APPLICATION_JSON);
91         headers.set(MsoLogger.ECOMP_REQUEST_ID, "987654321");
92         headers.set(MsoLogger.CLIENT_ID, "VID");
93         HttpEntity<TasksRequest> entity = new HttpEntity<TasksRequest>(taskReq, headers);
94
95         UriComponentsBuilder builder = UriComponentsBuilder.fromHttpUrl(createURLWithPort(basePath) + taskId + "/complete");           
96         ResponseEntity<String> response = restTemplate.exchange(
97                 builder.toUriString(),
98                 HttpMethod.POST, entity, String.class);
99
100
101         ObjectMapper mapper = new ObjectMapper();
102         mapper.configure(DeserializationFeature.UNWRAP_ROOT_VALUE, true);
103         mapper.configure(DeserializationFeature.FAIL_ON_UNKNOWN_PROPERTIES, false);
104
105         TaskRequestReference realResponse = mapper.readValue(response.getBody(), TaskRequestReference.class);
106
107
108         //then          
109         assertEquals(Response.Status.ACCEPTED.getStatusCode(), response.getStatusCode().value());       
110         assertThat(realResponse, sameBeanAs(expectedResponse)); 
111         
112         for(ILoggingEvent logEvent : TestAppender.events)
113             if(logEvent.getLoggerName().equals("org.onap.so.logging.jaxrs.filter.jersey.JaxRsFilterLogging") &&
114                         logEvent.getMarker() != null && logEvent.getMarker().getName().equals("ENTRY")
115                     ){
116                 Map<String,String> mdc = logEvent.getMDCPropertyMap();
117                 assertNotNull(mdc.get(ONAPLogConstants.MDCs.ENTRY_TIMESTAMP));
118                 assertNotNull(mdc.get(ONAPLogConstants.MDCs.REQUEST_ID));
119                 assertNotNull(mdc.get(MsoLogger.INVOCATION_ID));               
120                 assertEquals("UNKNOWN",mdc.get(MsoLogger.PARTNERNAME));
121                 assertEquals("tasks/v1/55/complete",mdc.get(MsoLogger.SERVICE_NAME));
122                 assertEquals("INPROGRESS",mdc.get(MsoLogger.STATUSCODE));
123             }else if(logEvent.getLoggerName().equals("org.onap.so.logging.jaxrs.filter.jersey.JaxRsFilterLogging") &&
124                         logEvent.getMarker() != null && logEvent.getMarker().getName().equals("EXIT")){
125                 Map<String,String> mdc = logEvent.getMDCPropertyMap();
126                 assertNotNull(mdc.get(ONAPLogConstants.MDCs.ENTRY_TIMESTAMP));
127                 assertNotNull(mdc.get(MsoLogger.ENDTIME));
128                 assertNotNull(mdc.get(ONAPLogConstants.MDCs.REQUEST_ID));
129                 assertNotNull(mdc.get(MsoLogger.INVOCATION_ID));
130                 assertEquals("202",mdc.get(MsoLogger.RESPONSECODE));
131                 assertEquals("UNKNOWN",mdc.get(MsoLogger.PARTNERNAME));
132                 assertEquals("tasks/v1/55/complete",mdc.get(MsoLogger.SERVICE_NAME));
133                 assertEquals("COMPLETE",mdc.get(MsoLogger.STATUSCODE));
134                 assertNotNull(mdc.get(MsoLogger.RESPONSEDESC));
135                 assertEquals("application/json", response.getHeaders().get(HttpHeaders.CONTENT_TYPE).get(0));
136                 assertEquals("0", response.getHeaders().get("X-MinorVersion").get(0));
137                 assertEquals("0", response.getHeaders().get("X-PatchVersion").get(0));
138                 assertEquals("1.0.0", response.getHeaders().get("X-LatestVersion").get(0));
139             }
140     }
141     @Test
142     public void completeTaskMappingError() throws IOException {
143         String invalidRequest = "test";
144         RequestError expectedResponse = new RequestError();
145         ServiceException se = new ServiceException();
146         se.setMessageId("SVC0002");
147         se.setText("Mapping of request to JSON object failed: Unrecognized token \'test\': "
148                         + "was expecting \'null\', \'true\', \'false\' or NaN\n at [Source: (String)\"test\"; line: 1, column: 9]");
149         expectedResponse.setServiceException(se);
150         
151         HttpHeaders headers = new HttpHeaders();
152         headers.set("Accept", MediaType.APPLICATION_JSON);
153         headers.set("Content-Type", MediaType.APPLICATION_JSON);
154         headers.set(MsoLogger.ECOMP_REQUEST_ID, "987654321");
155         headers.set(MsoLogger.CLIENT_ID, "VID");
156         HttpEntity<String> entity = new HttpEntity<String>(invalidRequest, headers);
157
158         UriComponentsBuilder builder = UriComponentsBuilder.fromHttpUrl(createURLWithPort(basePath) + "55" + "/complete");             
159         ResponseEntity<String> response = restTemplate.exchange(
160                 builder.toUriString(),
161                 HttpMethod.POST, entity, String.class);
162
163         ObjectMapper mapper = new ObjectMapper();
164         mapper.configure(DeserializationFeature.UNWRAP_ROOT_VALUE, true);
165         mapper.configure(DeserializationFeature.FAIL_ON_UNKNOWN_PROPERTIES, false);
166         
167         RequestError realResponse = mapper.readValue(response.getBody(), RequestError.class);
168         assertEquals(Response.Status.BAD_REQUEST.getStatusCode(), response.getStatusCode().value());    
169         assertThat(realResponse, sameBeanAs(expectedResponse));
170     }
171     @Test
172     public void completeTaskValidationError() throws IOException {
173         String taskId = "55";
174         TasksRequest taskReq = new TasksRequest();
175         RequestDetails reqDetail = new RequestDetails();
176         RequestInfo reqInfo = new RequestInfo();
177         reqInfo.setSource("testSource");        
178         reqInfo.setResponseValue(ValidResponses.skip);
179         reqDetail.setRequestInfo(reqInfo);
180         taskReq.setRequestDetails(reqDetail);
181
182         RequestError expectedResponse = new RequestError();
183         ServiceException se = new ServiceException();
184         se.setMessageId("SVC0002");
185         se.setText("Mapping of request to JSON Object failed. No valid requestorId is specified");
186         expectedResponse.setServiceException(se);
187         HttpHeaders headers = new HttpHeaders();
188         headers.set("Accept", MediaType.APPLICATION_JSON);
189         headers.set("Content-Type", MediaType.APPLICATION_JSON);
190         headers.set(MsoLogger.ECOMP_REQUEST_ID, "987654321");
191         headers.set(MsoLogger.CLIENT_ID, "VID");
192         HttpEntity<TasksRequest> entity = new HttpEntity<TasksRequest>(taskReq, headers);
193
194         UriComponentsBuilder builder = UriComponentsBuilder.fromHttpUrl(createURLWithPort(basePath) + taskId + "/complete");           
195         ResponseEntity<String> response = restTemplate.exchange(
196                 builder.toUriString(),
197                 HttpMethod.POST, entity, String.class);
198
199         ObjectMapper mapper = new ObjectMapper();
200         mapper.configure(DeserializationFeature.UNWRAP_ROOT_VALUE, true);
201         mapper.configure(DeserializationFeature.FAIL_ON_UNKNOWN_PROPERTIES, false);
202
203         RequestError realResponse = mapper.readValue(response.getBody(), RequestError.class);
204         assertEquals(Response.Status.BAD_REQUEST.getStatusCode(), response.getStatusCode().value());    
205         assertThat(realResponse, sameBeanAs(expectedResponse));
206     }
207     @Test
208     public void completeTaskBpelResponseError() throws IOException {
209         stubFor(post(urlPathEqualTo("/sobpmnengine/task/55/complete"))
210                 .willReturn(aResponse().withHeader("Content-Type", "application/json").withFault(Fault.EMPTY_RESPONSE)));
211
212         String taskId = "55";
213         TasksRequest taskReq = new TasksRequest();
214         RequestDetails reqDetail = new RequestDetails();
215         RequestInfo reqInfo = new RequestInfo();
216         reqInfo.setRequestorId("testId");
217         reqInfo.setSource("testSource");        
218         reqInfo.setResponseValue(ValidResponses.skip);
219         reqDetail.setRequestInfo(reqInfo);
220         taskReq.setRequestDetails(reqDetail);
221
222         RequestError expectedResponse = new RequestError();
223         ServiceException se = new ServiceException();
224         se.setMessageId("SVC1000");
225         se.setText("Request Failed due to BPEL error with HTTP Status = 502");
226         expectedResponse.setServiceException(se);
227         HttpHeaders headers = new HttpHeaders();
228         headers.set("Accept", MediaType.APPLICATION_JSON);
229         headers.set("Content-Type", MediaType.APPLICATION_JSON);
230         headers.set(MsoLogger.ECOMP_REQUEST_ID, "987654321");
231         headers.set(MsoLogger.CLIENT_ID, "VID");
232         HttpEntity<TasksRequest> entity = new HttpEntity<TasksRequest>(taskReq, headers);
233
234         UriComponentsBuilder builder = UriComponentsBuilder.fromHttpUrl(createURLWithPort(basePath) + taskId + "/complete");           
235         ResponseEntity<String> response = restTemplate.exchange(
236                 builder.toUriString(),
237                 HttpMethod.POST, entity, String.class);
238
239
240         ObjectMapper mapper = new ObjectMapper();
241         mapper.configure(DeserializationFeature.UNWRAP_ROOT_VALUE, true);
242         mapper.configure(DeserializationFeature.FAIL_ON_UNKNOWN_PROPERTIES, false);
243
244         RequestError realResponse = mapper.readValue(response.getBody(), RequestError.class);
245         assertEquals(Response.Status.BAD_GATEWAY.getStatusCode(), response.getStatusCode().value());    
246         assertThat(realResponse, sameBeanAs(expectedResponse));
247     }
248 }