2 * ============LICENSE_START=======================================================
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
11 * http://www.apache.org/licenses/LICENSE-2.0
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=========================================================
21 package org.onap.so.apihandlerinfra;
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;
31 import static com.shazam.shazamcrest.MatcherAssert.assertThat;
33 import java.io.IOException;
36 import javax.ws.rs.core.MediaType;
37 import javax.ws.rs.core.Response;
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;
56 import com.fasterxml.jackson.databind.DeserializationFeature;
57 import com.fasterxml.jackson.databind.ObjectMapper;
58 import com.github.tomakehurst.wiremock.http.Fault;
60 import ch.qos.logback.classic.spi.ILoggingEvent;
63 public class ManualTasksTest extends BaseTest{
65 private final String basePath = "/tasks/v1/";
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)));
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);
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);
95 UriComponentsBuilder builder = UriComponentsBuilder.fromHttpUrl(createURLWithPort(basePath) + taskId + "/complete");
96 ResponseEntity<String> response = restTemplate.exchange(
97 builder.toUriString(),
98 HttpMethod.POST, entity, String.class);
101 ObjectMapper mapper = new ObjectMapper();
102 mapper.configure(DeserializationFeature.UNWRAP_ROOT_VALUE, true);
103 mapper.configure(DeserializationFeature.FAIL_ON_UNKNOWN_PROPERTIES, false);
105 TaskRequestReference realResponse = mapper.readValue(response.getBody(), TaskRequestReference.class);
109 assertEquals(Response.Status.ACCEPTED.getStatusCode(), response.getStatusCode().value());
110 assertThat(realResponse, sameBeanAs(expectedResponse));
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")
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));
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);
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);
158 UriComponentsBuilder builder = UriComponentsBuilder.fromHttpUrl(createURLWithPort(basePath) + "55" + "/complete");
159 ResponseEntity<String> response = restTemplate.exchange(
160 builder.toUriString(),
161 HttpMethod.POST, entity, String.class);
163 ObjectMapper mapper = new ObjectMapper();
164 mapper.configure(DeserializationFeature.UNWRAP_ROOT_VALUE, true);
165 mapper.configure(DeserializationFeature.FAIL_ON_UNKNOWN_PROPERTIES, false);
167 RequestError realResponse = mapper.readValue(response.getBody(), RequestError.class);
168 assertEquals(Response.Status.BAD_REQUEST.getStatusCode(), response.getStatusCode().value());
169 assertThat(realResponse, sameBeanAs(expectedResponse));
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);
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);
194 UriComponentsBuilder builder = UriComponentsBuilder.fromHttpUrl(createURLWithPort(basePath) + taskId + "/complete");
195 ResponseEntity<String> response = restTemplate.exchange(
196 builder.toUriString(),
197 HttpMethod.POST, entity, String.class);
199 ObjectMapper mapper = new ObjectMapper();
200 mapper.configure(DeserializationFeature.UNWRAP_ROOT_VALUE, true);
201 mapper.configure(DeserializationFeature.FAIL_ON_UNKNOWN_PROPERTIES, false);
203 RequestError realResponse = mapper.readValue(response.getBody(), RequestError.class);
204 assertEquals(Response.Status.BAD_REQUEST.getStatusCode(), response.getStatusCode().value());
205 assertThat(realResponse, sameBeanAs(expectedResponse));
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)));
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);
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);
234 UriComponentsBuilder builder = UriComponentsBuilder.fromHttpUrl(createURLWithPort(basePath) + taskId + "/complete");
235 ResponseEntity<String> response = restTemplate.exchange(
236 builder.toUriString(),
237 HttpMethod.POST, entity, String.class);
240 ObjectMapper mapper = new ObjectMapper();
241 mapper.configure(DeserializationFeature.UNWRAP_ROOT_VALUE, true);
242 mapper.configure(DeserializationFeature.FAIL_ON_UNKNOWN_PROPERTIES, false);
244 RequestError realResponse = mapper.readValue(response.getBody(), RequestError.class);
245 assertEquals(Response.Status.BAD_GATEWAY.getStatusCode(), response.getStatusCode().value());
246 assertThat(realResponse, sameBeanAs(expectedResponse));