c9d83efced95db80849d7842d165eec318c36741
[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.assertThat;
30
31 import java.io.IOException;
32 import java.util.Map;
33
34 import javax.ws.rs.core.HttpHeaders;
35 import javax.ws.rs.core.MediaType;
36 import javax.ws.rs.core.Response;
37
38 import org.apache.http.HttpStatus;
39 import org.apache.log4j.MDC;
40 import org.junit.Test;
41 import org.onap.so.apihandlerinfra.tasksbeans.RequestDetails;
42 import org.onap.so.apihandlerinfra.tasksbeans.RequestInfo;
43 import org.onap.so.apihandlerinfra.tasksbeans.TaskRequestReference;
44 import org.onap.so.apihandlerinfra.tasksbeans.TasksRequest;
45 import org.onap.so.apihandlerinfra.tasksbeans.ValidResponses;
46 import org.onap.so.logger.MsoLogger;
47 import org.springframework.http.HttpEntity;
48 import org.springframework.http.HttpMethod;
49 import org.springframework.http.ResponseEntity;
50 import org.springframework.web.util.UriComponentsBuilder;
51
52 import com.fasterxml.jackson.databind.DeserializationFeature;
53 import com.fasterxml.jackson.databind.ObjectMapper;
54
55 import ch.qos.logback.classic.spi.ILoggingEvent;
56
57
58 public class ManualTasksTest extends BaseTest{
59
60         private final String basePath = "/tasks/v1/";
61         
62
63         
64         @Test
65         public void testCreateOpEnvObjectMapperError() throws IOException {
66                 TestAppender.events.clear();
67                 stubFor(post(urlPathEqualTo("/sobpmnengine/task/55/complete"))
68                                 .willReturn(aResponse().withHeader("Content-Type", "application/json").withStatus(HttpStatus.SC_OK)));
69                 
70                 String taskId = "55";
71                 TasksRequest taskReq = new TasksRequest();
72                 RequestDetails reqDetail = new RequestDetails();
73                 RequestInfo reqInfo = new RequestInfo();
74                 reqInfo.setRequestorId("testId");
75                 reqInfo.setSource("testSource");        
76                 reqInfo.setResponseValue(ValidResponses.skip);
77                 reqDetail.setRequestInfo(reqInfo);
78                 taskReq.setRequestDetails(reqDetail);
79                 
80                 //expected response
81                 TaskRequestReference expectedResponse = new TaskRequestReference();
82                 expectedResponse.setTaskId(taskId);     
83                 
84                 headers.set("Accept", MediaType.APPLICATION_JSON);
85                 headers.set("Content-Type", MediaType.APPLICATION_JSON);
86                 headers.set(MsoLogger.ECOMP_REQUEST_ID, "987654321");
87                 headers.set(MsoLogger.CLIENT_ID, "VID");
88                 HttpEntity<TasksRequest> entity = new HttpEntity<TasksRequest>(taskReq, headers);
89                 
90                 UriComponentsBuilder builder = UriComponentsBuilder.fromHttpUrl(createURLWithPort(basePath) + taskId + "/complete");           
91                 ResponseEntity<String> response = restTemplate.exchange(
92                                 builder.toUriString(),
93                                 HttpMethod.POST, entity, String.class);
94
95         
96                 ObjectMapper mapper = new ObjectMapper();
97                 mapper.configure(DeserializationFeature.UNWRAP_ROOT_VALUE, true);
98                 mapper.configure(DeserializationFeature.FAIL_ON_UNKNOWN_PROPERTIES, false);
99
100                 TaskRequestReference realResponse = mapper.readValue(response.getBody(), TaskRequestReference.class);
101                 
102                 
103                 //then          
104                 assertEquals(Response.Status.ACCEPTED.getStatusCode(), response.getStatusCode().value());       
105                 assertThat(realResponse, sameBeanAs(expectedResponse)); 
106                 ILoggingEvent logEvent = TestAppender.events.get(0);
107         Map<String,String> mdc = logEvent.getMDCPropertyMap();
108         assertEquals("987654321", mdc.get(MsoLogger.REQUEST_ID));
109         assertEquals("VID", mdc.get(MsoLogger.CLIENT_ID));        
110         assertEquals("application/json", response.getHeaders().get(HttpHeaders.CONTENT_TYPE).get(0));
111         assertEquals("0", response.getHeaders().get("X-MinorVersion").get(0));
112         assertEquals("0", response.getHeaders().get("X-PatchVersion").get(0));
113         assertEquals("1.0.0", response.getHeaders().get("X-LatestVersion").get(0));
114         assertEquals("987654321", response.getHeaders().get("X-TransactionID").get(0));
115         MDC.remove(MsoLogger.CLIENT_ID);
116                 
117         }
118 }