Add Unit Tests 17/29017/1
authorGuangrong Fu <fu.guangrong@zte.com.cn>
Wed, 24 Jan 2018 09:32:24 +0000 (17:32 +0800)
committerGuangrong Fu <fu.guangrong@zte.com.cn>
Wed, 24 Jan 2018 09:32:24 +0000 (17:32 +0800)
Change-Id: I87a60d05b7046dab91785bf959fa391fd24c7371
Issue-ID: HOLMES-97
Signed-off-by: Guangrong Fu <fu.guangrong@zte.com.cn>
dmaap-dsa/src/main/java/org/onap/holmes/dsa/dmaappolling/DMaaPResponseUtil.java
dmaap-dsa/src/test/java/org/onap/holmes/dsa/dmaappolling/DMaaPResponseUtilTest.java
dmaap-dsa/src/test/java/org/onap/holmes/dsa/dmaappolling/SubscriberTest.java [new file with mode: 0644]

index 6679327..5dffc7d 100644 (file)
@@ -100,7 +100,7 @@ public class DMaaPResponseUtil {
                     if(alarm.has("name") && alarm.has("value")) {
                         AlarmAdditionalField field = new AlarmAdditionalField();
                         field.setName(getTextElementByNode(alarm, "name"));
-                        field.setName(getTextElementByNode(alarm, "value"));
+                        field.setValue(getTextElementByNode(alarm, "value"));
                         alarms.add(field);
                     }
                 });
index 6737868..aacbee3 100644 (file)
@@ -16,7 +16,7 @@
 package org.onap.holmes.dsa.dmaappolling;
 
 import static org.hamcrest.CoreMatchers.equalTo;
-import static org.hamcrest.MatcherAssert.assertThat;
+import static org.junit.Assert.assertThat;
 
 import java.io.IOException;
 import java.util.ArrayList;
