Enhance SchemaGenerator to also generate indices for relationships
[aai/aai-common.git] / aai-core / src / test / java / org / onap / aai / serialization / queryformats / ResourceWithSoTTest.java
index ad28e69..a1206b5 100644 (file)
  * limitations under the License.
  * ============LICENSE_END=========================================================
  */
+
 package org.onap.aai.serialization.queryformats;
 
+import static org.junit.Assert.*;
+import static org.mockito.Mockito.spy;
+import static org.mockito.Mockito.when;
+
 import com.google.gson.JsonObject;
-import org.apache.tinkerpop.gremlin.process.traversal.dsl.graph.GraphTraversalSource;
+
+import java.util.Optional;
+
 import org.apache.tinkerpop.gremlin.process.traversal.strategy.verification.ReadOnlyStrategy;
 import org.apache.tinkerpop.gremlin.structure.Graph;
 import org.apache.tinkerpop.gremlin.structure.Vertex;
@@ -30,7 +37,6 @@ import org.junit.Test;
 import org.mockito.Mock;
 import org.mockito.MockitoAnnotations;
 import org.onap.aai.AAISetup;
-import org.onap.aai.dbmap.DBConnectionType;
 import org.onap.aai.exceptions.AAIException;
 import org.onap.aai.introspection.Loader;
 import org.onap.aai.introspection.ModelType;
@@ -41,13 +47,10 @@ import org.onap.aai.serialization.engines.TransactionalGraphEngine;
 import org.onap.aai.serialization.queryformats.exceptions.AAIFormatVertexException;
 import org.onap.aai.serialization.queryformats.utils.UrlBuilder;
 import org.onap.aai.setup.SchemaVersion;
+import org.springframework.test.annotation.DirtiesContext;
+import org.springframework.test.annotation.DirtiesContext.ClassMode;
 
