contains-other-v no longer implies delete-other-v
[aai/aai-common.git] / aai-core / src / test / java / org / onap / aai / serialization / engines / query / GraphTraversalQueryEngineTest.java
diff --git a/aai-core/src/test/java/org/onap/aai/serialization/engines/query/GraphTraversalQueryEngineTest.java b/aai-core/src/test/java/org/onap/aai/serialization/engines/query/GraphTraversalQueryEngineTest.java
new file mode 100644 (file)
index 0000000..4e3b7d0
--- /dev/null
@@ -0,0 +1,75 @@
+/**
+ * ============LICENSE_START=======================================================
+ * org.onap.aai
+ * ================================================================================
+ * 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=========================================================
+ *
+ * ECOMP is a trademark and service mark of AT&T Intellectual Property.
+ */
+
+package org.onap.aai.serialization.engines.query;
+
+import static org.junit.Assert.*;
+
+import java.util.ArrayList;
+import java.util.Arrays;
+import java.util.List;
+
+import org.apache.tinkerpop.gremlin.process.traversal.dsl.graph.GraphTraversalSource;
+import org.apache.tinkerpop.gremlin.structure.Graph;
+import org.apache.tinkerpop.gremlin.structure.T;
+import org.apache.tinkerpop.gremlin.structure.Vertex;
+import org.apache.tinkerpop.gremlin.tinkergraph.structure.TinkerGraph;
+import org.junit.Test;
+import org.onap.aai.exceptions.AAIException;
+import org.onap.aai.serialization.db.EdgeRules;
+
+public class GraphTraversalQueryEngineTest {
+
+       @Test
+       public void testFindDeletable() throws AAIException {
+               //setup
+               EdgeRules rules = EdgeRules.getInstance("/dbedgerules/DbEdgeRules_test.json");
+               
+               Graph graph = TinkerGraph.open();
+               Vertex parent = graph.addVertex(T.id, "00", "aai-node-type", "test-parent");
+               Vertex child = graph.addVertex(T.id, "10", "aai-node-type", "test-child");
+               Vertex cousin = graph.addVertex(T.id, "20", "aai-node-type", "test-cousin");
+               Vertex grandchild = graph.addVertex(T.id, "30", "aai-node-type", "test-grandchild");
+
+               GraphTraversalSource g = graph.traversal();
+               
+               rules.addTreeEdge(g, parent, child); //delete-other-v=none, no cascade
+               rules.addTreeEdge(g, child, grandchild); //d-o-v=out, yes from child
+               rules.addEdge(g, cousin, child); //d-o-v=out, yes from cousin
+               
+               List<Vertex> parentExpected = new ArrayList<>(Arrays.asList(parent));
+               List<Vertex> childExpected = new ArrayList<>(Arrays.asList(child, grandchild));
+               List<Vertex> cousinExpected = new ArrayList<>(Arrays.asList(cousin, child, grandchild));
+               
+               GraphTraversalQueryEngine engine = new GraphTraversalQueryEngine(g);
+               
+               //tests
+               List<Vertex> parentDeletes = engine.findDeletable(parent);
+               assertTrue(parentExpected.containsAll(parentDeletes) && parentDeletes.containsAll(parentExpected));
+               
+               List<Vertex> childDeletes = engine.findDeletable(child);
+               assertTrue(childExpected.containsAll(childDeletes) && childDeletes.containsAll(childExpected));
+               
+               List<Vertex> cousinDeletes = engine.findDeletable(cousin);
+               assertTrue(cousinExpected.containsAll(cousinDeletes) && cousinDeletes.containsAll(cousinExpected));
+       }
+}