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