Fix Spike Event Processing with Common Format
[aai/data-router.git] / src / test / java / org / onap / aai / datarouter / policy / SpikeAutosuggestProcessorTest.java
index 8ef5ab6..c49f17b 100644 (file)
@@ -34,66 +34,104 @@ import org.apache.commons.io.IOUtils;
 import org.junit.Before;
 import org.junit.Test;
 import org.onap.aai.datarouter.util.NodeUtils;
-import org.onap.aai.datarouter.util.SearchServiceAgent;
 import org.powermock.api.mockito.PowerMockito;
 
-
-
 public class SpikeAutosuggestProcessorTest {
-  SpikeAutosuggestIndexProcessor policy;
-  String eventJson;
+  private SpikeEventPolicyConfig eventPolicyConfig;
+  private SpikeAutosuggestIndexProcessor policy;
+  private InMemorySearchDatastore searchDb;
 
-  @SuppressWarnings("unchecked")
   @Before
   public void init() throws Exception {
-    SpikeEventPolicyConfig config = PowerMockito.mock(SpikeEventPolicyConfig.class);
-    PowerMockito.when(config.getSearchKeystorePwd()).thenReturn("password");
-    PowerMockito.when(config.getSourceDomain()).thenReturn("JUNIT");
-
-
-    SearchServiceAgent searchServiceAgent = PowerMockito.mock(SearchServiceAgent.class);
-    PowerMockito.whenNew(SearchServiceAgent.class).withAnyArguments()
-        .thenReturn(searchServiceAgent);
-
-
-    policy = new SpikeAutosuggestProcessorStubbed(config);
-    FileInputStream event = new FileInputStream(new File("src/test/resources/spike_event.json"));
-    eventJson = IOUtils.toString(event, "UTF-8");  
+    
+    eventPolicyConfig = new SpikeEventPolicyConfig();
+    eventPolicyConfig.setSearchKeystorePwd("password");
+    eventPolicyConfig.setSourceDomain("JUNIT");
+    
+    searchDb = new InMemorySearchDatastore();
+    policy = new SpikeAutosuggestProcessorStubbed(eventPolicyConfig).withSearchDb(searchDb); 
 
   }
 
   @Test
   public void testProcess_success() throws Exception {
-    policy.process(getExchangeEvent("77777", "create", "generic-vnf"));
+    
+    String genericVnfEventJsonTemplate = IOUtils.toString(
+        new FileInputStream(new File("src/test/resources/generic-vnf-spike-event.json")), "UTF-8");
+  
+    policy.process(getExchangeEvent(genericVnfEventJsonTemplate, "update-notification", "CREATE", "vserver123"));
     
     assertNotNull(
-        InMemorySearchDatastore.get(NodeUtils.generateUniqueShaDigest("junk and Running VNFs")));
+        searchDb.get(NodeUtils.generateUniqueShaDigest("junk and Running VNFs")));
     assertNotNull(
-        InMemorySearchDatastore.get(NodeUtils.generateUniqueShaDigest("junk VNFs")));
+        searchDb.get(NodeUtils.generateUniqueShaDigest("junk VNFs")));
     assertNotNull(
-        InMemorySearchDatastore.get(NodeUtils.generateUniqueShaDigest("Running VNFs")));
-   
+        searchDb.get(NodeUtils.generateUniqueShaDigest("Running VNFs")));
    
   }
+  
+  /*
+   * Failure test cases
+   * - no searchable attribute for type
+   */
+  
   @Test
-  public void testProcess_fail() throws Exception {
-    policy.process(getExchangeEvent("666666", "create", "NotValid"));
-    assertNull(
-        InMemorySearchDatastore.get(NodeUtils.generateUniqueShaDigest("NotValid/666666")));
+  public void testProcess_failure_unknownOxmEntityType() throws Exception {
+    
+    String pserverEventJsonTemplate = IOUtils.toString(
+        new FileInputStream(new File("src/test/resources/optical-router-spike-event.json")), "UTF-8");
     
-    policy.process(getExchangeEvent("", "create", "generic-vnf"));
+    policy.process(getExchangeEvent(pserverEventJsonTemplate, "update-notification", "CREATE", "optronic123"));
+
     assertNull(
-        InMemorySearchDatastore.get(NodeUtils.generateUniqueShaDigest("generic-vnf/")));
+        searchDb.get(NodeUtils.generateUniqueShaDigest("optical-router/optronic123")));
+  }
+  
+  @Test
+  public void testProcess_failure_missingMandatoryFieldsFromBodyObject() throws Exception {
+    
+    String pserverEventJsonTemplate = IOUtils.toString(
+        new FileInputStream(new File("src/test/resources/pserver-missing-mandtory-field-spike-event.json")), "UTF-8");
+    
+    policy.process(getExchangeEvent(pserverEventJsonTemplate, "update-notification", "CREATE", "pserver123"));
 
+    assertNull(
+        searchDb.get(NodeUtils.generateUniqueShaDigest("pserver/pserver123")));
   }
+  
+  @Test
+  public void testProcess_failure_missingMandatoryVertexProperties() throws Exception {
+    
+    String pserverEventJsonTemplate = IOUtils.toString(
+        new FileInputStream(new File("src/test/resources/pserver-missing-primary-key-spike-event.json")), "UTF-8");
+    
+    policy.process(getExchangeEvent(pserverEventJsonTemplate, "update-notification", "CREATE", "pserver123"));
 
+    assertNull(
+        searchDb.get(NodeUtils.generateUniqueShaDigest("pserver/pserver123")));
+  }
   
-  private Exchange getExchangeEvent(String key, String action, String type) {
-    Object obj = eventJson.replace("$KEY", key).replace("$ACTION", action).replace("$TYPE", type);
+  @Test
+  public void testProcess_failure_noSuggestibleAttributesForEntityType() throws Exception {
+    
+    String pserverEventJsonTemplate = IOUtils.toString(
+        new FileInputStream(new File("src/test/resources/vserver-spike-event.json")), "UTF-8");
+    
+    policy.process(getExchangeEvent(pserverEventJsonTemplate, "update-notification", "CREATE", "vserver123"));
+
+    assertNull(
+        searchDb.get(NodeUtils.generateUniqueShaDigest("vserver/vserver123")));
+  }
+    
+  private Exchange getExchangeEvent(String payloadTemplate, String eventType, String operationType,
+      String entityKey) {
+    Object obj = payloadTemplate.replace("$EVENT_TYPE", eventType)
+        .replace("$OPERATION_TYPE", operationType).replace("$ENTITY_KEY", entityKey);
+
     Exchange exchange = PowerMockito.mock(Exchange.class);
     Message inMessage = PowerMockito.mock(Message.class);
     Message outMessage = PowerMockito.mock(Message.class);
-    PowerMockito.when(exchange.getIn()).thenReturn(inMessage); 
+    PowerMockito.when(exchange.getIn()).thenReturn(inMessage);
     PowerMockito.when(inMessage.getBody()).thenReturn(obj);
 
     PowerMockito.when(exchange.getOut()).thenReturn(outMessage);
@@ -105,5 +143,4 @@ public class SpikeAutosuggestProcessorTest {
   }
 
 
-
 }