@@ -300,7 +300,7 @@ public class DMaaPResponseUtilTest {
         List<AlarmAdditionalField> alarmAdditionalFields = new ArrayList<>();
         AlarmAdditionalField alarmAdditionalField = new AlarmAdditionalField();
         alarmAdditionalField.setName("tian");
-        alarmAdditionalField.setName("22222");
+        alarmAdditionalField.setValue("22222");
         alarmAdditionalFields.add(alarmAdditionalField);
         expected.setAlarmAdditionalInformation(alarmAdditionalFields);
 
diff --git a/dmaap-dsa/src/test/java/org/onap/holmes/dsa/dmaappolling/SubscriberTest.java b/dmaap-dsa/src/test/java/org/onap/holmes/dsa/dmaappolling/SubscriberTest.java
new file mode 100644 (file)
index 0000000..d1d3653
--- /dev/null
@@ -0,0 +1,184 @@
+/*
+ * Copyright 2017 ZTE Corporation.
+ *
+ * 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.onap.holmes.dsa.dmaappolling;
+
+import com.fasterxml.jackson.databind.ObjectMapper;
+import com.sun.org.apache.regexp.internal.RE;
+import io.dropwizard.cli.Cli;
+import org.easymock.EasyMock;
+import org.glassfish.hk2.api.ServiceLocator;
+import org.glassfish.jersey.client.ClientConfig;
+import org.junit.Before;
+import org.junit.Test;
+import org.junit.runner.RunWith;
+import org.onap.holmes.common.api.stat.AlarmAdditionalField;
+import org.onap.holmes.common.api.stat.VesAlarm;
+import org.onap.holmes.common.dropwizard.ioc.utils.ServiceLocatorHolder;
+import org.powermock.api.easymock.PowerMock;
+import org.powermock.core.classloader.annotations.PrepareForTest;
+import org.powermock.modules.junit4.PowerMockRunner;
+
+import javax.ws.rs.client.Client;
+import javax.ws.rs.client.ClientBuilder;
+import javax.ws.rs.client.Invocation;
+import javax.ws.rs.client.WebTarget;
+import javax.ws.rs.core.Response;
+
+import java.util.ArrayList;
+import java.util.List;
+
+import static org.hamcrest.CoreMatchers.equalTo;
+import static org.hamcrest.CoreMatchers.is;
+import static org.hamcrest.CoreMatchers.nullValue;
+import static org.junit.Assert.*;
+
+@PrepareForTest({ServiceLocatorHolder.class, ServiceLocator.class, ClientBuilder.class,
+    WebTarget.class, Response.class, Invocation.Builder.class, Client.class})
+@RunWith(PowerMockRunner.class)
+public class SubscriberTest {
+
+    private DMaaPResponseUtil util = new DMaaPResponseUtil();
+
+    @Before
+    public void init() {
+        PowerMock.mockStatic(ServiceLocatorHolder.class);
+        ServiceLocator serviceLocator = PowerMock.createMock(ServiceLocator.class);
+        EasyMock.expect(ServiceLocatorHolder.getLocator()).andReturn(serviceLocator);
+        EasyMock.expect(serviceLocator.getService(DMaaPResponseUtil.class)).andReturn(util);
+    }
+
+    @Test
+    public void subscribe() throws Exception {
+
+        VesAlarm vesAlarm = new VesAlarm();
+        vesAlarm.setDomain("ONAP");
+        vesAlarm.setEventId("123");
+        vesAlarm.setEventName("Event-123");
+        vesAlarm.setEventType("EventType");
+        vesAlarm.setLastEpochMicrosec(1000L);
+        vesAlarm.setNfcNamingCode("123");
+        vesAlarm.setNfNamingCode("123");
+        vesAlarm.setPriority("high");
+        vesAlarm.setReportingEntityId("ID-123");
+        vesAlarm.setReportingEntityName("Name-123");
+        vesAlarm.setSequence(1);
+        vesAlarm.setSourceId("Source-123");
+        vesAlarm.setSourceName("Source-123");
+        vesAlarm.setStartEpochMicrosec(500L);
+        vesAlarm.setVersion(1L);
+        List<AlarmAdditionalField> alarmAdditionalFields = new ArrayList<>();
+        AlarmAdditionalField field = new AlarmAdditionalField();
+        field.setName("addInfo");
+        field.setValue("addInfo");
+        alarmAdditionalFields.add(field);
+        vesAlarm.setAlarmAdditionalInformation(alarmAdditionalFields);
+        vesAlarm.setAlarmCondition("alarmCondition");
+        vesAlarm.setAlarmInterfaceA("alarmInterfaceA");
+        vesAlarm.setEventCategory("eventCategory");
+        vesAlarm.setEventSeverity("eventSeverity");
+        vesAlarm.setEventSourceType("eventSourceType");
+        vesAlarm.setFaultFieldsVersion(1L);
+        vesAlarm.setSpecificProblem("specificProblem");
+        vesAlarm.setVfStatus("vfStatus");
+
+        String eventString = "{\"event\": {\"commonEventHeader\": {" +
+                "\"domain\": \"ONAP\"," +
+                "\"eventId\": \"123\"," +
+                "\"eventName\": \"Event-123\"," +
+                "\"eventType\": \"EventType\"," +
+                "\"lastEpochMicrosec\": 1000," +
+                "\"nfcNamingCode\": \"123\"," +
+                "\"nfNamingCode\": \"123\"," +
+                "\"priority\": \"high\"," +
+                "\"reportingEntityId\": \"ID-123\"," +
+                "\"reportingEntityName\": \"Name-123\"," +
+                "\"sequence\": 1," +
+                "\"sourceId\": \"Source-123\"," +
+                "\"sourceName\": \"Source-123\"," +
+                "\"startEpochMicrosec\": 500," +
+                "\"version\": 1" +
+                "}," +
+                " \"faultFields\" : {" +
+                "\"alarmAdditionalInformation\": [{\"name\":\"addInfo\", \"value\":\"addInfo\"}]," +
+                "\"alarmCondition\": \"alarmCondition\"," +
+                "\"alarmInterfaceA\": \"alarmInterfaceA\"," +
+                "\"eventCategory\": \"eventCategory\"," +
+                "\"eventSeverity\": \"eventSeverity\"," +
+                "\"eventSourceType\": \"eventSourceType\"," +
+                "\"faultFieldsVersion\": 1," +
+                "\"specificProblem\": \"specificProblem\"," +
+                "\"vfStatus\": \"vfStatus\"" +
+                "}}}";
+
+        List<String> responseList = new ArrayList<>();
+        responseList.add(eventString);
+
+
+        PowerMock.mockStatic(ClientBuilder.class);
+        Client client = PowerMock.createMock(Client.class);
+        WebTarget webTarget = PowerMock.createMock(WebTarget.class);
+        Response response = PowerMock.createMock(Response.class);
+        Invocation.Builder builder = PowerMock.createMock(Invocation.Builder.class);
+
+        EasyMock.expect(ClientBuilder.newClient(EasyMock.anyObject(ClientConfig.class))).andReturn(client);
+        EasyMock.expect(client.target(EasyMock.anyObject(String.class))).andReturn(webTarget);
+        EasyMock.expect(webTarget.queryParam("timeout", 15000)).andReturn(webTarget);
+        EasyMock.expect(webTarget.request()).andReturn(builder);
+        EasyMock.expect(builder.get()).andReturn(response);
+        EasyMock.expect(response.readEntity(List.class)).andReturn(responseList);
+
+        PowerMock.replayAll();
+
+        List<VesAlarm> vesAlarms = new Subscriber().subscribe();
+
+        assertThat(new ObjectMapper().writeValueAsString(vesAlarm),
+                equalTo(new ObjectMapper().writeValueAsString(vesAlarms.get(0))));
+
+        PowerMock.verifyAll();
+    }
+
+    @Test
+    public void testSetterAndGetter() {
+
+        PowerMock.replayAll();
+
+        Subscriber subscriber = new Subscriber();
+        subscriber.setTimeout(100);
+        subscriber.setLimit(10);
+        subscriber.setPeriod(10);
+        subscriber.setSecure(false);
+        subscriber.setTopic("test");
+        subscriber.setUrl("http://localhost");
+        subscriber.setConsumerGroup("Group1");
+        subscriber.setConsumer("Consumer1");
+        subscriber.setAuthInfo(null);
+        subscriber.setAuthExpDate(null);
+
+        assertThat(subscriber.getTimeout(), is(100));
+        assertThat(subscriber.getLimit(), is(10));
+        assertThat(subscriber.getPeriod(), is(10));
+        assertThat(subscriber.isSecure(), is(false));
+        assertThat(subscriber.getTopic(), equalTo("test"));
+        assertThat(subscriber.getUrl(), equalTo("http://localhost"));
+        assertThat(subscriber.getConsumerGroup(), equalTo("Group1"));
+        assertThat(subscriber.getConsumer(), equalTo("Consumer1"));
+        assertThat(subscriber.getAuthInfo(), nullValue());
+        assertThat(subscriber.getAuthExpDate(), nullValue());
+
+        PowerMock.verifyAll();
+    }
+
+}
\ No newline at end of file