-import static org.junit.Assert.assertEquals;
-import static org.junit.Assert.assertNull;
-import static org.junit.Assert.assertTrue;
-import static org.mockito.Mockito.spy;
-import static org.mockito.Mockito.when;
-
+@DirtiesContext(classMode=ClassMode.BEFORE_CLASS)
 public class ResourceWithSoTTest extends AAISetup {
     @Mock
     private UrlBuilder urlBuilder;
@@ -57,9 +60,9 @@ public class ResourceWithSoTTest extends AAISetup {
     private Vertex patchVertex1;
     private Vertex patchVertex2;
 
-    private JsonObject jsonPutObj = new JsonObject() ;
-    private JsonObject jsonPatchObj1 = new JsonObject() ;
-    private JsonObject jsonPatchObj2 = new JsonObject() ;
+    private JsonObject jsonPutObj = new JsonObject();
+    private JsonObject jsonPatchObj1 = new JsonObject();
+    private JsonObject jsonPatchObj2 = new JsonObject();
 
     private SchemaVersion version;
     private ResourceWithSoT resourceWithSoT;
@@ -73,12 +76,12 @@ public class ResourceWithSoTTest extends AAISetup {
     public void setUp() throws Exception {
 
         version = schemaVersions.getDefaultVersion();
-        MockitoAnnotations.initMocks(this);
+        MockitoAnnotations.openMocks(this);
 
         graph = TinkerGraph.open();
 
-        Long currentTimeMs = System.currentTimeMillis();
-        String timeNowInMs = Long.toString(currentTimeMs);
+        long currentTimeMs = System.currentTimeMillis();
+        final String timeNowInMs = Long.toString(currentTimeMs);
 
         // PUT / CREATE
         jsonPutObj.addProperty("aai-created-ts", timeNowInMs);
@@ -87,12 +90,8 @@ public class ResourceWithSoTTest extends AAISetup {
         jsonPutObj.addProperty("last-mod-source-of-truth", "user_a");
         jsonPutObj.addProperty("last-action-performed", "Created");
 
-        putVertex = graph.addVertex(
-            "aai-created-ts", timeNowInMs,
-            "aai-last-mod-ts", timeNowInMs,
-            "source-of-truth", "user_a",
-            "last-mod-source-of-truth", "user_a"
-        );
+        putVertex = graph.addVertex("aai-created-ts", timeNowInMs, "aai-last-mod-ts", timeNowInMs, "source-of-truth",
+                "user_a", "last-mod-source-of-truth", "user_a");
 
         // PATCH / MODIFY with differing source of truths
         jsonPatchObj1.addProperty("aai-created-ts", timeNowInMs);
@@ -101,12 +100,8 @@ public class ResourceWithSoTTest extends AAISetup {
         jsonPatchObj1.addProperty("last-mod-source-of-truth", "user_b");
         jsonPatchObj1.addProperty("last-action-performed", "Modified");
 
-        patchVertex1 = graph.addVertex(
-            "aai-created-ts", timeNowInMs,
-            "aai-last-mod-ts", timeNowInMs,
-            "source-of-truth", "user_a",
-            "last-mod-source-of-truth", "user_b"
-        );
+        patchVertex1 = graph.addVertex("aai-created-ts", timeNowInMs, "aai-last-mod-ts", timeNowInMs, "source-of-truth",
+                "user_a", "last-mod-source-of-truth", "user_b");
 
         // PATCH / MODIFY with differing time stamps
         jsonPatchObj2.addProperty("aai-created-ts", timeNowInMs);
@@ -115,22 +110,36 @@ public class ResourceWithSoTTest extends AAISetup {
         jsonPatchObj2.addProperty("last-mod-source-of-truth", "user_a");
         jsonPatchObj2.addProperty("last-action-performed", "Modified");
 
-        patchVertex2 = graph.addVertex(
-            "aai-created-ts", timeNowInMs,
-            "aai-last-mod-ts", Long.toString(currentTimeMs + 1000),
-            "source-of-truth", "user_a",
-            "last-mod-source-of-truth", "user_a"
-        );
+        patchVertex2 = graph.addVertex("aai-created-ts", timeNowInMs, "aai-last-mod-ts",
+                Long.toString(currentTimeMs + 1000), "source-of-truth", "user_a", "last-mod-source-of-truth", "user_a");
 
         graph = TinkerGraph.open();
         createLoaderEngineSetup();
     }
 
+    public void createLoaderEngineSetup() throws AAIException {
+
+        loader = loaderFactory.createLoaderForVersion(factoryType, version);
+
+        dbEngine = spy(new JanusGraphDBEngine(QueryStyle.TRAVERSAL, loader));
+        serializer = new DBSerializer(version, dbEngine, factoryType, "Junit");
+        resourceWithSoT = new ResourceWithSoT.Builder(loader, serializer, urlBuilder).build();
+
+        TransactionalGraphEngine.Admin spyAdmin = spy(dbEngine.asAdmin());
+
+        when(dbEngine.tx()).thenReturn(graph);
+        when(dbEngine.asAdmin()).thenReturn(spyAdmin);
+
+        when(spyAdmin.getReadOnlyTraversalSource())
+                .thenReturn(graph.traversal().withStrategies(ReadOnlyStrategy.instance()));
+        when(spyAdmin.getTraversalSource()).thenReturn(graph.traversal());
+    }
+
     // This test is to simulate a PUT request
     @Test
     public void testGetJsonFromVertexWithCreateVertex() throws AAIFormatVertexException, AAIException {
         if (putVertex == null)
-            assertTrue("The vertex used for this test is null. Fail immediately.", false);
+            fail("The vertex used for this test is null. Fail immediately.");
 
         JsonObject json = resourceWithSoT.getJsonFromVertex(putVertex).get();
         assertEquals(jsonPutObj, json);
@@ -140,42 +149,24 @@ public class ResourceWithSoTTest extends AAISetup {
     @Test
     public void testGetJsonFromVertexWithModifyVertex() throws AAIFormatVertexException, AAIException {
         if (patchVertex1 == null)
-            assertTrue("The vertex 1 used for this test is null. Fail immediately.", false);
+            fail("The vertex 1 used for this test is null. Fail immediately.");
         if (patchVertex2 == null)
-            assertTrue("The vertex 2 used for this test is null. Fail immediately.", false);
+            fail("The vertex 2 used for this test is null. Fail immediately.");
 
         // Differing Source of Truths will indicate that the action performed modified the vertex
         JsonObject json1 = resourceWithSoT.getJsonFromVertex(patchVertex1).get();
         assertEquals(jsonPatchObj1, json1);
 
-        // Timestamps that have a large span in time difference will (likely) indicate that the transaction was not a create (thus, modify)
+        // Timestamps that have a large span in time difference will (likely) indicate that the transaction was not a
+        // create (thus, modify)
         JsonObject json2 = resourceWithSoT.getJsonFromVertex(patchVertex2).get();
         assertEquals(jsonPatchObj2, json2);
     }
 
     @Test
-    public void testGetJsonFromVertexWithNullVertex() throws AAIFormatVertexException, AAIException {
-        // Null check, will return null.
-        assertNull(resourceWithSoT.getJsonFromVertex(null));
-    }
-
-    public void createLoaderEngineSetup() throws AAIException {
-
-        if (loader == null) {
-            loader = loaderFactory.createLoaderForVersion(factoryType, version);
-            //loader = LoaderFactory.createLoaderForVersion(factoryType, version);
-            dbEngine = spy(new JanusGraphDBEngine(QueryStyle.TRAVERSAL, DBConnectionType.CACHED, loader));
-            serializer = new DBSerializer(version, dbEngine, factoryType, "Junit");
-            resourceWithSoT = new ResourceWithSoT.Builder(loader, serializer, urlBuilder).build();
-
-            TransactionalGraphEngine.Admin spyAdmin = spy(dbEngine.asAdmin());
-
-            when(dbEngine.tx()).thenReturn(graph);
-            when(dbEngine.asAdmin()).thenReturn(spyAdmin);
-
-            when(spyAdmin.getReadOnlyTraversalSource())
-                .thenReturn(graph.traversal(GraphTraversalSource.build().with(ReadOnlyStrategy.instance())));
-            when(spyAdmin.getTraversalSource()).thenReturn(graph.traversal());
-        }
+    public void testGetJsonFromVertexWithNullVertex() throws AAIFormatVertexException {
+        // Null check, will return not present Optional.
+        Optional<JsonObject> result = resourceWithSoT.getJsonFromVertex(null);
+        assertFalse(result.isPresent());
     }
 }