From c8661bd2bab88a77a29167c782a76cdf729648ed Mon Sep 17 00:00:00 2001 From: vempo Date: Thu, 2 Aug 2018 17:25:25 +0300 Subject: Added logging interceptor for Spring Change-Id: I1de1f6baca48f36f05e32231f5a7e900738bd900 Issue-ID: SDC-1580 Signed-off-by: vempo --- .../servlet/spring/LoggingInterceptorTest.java | 117 +++++++++++++++++++++ 1 file changed, 117 insertions(+) create mode 100644 openecomp-be/lib/openecomp-sdc-logging-lib/openecomp-sdc-logging-spring/src/test/java/org/openecomp/sdc/logging/servlet/spring/LoggingInterceptorTest.java (limited to 'openecomp-be/lib/openecomp-sdc-logging-lib/openecomp-sdc-logging-spring/src/test') diff --git a/openecomp-be/lib/openecomp-sdc-logging-lib/openecomp-sdc-logging-spring/src/test/java/org/openecomp/sdc/logging/servlet/spring/LoggingInterceptorTest.java b/openecomp-be/lib/openecomp-sdc-logging-lib/openecomp-sdc-logging-spring/src/test/java/org/openecomp/sdc/logging/servlet/spring/LoggingInterceptorTest.java new file mode 100644 index 0000000000..ccd0b70552 --- /dev/null +++ b/openecomp-be/lib/openecomp-sdc-logging-lib/openecomp-sdc-logging-spring/src/test/java/org/openecomp/sdc/logging/servlet/spring/LoggingInterceptorTest.java @@ -0,0 +1,117 @@ +/* + * Copyright © 2016-2018 European Support Limited + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +package org.openecomp.sdc.logging.servlet.spring; + +import static org.junit.Assert.assertEquals; +import static org.mockito.ArgumentMatchers.any; +import static org.mockito.ArgumentMatchers.eq; +import static org.mockito.Mockito.mock; +import static org.mockito.Mockito.verify; +import static org.mockito.Mockito.when; +import static org.openecomp.sdc.logging.api.StatusCode.COMPLETE; +import static org.openecomp.sdc.logging.api.StatusCode.ERROR; +import static org.openecomp.sdc.logging.servlet.spring.LoggingInterceptor.LOGGING_TRACKER_KEY; + +import javax.servlet.http.HttpServletRequest; +import javax.servlet.http.HttpServletResponse; +import org.junit.Test; +import org.openecomp.sdc.logging.servlet.HttpHeader; +import org.openecomp.sdc.logging.servlet.RequestProcessingResult; +import org.openecomp.sdc.logging.servlet.Tracker; + +/** + * Audit tracking via Spring interceptor. + * + * @author evitaliy + * @since 05 Aug 2018 + */ +public class LoggingInterceptorTest { + + @Test(expected = NullPointerException.class) + public void exceptionThrownWhenPartnerNameHeaderNull() { + new LoggingInterceptor(null, mock(HttpHeader.class)); + } + + @Test(expected = NullPointerException.class) + public void exceptionThrownWhenRequestIdHeaderNull() { + new LoggingInterceptor(mock(HttpHeader.class), null); + } + + @Test + public void trackerAddedWhenBeforeRequest() { + HttpServletRequest request = mock(HttpServletRequest.class); + LoggingInterceptor interceptor = new LoggingInterceptor(mock(HttpHeader.class), mock(HttpHeader.class)); + interceptor.preHandle(request, mock(HttpServletResponse.class), null); + verify(request).setAttribute(eq(LOGGING_TRACKER_KEY), any(Tracker.class)); + } + + @Test + public void trackerInvokedWhenPresentInRequest() { + + Tracker tracker = mock(Tracker.class); + + HttpServletRequest request = mock(HttpServletRequest.class); + when(request.getAttribute(LOGGING_TRACKER_KEY)).thenReturn(tracker); + + HttpServletResponse response = mock(HttpServletResponse.class); + when(response.getStatus()).thenReturn(200); + + LoggingInterceptor interceptor = new LoggingInterceptor(mock(HttpHeader.class), mock(HttpHeader.class)); + interceptor.afterCompletion(request, response, null, null); + verify(tracker).postRequest(any(RequestProcessingResult.class)); + } + + @Test + public void errorStatusWhenInformationalCode() { + final int status = 101; + LoggingInterceptor.ServletResponseResult result = new LoggingInterceptor.ServletResponseResult(status); + assertEquals(status, result.getStatus()); + assertEquals(ERROR, result.getStatusCode()); + } + + @Test + public void errorStatusWhenClientErrorCode() { + final int status = 404; + LoggingInterceptor.ServletResponseResult result = new LoggingInterceptor.ServletResponseResult(status); + assertEquals(status, result.getStatus()); + assertEquals(ERROR, result.getStatusCode()); + } + + @Test + public void errorStatusWhenServerErrorCode() { + final int status = 503; + LoggingInterceptor.ServletResponseResult result = new LoggingInterceptor.ServletResponseResult(status); + assertEquals(status, result.getStatus()); + assertEquals(ERROR, result.getStatusCode()); + } + + @Test + public void completeStatusWhenSuccessCode() { + final int status = 204; + LoggingInterceptor.ServletResponseResult result = new LoggingInterceptor.ServletResponseResult(status); + assertEquals(status, result.getStatus()); + assertEquals(COMPLETE, result.getStatusCode()); + } + + @Test + public void completeStatusWhenRedirectionCode() { + final int status = 307; + LoggingInterceptor.ServletResponseResult result = new LoggingInterceptor.ServletResponseResult(status); + assertEquals(status, result.getStatus()); + assertEquals(COMPLETE, result.getStatusCode()); + } +} \ No newline at end of file -- cgit 1.2.3-korg