TCA: Support for VES/A&AI enrichment
[dcaegen2/analytics/tca.git] / dcae-analytics-cdap-tca / src / test / java / org / openecomp / dcae / apod / analytics / cdap / tca / worker / TCADMaaPMRPublisherJobTest.java
index 5f7e989..8028dd4 100644 (file)
-/*
- * ===============================LICENSE_START======================================
- *  dcae-analytics
- * ================================================================================
- *    Copyright © 2017 AT&T Intellectual Property. All rights reserved.
- * ================================================================================
- *  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.
- *  ============================LICENSE_END===========================================
- */
-
-package org.openecomp.dcae.apod.analytics.cdap.tca.worker;
-
-import co.cask.cdap.api.TxRunnable;
-import co.cask.cdap.api.metrics.Metrics;
-import co.cask.cdap.api.worker.WorkerContext;
-import org.junit.Before;
-import org.junit.Test;
-import org.mockito.ArgumentMatchers;
-import org.openecomp.dcae.apod.analytics.cdap.common.CDAPMetricsConstants;
-import org.openecomp.dcae.apod.analytics.cdap.common.persistance.tca.TCAVESAlertEntity;
-import org.openecomp.dcae.apod.analytics.cdap.tca.BaseAnalyticsCDAPTCAUnitTest;
-import org.openecomp.dcae.apod.analytics.common.AnalyticsConstants;
-import org.openecomp.dcae.apod.analytics.dmaap.domain.response.DMaaPMRPublisherResponse;
-import org.openecomp.dcae.apod.analytics.dmaap.service.publisher.DMaaPMRPublisher;
-import org.quartz.JobDataMap;
-import org.quartz.JobExecutionContext;
-
-import java.util.HashMap;
-import java.util.Map;
-import java.util.Set;
-
-import static org.mockito.ArgumentMatchers.any;
-import static org.mockito.ArgumentMatchers.anyInt;
-import static org.mockito.ArgumentMatchers.anyString;
-import static org.mockito.ArgumentMatchers.eq;
-import static org.mockito.Mockito.doNothing;
-import static org.mockito.Mockito.mock;
-import static org.mockito.Mockito.times;
-import static org.mockito.Mockito.verify;
-import static org.mockito.Mockito.when;
-
-/**
- * @author Rajiv Singla . Creation Date: 12/20/2016.
- */
-public class TCADMaaPMRPublisherJobTest extends BaseAnalyticsCDAPTCAUnitTest {
-
-    private JobExecutionContext jobExecutionContext;
-    private TCADMaaPMRPublisherJob publisherJob;
-    private JobDataMap jobDataMap;
-    private WorkerContext workerContext;
-    private DMaaPMRPublisher publisher;
-    private Metrics metrics;
-
-    private class TCATestDMaaPMRPublisherJob extends TCADMaaPMRPublisherJob {
-
-        private Map<String, TCAVESAlertEntity> alertEntityMap;
-
-        public TCATestDMaaPMRPublisherJob(Map<String, TCAVESAlertEntity> alertEntityMap) {
-            this.alertEntityMap = alertEntityMap;
-        }
-
-        @Override
-        protected Map<String, TCAVESAlertEntity> getNewAlertsMap(
-                String cdapAlertsTableName, WorkerContext workerContext) {
-            return alertEntityMap;
-        }
-
-        @Override
-        protected void deleteAlertsByKey(String cdapAlertsTableName, WorkerContext workerContext,
-                                         Set<String> rowKeys, Metrics metrics) {
-            // do nothing
-        }
-    }
-
-    @Before
-    public void before() throws Exception {
-
-        jobExecutionContext = mock(JobExecutionContext.class);
-        workerContext = mock(WorkerContext.class);
-
-        metrics = mock(Metrics.class);
-        doNothing().when(metrics).count(anyString(), anyInt());
-        publisher = mock(DMaaPMRPublisher.class);
-
-        jobDataMap = mock(JobDataMap.class);
-        when(jobDataMap.getString(eq(AnalyticsConstants.CDAP_ALERTS_TABLE_VARIABLE_NAME))).thenReturn
-                ("testAlertTableName");
-        when(jobDataMap.get(eq(AnalyticsConstants.WORKER_CONTEXT_VARIABLE_NAME))).thenReturn(workerContext);
-        when(jobDataMap.get(eq(AnalyticsConstants.DMAAP_PUBLISHER_VARIABLE_NAME))).thenReturn(publisher);
-        when(jobDataMap.get(AnalyticsConstants.DMAAP_METRICS_VARIABLE_NAME)).thenReturn(metrics);
-        when(jobExecutionContext.getMergedJobDataMap()).thenReturn(jobDataMap);
-
-
-        publisherJob = new TCADMaaPMRPublisherJob();
-    }
-
-    @Test
-    public void testExecuteWhenNoAlertsFoundInAlertsTable() throws Exception {
-        doNothing().when(workerContext).execute(any(TxRunnable.class));
-        publisherJob.execute(jobExecutionContext);
-        verify(metrics, times(1))
-                .count(eq(CDAPMetricsConstants.TCA_PUBLISHER_NO_NEW_ALERTS_LOOKUP_METRIC), eq(1));
-    }
-
-    @Test
-    public void testExecuteWhenAlertsWereFoundInAlertsTable() throws Exception {
-
-        final DMaaPMRPublisherResponse publisherResponse = mock(DMaaPMRPublisherResponse.class);
-        when(publisherResponse.getResponseCode()).thenReturn(200);
-        when(publisherResponse.getResponseMessage()).thenReturn("success");
-        when(publisherResponse.getPendingMessagesCount()).thenReturn(0);
-        when(publisher.publish(ArgumentMatchers.<String>anyList())).thenReturn(publisherResponse);
-
-        final TCAVESAlertEntity tcavesAlertEntity = mock(TCAVESAlertEntity.class);
-        when(tcavesAlertEntity.getAlertMessage()).thenReturn("testAlertMessage");
-        Map<String, TCAVESAlertEntity> alertEntityMap = new HashMap<>();
-        alertEntityMap.put("key1", tcavesAlertEntity);
-        final TCATestDMaaPMRPublisherJob testPublisherJob = new TCATestDMaaPMRPublisherJob(alertEntityMap);
-        testPublisherJob.execute(jobExecutionContext);
-        verify(metrics, times(1))
-                .count(eq(CDAPMetricsConstants.TCA_PUBLISHER_NEW_ALERTS_METRIC), eq(1));
-        verify(metrics, times(1))
-                .count(eq(CDAPMetricsConstants.TCA_PUBLISHER_SUCCESSFUL_DMAAP_RESPONSE_METRIC), eq(1));
-    }
-
-    @Test
-    public void testExecuteWhenAlertsWereFoundButPublisherReturnedNon200ResponseCode() throws Exception {
-
-        final DMaaPMRPublisherResponse publisherResponse = mock(DMaaPMRPublisherResponse.class);
-        when(publisherResponse.getResponseCode()).thenReturn(500);
-        when(publisherResponse.getResponseMessage()).thenReturn("failed");
-        when(publisherResponse.getPendingMessagesCount()).thenReturn(0);
-        when(publisher.publish(ArgumentMatchers.<String>anyList())).thenReturn(publisherResponse);
-
-        final TCAVESAlertEntity tcavesAlertEntity = mock(TCAVESAlertEntity.class);
-        when(tcavesAlertEntity.getAlertMessage()).thenReturn("testAlertMessage");
-        Map<String, TCAVESAlertEntity> alertEntityMap = new HashMap<>();
-        alertEntityMap.put("key1", tcavesAlertEntity);
-        final TCATestDMaaPMRPublisherJob testPublisherJob = new TCATestDMaaPMRPublisherJob(alertEntityMap);
-        testPublisherJob.execute(jobExecutionContext);
-        verify(metrics, times(1))
-                .count(eq(CDAPMetricsConstants.TCA_PUBLISHER_NEW_ALERTS_METRIC), eq(1));
-        verify(metrics, times(1))
-                .count(eq(CDAPMetricsConstants.TCA_PUBLISHER_UNSUCCESSFUL_DMAAP_RESPONSE_METRIC), eq(1));
-    }
-
-
-}
+/*\r
+ * ===============================LICENSE_START======================================\r
+ *  dcae-analytics\r
+ * ================================================================================\r
+ *    Copyright © 2017 AT&T Intellectual Property. All rights reserved.\r
+ * ================================================================================\r
+ *  Licensed under the Apache License, Version 2.0 (the "License");\r
+ *  you may not use this file except in compliance with the License.\r
+ *   You may obtain a copy of the License at\r
+ *\r
+ *          http://www.apache.org/licenses/LICENSE-2.0\r
+ *\r
+ *  Unless required by applicable law or agreed to in writing, software\r
+ *  distributed under the License is distributed on an "AS IS" BASIS,\r
+ *  WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\r
+ *  See the License for the specific language governing permissions and\r
+ *  limitations under the License.\r
+ *  ============================LICENSE_END===========================================\r
+ */\r
+\r
+package org.openecomp.dcae.apod.analytics.cdap.tca.worker;\r
+\r
+import co.cask.cdap.api.TxRunnable;\r
+import co.cask.cdap.api.metrics.Metrics;\r
+import co.cask.cdap.api.worker.WorkerContext;\r
+import org.junit.Before;\r
+import org.junit.Test;\r
+import org.mockito.ArgumentMatchers;\r
+import org.openecomp.dcae.apod.analytics.cdap.common.CDAPMetricsConstants;\r
+import org.openecomp.dcae.apod.analytics.cdap.common.persistance.tca.TCAVESAlertEntity;\r
+import org.openecomp.dcae.apod.analytics.cdap.tca.BaseAnalyticsCDAPTCAUnitTest;\r
+import org.openecomp.dcae.apod.analytics.common.AnalyticsConstants;\r
+import org.openecomp.dcae.apod.analytics.dmaap.domain.response.DMaaPMRPublisherResponse;\r
+import org.openecomp.dcae.apod.analytics.dmaap.service.publisher.DMaaPMRPublisher;\r
+import org.quartz.JobDataMap;\r
+import org.quartz.JobExecutionContext;\r
+\r
+import java.util.HashMap;\r
+import java.util.Map;\r
+import java.util.Set;\r
+\r
+import static org.mockito.ArgumentMatchers.any;\r
+import static org.mockito.ArgumentMatchers.anyInt;\r
+import static org.mockito.ArgumentMatchers.anyString;\r
+import static org.mockito.ArgumentMatchers.eq;\r
+import static org.mockito.Mockito.doNothing;\r
+import static org.mockito.Mockito.mock;\r
+import static org.mockito.Mockito.times;\r
+import static org.mockito.Mockito.verify;\r
+import static org.mockito.Mockito.when;\r
+\r
+/**\r
+ * @author Rajiv Singla . Creation Date: 12/20/2016.\r
+ */\r
+public class TCADMaaPMRPublisherJobTest extends BaseAnalyticsCDAPTCAUnitTest {\r
+\r
+    private JobExecutionContext jobExecutionContext;\r
+    private TCADMaaPMRPublisherJob publisherJob;\r
+    private JobDataMap jobDataMap;\r
+    private WorkerContext workerContext;\r
+    private DMaaPMRPublisher publisher;\r
+    private Metrics metrics;\r
+\r
+    private class TCATestDMaaPMRPublisherJob extends TCADMaaPMRPublisherJob {\r
+\r
+        private Map<String, TCAVESAlertEntity> alertEntityMap;\r
+\r
+        public TCATestDMaaPMRPublisherJob(Map<String, TCAVESAlertEntity> alertEntityMap) {\r
+            this.alertEntityMap = alertEntityMap;\r
+        }\r
+\r
+        @Override\r
+        protected Map<String, TCAVESAlertEntity> getNewAlertsMap(\r
+                String cdapAlertsTableName, WorkerContext workerContext) {\r
+            return alertEntityMap;\r
+        }\r
+\r
+        @Override\r
+        protected void deleteAlertsByKey(String cdapAlertsTableName, WorkerContext workerContext,\r
+                                         Set<String> rowKeys, Metrics metrics) {\r
+            // do nothing\r
+        }\r
+    }\r
+\r
+    @Before\r
+    public void before() throws Exception {\r
+\r
+        jobExecutionContext = mock(JobExecutionContext.class);\r
+        workerContext = mock(WorkerContext.class);\r
+\r
+        metrics = mock(Metrics.class);\r
+        doNothing().when(metrics).count(anyString(), anyInt());\r
+        publisher = mock(DMaaPMRPublisher.class);\r
+\r
+        jobDataMap = mock(JobDataMap.class);\r
+        when(jobDataMap.getString(eq(AnalyticsConstants.CDAP_ALERTS_TABLE_VARIABLE_NAME))).thenReturn\r
+                ("testAlertTableName");\r
+        when(jobDataMap.get(eq(AnalyticsConstants.WORKER_CONTEXT_VARIABLE_NAME))).thenReturn(workerContext);\r
+        when(jobDataMap.get(eq(AnalyticsConstants.DMAAP_PUBLISHER_VARIABLE_NAME))).thenReturn(publisher);\r
+        when(jobDataMap.get(AnalyticsConstants.DMAAP_METRICS_VARIABLE_NAME)).thenReturn(metrics);\r
+        when(jobExecutionContext.getMergedJobDataMap()).thenReturn(jobDataMap);\r
+\r
+\r
+        publisherJob = new TCADMaaPMRPublisherJob();\r
+    }\r
+\r
+    @Test\r
+    public void testExecuteWhenNoAlertsFoundInAlertsTable() throws Exception {\r
+        doNothing().when(workerContext).execute(any(TxRunnable.class));\r
+        publisherJob.execute(jobExecutionContext);\r
+        verify(metrics, times(1))\r
+                .count(eq(CDAPMetricsConstants.TCA_PUBLISHER_NO_NEW_ALERTS_LOOKUP_METRIC), eq(1));\r
+    }\r
+\r
+    @Test\r
+    public void testExecuteWhenAlertsWereFoundInAlertsTable() throws Exception {\r
+\r
+        final DMaaPMRPublisherResponse publisherResponse = mock(DMaaPMRPublisherResponse.class);\r
+        when(publisherResponse.getResponseCode()).thenReturn(200);\r
+        when(publisherResponse.getResponseMessage()).thenReturn("success");\r
+        when(publisherResponse.getPendingMessagesCount()).thenReturn(0);\r
+        when(publisher.publish(ArgumentMatchers.<String>anyList())).thenReturn(publisherResponse);\r
+\r
+        final TCAVESAlertEntity tcavesAlertEntity = mock(TCAVESAlertEntity.class);\r
+        when(tcavesAlertEntity.getAlertMessage()).thenReturn("testAlertMessage");\r
+        Map<String, TCAVESAlertEntity> alertEntityMap = new HashMap<>();\r
+        alertEntityMap.put("key1", tcavesAlertEntity);\r
+        final TCATestDMaaPMRPublisherJob testPublisherJob = new TCATestDMaaPMRPublisherJob(alertEntityMap);\r
+        testPublisherJob.execute(jobExecutionContext);\r
+        verify(metrics, times(1))\r
+                .count(eq(CDAPMetricsConstants.TCA_PUBLISHER_NEW_ALERTS_METRIC), eq(1));\r
+        verify(metrics, times(1))\r
+                .count(eq(CDAPMetricsConstants.TCA_PUBLISHER_SUCCESSFUL_DMAAP_RESPONSE_METRIC), eq(1));\r
+    }\r
+\r
+    @Test\r
+    public void testExecuteWhenAlertsWereFoundButPublisherReturnedNon200ResponseCode() throws Exception {\r
+\r
+        final DMaaPMRPublisherResponse publisherResponse = mock(DMaaPMRPublisherResponse.class);\r
+        when(publisherResponse.getResponseCode()).thenReturn(500);\r
+        when(publisherResponse.getResponseMessage()).thenReturn("failed");\r
+        when(publisherResponse.getPendingMessagesCount()).thenReturn(0);\r
+        when(publisher.publish(ArgumentMatchers.<String>anyList())).thenReturn(publisherResponse);\r
+\r
+        final TCAVESAlertEntity tcavesAlertEntity = mock(TCAVESAlertEntity.class);\r
+        when(tcavesAlertEntity.getAlertMessage()).thenReturn("testAlertMessage");\r
+        Map<String, TCAVESAlertEntity> alertEntityMap = new HashMap<>();\r
+        alertEntityMap.put("key1", tcavesAlertEntity);\r
+        final TCATestDMaaPMRPublisherJob testPublisherJob = new TCATestDMaaPMRPublisherJob(alertEntityMap);\r
+        testPublisherJob.execute(jobExecutionContext);\r
+        verify(metrics, times(1))\r
+                .count(eq(CDAPMetricsConstants.TCA_PUBLISHER_NEW_ALERTS_METRIC), eq(1));\r
+        verify(metrics, times(1))\r
+                .count(eq(CDAPMetricsConstants.TCA_PUBLISHER_UNSUCCESSFUL_DMAAP_RESPONSE_METRIC), eq(1));\r
+    }\r
+\r
+\r
+}\r