summaryrefslogtreecommitdiffstats
path: root/ecomp-sdk/epsdk-analytics/src/test/java/org/onap/portalsdk/analytics/controller/ErrorHandlerTest.java
diff options
context:
space:
mode:
Diffstat (limited to 'ecomp-sdk/epsdk-analytics/src/test/java/org/onap/portalsdk/analytics/controller/ErrorHandlerTest.java')
-rw-r--r--ecomp-sdk/epsdk-analytics/src/test/java/org/onap/portalsdk/analytics/controller/ErrorHandlerTest.java191
1 files changed, 191 insertions, 0 deletions
diff --git a/ecomp-sdk/epsdk-analytics/src/test/java/org/onap/portalsdk/analytics/controller/ErrorHandlerTest.java b/ecomp-sdk/epsdk-analytics/src/test/java/org/onap/portalsdk/analytics/controller/ErrorHandlerTest.java
new file mode 100644
index 00000000..6c84ce12
--- /dev/null
+++ b/ecomp-sdk/epsdk-analytics/src/test/java/org/onap/portalsdk/analytics/controller/ErrorHandlerTest.java
@@ -0,0 +1,191 @@
+package org.onap.portalsdk.analytics.controller;
+/*
+ * ============LICENSE_START==========================================
+ * ONAP Portal SDK
+ * ===================================================================
+ * Copyright © 2018 AT&T Intellectual Property. All rights reserved.
+ * ===================================================================
+ *
+ * Unless otherwise specified, all software contained herein is licensed
+ * under the Apache License, Version 2.0 (the "License");
+ * you may not use this software 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.
+ *
+ * Unless otherwise specified, all documentation contained herein is licensed
+ * under the Creative Commons License, Attribution 4.0 Intl. (the "License");
+ * you may not use this documentation except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * https://creativecommons.org/licenses/by/4.0/
+ *
+ * Unless required by applicable law or agreed to in writing, documentation
+ * 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.
+ *
+ * ============LICENSE_END============================================
+ *
+ *
+ */
+
+
+import static org.junit.Assert.assertEquals;
+import static org.junit.Assert.assertTrue;
+import static org.mockito.Mockito.when;
+
+import javax.servlet.http.HttpServletRequest;
+import javax.servlet.http.HttpSession;
+
+import org.junit.Before;
+import org.junit.Test;
+import org.junit.runner.RunWith;
+import org.mockito.MockitoAnnotations;
+import org.onap.portalsdk.analytics.error.RaptorException;
+import org.onap.portalsdk.analytics.error.ReportSQLException;
+import org.onap.portalsdk.analytics.model.definition.ReportDefinition;
+import org.onap.portalsdk.analytics.model.runtime.ReportRuntime;
+import org.onap.portalsdk.analytics.system.AppUtils;
+import org.onap.portalsdk.analytics.system.Globals;
+import org.onap.portalsdk.analytics.util.AppConstants;
+import org.onap.portalsdk.analytics.xmlobj.MockitoTestSuite;
+import org.powermock.api.mockito.PowerMockito;
+import org.powermock.core.classloader.annotations.PrepareForTest;
+import org.powermock.modules.junit4.PowerMockRunner;
+
+@RunWith(PowerMockRunner.class)
+@PrepareForTest({Globals.class, AppUtils.class})
+public class ErrorHandlerTest {
+
+ ErrorHandler errorHandler;
+ private String ERROR_MESSAGE = "testErrorMessage";
+ private String TEST_PAGE = "testPage";
+ private String TEST_ID = "testID";
+ private String REPORT_NAME = "testReport";
+ private String REPORT_SQL = "testReportSQL";
+ private String LOG_VAR_IN_SESSION = "test";
+
+ @Before
+ public void setup() {
+ errorHandler = new ErrorHandler();
+ MockitoAnnotations.initMocks(this);
+ }
+
+ MockitoTestSuite mockitoTestSuite = new MockitoTestSuite();
+ HttpServletRequest mockedRequest = mockitoTestSuite.getMockedRequest();
+
+ @Test
+ public void processErrorTest() {
+ when(mockedRequest.getAttribute(AppConstants.RI_ERROR_LIST)).thenReturn(null);
+ errorHandler.processError(mockedRequest, ERROR_MESSAGE);
+ }
+
+ @Test
+ public void processErrorRaptorExceptionTest() {
+ when(mockedRequest.getAttribute(AppConstants.RI_ERROR_LIST)).thenReturn(null);
+ RaptorException re = new RaptorException(ERROR_MESSAGE);
+ errorHandler.processError(mockedRequest, re);
+ }
+
+ @Test
+ public void processFatalErrorTest_WhenReportWrapperIsNotNull() throws Exception{
+ PowerMockito.mockStatic(Globals.class);
+ PowerMockito.mockStatic(AppUtils.class);
+ HttpSession session = mockedRequest.getSession();
+ when(Globals.getLogVariablesInSession()).thenReturn(LOG_VAR_IN_SESSION);
+ ReportRuntime rr = PowerMockito.mock(ReportRuntime.class);
+ when(rr.getReportID()).thenReturn(TEST_ID);
+ when(rr.getReportName()).thenReturn(REPORT_NAME);
+ when(session.getAttribute(AppConstants.SI_REPORT_RUNTIME)).thenReturn(rr);
+ ReportSQLException rse = new ReportSQLException(ERROR_MESSAGE,REPORT_SQL);
+ PowerMockito.doNothing().when(AppUtils.class, "processErrorNotification", new Object[]{mockedRequest, rse});
+ when(AppUtils.getErrorPage()).thenReturn(TEST_PAGE);
+ assertEquals(TEST_PAGE, errorHandler.processFatalError(mockedRequest, rse));
+ }
+
+ @Test
+ public void processFatalErrorTest_WhenReportDefinitionIsNotNull() throws Exception{
+ PowerMockito.mockStatic(Globals.class);
+ PowerMockito.mockStatic(AppUtils.class);
+ HttpSession session = mockedRequest.getSession();
+ when(Globals.getLogVariablesInSession()).thenReturn(LOG_VAR_IN_SESSION);
+ ReportDefinition rd = PowerMockito.mock(ReportDefinition.class);
+ when(rd.getReportID()).thenReturn(TEST_ID);
+ when(rd.getReportName()).thenReturn(REPORT_NAME);
+ when(session.getAttribute(AppConstants.SI_REPORT_DEFINITION)).thenReturn(rd);
+ ReportSQLException rse = new ReportSQLException(ERROR_MESSAGE,REPORT_SQL);
+ PowerMockito.doNothing().when(AppUtils.class, "processErrorNotification", new Object[]{mockedRequest, rse});
+ when(AppUtils.getErrorPage()).thenReturn(TEST_PAGE);
+ assertEquals(TEST_PAGE, errorHandler.processFatalError(mockedRequest, rse));
+ }
+
+ @Test
+ public void processFatalErrorJSONTest_WhenReportWrapperIsNotNull() {
+ PowerMockito.mockStatic(Globals.class);
+ PowerMockito.mockStatic(AppUtils.class);
+ HttpSession session = mockedRequest.getSession();
+ when(Globals.getLogVariablesInSession()).thenReturn(LOG_VAR_IN_SESSION);
+ ReportRuntime rr = PowerMockito.mock(ReportRuntime.class);
+ when(rr.getReportID()).thenReturn(TEST_ID);
+ when(rr.getReportName()).thenReturn(REPORT_NAME);
+ when(session.getAttribute(AppConstants.SI_REPORT_RUNTIME)).thenReturn(rr);
+ ReportSQLException rse = new ReportSQLException(ERROR_MESSAGE,REPORT_SQL);
+ String jsonString = errorHandler.processFatalErrorJSON(mockedRequest, rse);
+ assertTrue(jsonString.contains(ERROR_MESSAGE));
+ }
+
+ @Test
+ public void processFatalErrorJSONTest_WhenReportDefinitionIsNotNull() {
+ PowerMockito.mockStatic(Globals.class);
+ PowerMockito.mockStatic(AppUtils.class);
+ HttpSession session = mockedRequest.getSession();
+ when(Globals.getLogVariablesInSession()).thenReturn(LOG_VAR_IN_SESSION);
+ ReportDefinition rd = PowerMockito.mock(ReportDefinition.class);
+ when(rd.getReportID()).thenReturn(TEST_ID);
+ when(rd.getReportName()).thenReturn(REPORT_NAME);
+ when(session.getAttribute(AppConstants.SI_REPORT_DEFINITION)).thenReturn(rd);
+ ReportSQLException rse = new ReportSQLException(ERROR_MESSAGE,REPORT_SQL);
+ String jsonString = errorHandler.processFatalErrorJSON(mockedRequest, rse);
+ assertTrue(jsonString.contains(ERROR_MESSAGE));
+ }
+
+ @Test
+ public void processFatalErrorWMenuTest_WhenReportWrapperIsNotNull() throws Exception {
+ PowerMockito.mockStatic(Globals.class);
+ PowerMockito.mockStatic(AppUtils.class);
+ when(Globals.getLogVariablesInSession()).thenReturn(LOG_VAR_IN_SESSION);
+ ReportRuntime rr = PowerMockito.mock(ReportRuntime.class);
+ when(rr.getReportID()).thenReturn(TEST_ID);
+ when(rr.getReportName()).thenReturn(REPORT_NAME);
+ HttpSession session = mockedRequest.getSession();
+ when(session.getAttribute(AppConstants.SI_REPORT_RUNTIME)).thenReturn(rr);
+ ReportSQLException rse = new ReportSQLException(ERROR_MESSAGE,REPORT_SQL);
+ PowerMockito.doNothing().when(AppUtils.class, "processErrorNotification", new Object[]{mockedRequest, rse});
+ when(AppUtils.getErrorPageWMenu()).thenReturn(TEST_PAGE);
+ assertEquals(TEST_PAGE, errorHandler.processFatalErrorWMenu(mockedRequest, rse));
+ }
+
+ @Test
+ public void processFatalErrorWMenuTest_WhenReportDefinitionIsNotNull() throws Exception {
+ PowerMockito.mockStatic(Globals.class);
+ PowerMockito.mockStatic(AppUtils.class);
+ when(Globals.getLogVariablesInSession()).thenReturn(LOG_VAR_IN_SESSION);
+ ReportDefinition rd = PowerMockito.mock(ReportDefinition.class);
+ when(rd.getReportID()).thenReturn(TEST_ID);
+ when(rd.getReportName()).thenReturn(REPORT_NAME);
+ HttpSession session = mockedRequest.getSession();
+ when(session.getAttribute(AppConstants.SI_REPORT_DEFINITION)).thenReturn(rd);
+ ReportSQLException rse = new ReportSQLException(ERROR_MESSAGE,REPORT_SQL);
+ PowerMockito.doNothing().when(AppUtils.class, "processErrorNotification", new Object[]{mockedRequest, rse});
+ when(AppUtils.getErrorPageWMenu()).thenReturn(TEST_PAGE);
+ assertEquals(TEST_PAGE, errorHandler.processFatalErrorWMenu(mockedRequest, rse));
+ }
+}