2 * ============LICENSE_START=======================================================
4 * ================================================================================
5 * Copyright © 2017-2018 AT&T Intellectual Property. All rights reserved.
6 * ================================================================================
7 * Licensed under the Apache License, Version 2.0 (the "License");
8 * you may not use this file except in compliance with the License.
9 * You may obtain a copy of the License at
11 * http://www.apache.org/licenses/LICENSE-2.0
13 * Unless required by applicable law or agreed to in writing, software
14 * distributed under the License is distributed on an "AS IS" BASIS,
15 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
16 * See the License for the specific language governing permissions and
17 * limitations under the License.
18 * ============LICENSE_END=========================================================
20 package org.onap.aai.query.builder;
22 import org.apache.tinkerpop.gremlin.process.traversal.dsl.graph.GraphTraversal;
23 import org.apache.tinkerpop.gremlin.process.traversal.dsl.graph.__;
24 import org.apache.tinkerpop.gremlin.process.traversal.step.util.Tree;
25 import org.apache.tinkerpop.gremlin.structure.Edge;
26 import org.apache.tinkerpop.gremlin.structure.Vertex;
27 import org.junit.Test;
28 import org.onap.aai.db.props.AAIProperties;
29 import org.onap.aai.exceptions.AAIException;
30 import org.onap.aai.serialization.db.EdgeType;
32 import java.io.UnsupportedEncodingException;
34 import java.net.URISyntaxException;
35 import java.util.List;
37 import static org.junit.Assert.assertEquals;
38 import static org.junit.Assert.assertTrue;
40 public class TraversalQueryTest extends QueryBuilderTestAbstraction {
44 protected QueryBuilder<Edge> getNewEdgeTraversalWithTestEdgeRules(Vertex v) {
45 return new TraversalQuery<>(loader, g, v, testEdgeRules);
49 protected QueryBuilder<Edge> getNewEdgeTraversalWithTestEdgeRules() {
50 return new TraversalQuery<>(loader, g, testEdgeRules);
54 protected QueryBuilder<Vertex> getNewVertexTraversalWithTestEdgeRules(Vertex v) {
55 return new TraversalQuery<>(loader, g, v, testEdgeRules);
59 protected QueryBuilder<Vertex> getNewVertexTraversalWithTestEdgeRules() {
60 return new TraversalQuery<>(loader, g, testEdgeRules);
64 protected QueryBuilder<Vertex> getNewVertexTraversal() {
65 return new TraversalQuery<>(loader, g);
69 protected QueryBuilder<Tree> getNewTreeTraversalWithTestEdgeRules(Vertex v) {
70 return new TraversalQuery<>(loader, g, v, testEdgeRules);
74 protected QueryBuilder<Tree> getNewTreeTraversalWithTestEdgeRules() {
75 return new TraversalQuery<>(loader, g, testEdgeRules);
79 public void unionQuery() {
80 QueryBuilder<Vertex> tQ = getNewVertexTraversal();
81 QueryBuilder<Vertex> tQ2 = getNewVertexTraversal();
82 QueryBuilder<Vertex> tQ3 = getNewVertexTraversal();
84 tQ2.getVerticesByProperty("test1", "value1"),
85 tQ3.getVerticesByIndexedProperty("test2", "value2"));
87 GraphTraversal<Vertex, Vertex> expected = __.<Vertex>start()
88 .union(__.has("test1", "value1"),__.has("test2", "value2"));
90 assertEquals("they are equal", expected, tQ.getQuery());
96 public void traversalClones() throws UnsupportedEncodingException, AAIException, URISyntaxException {
97 QueryBuilder<Vertex> tQ = getNewVertexTraversal();
98 QueryBuilder<Vertex> builder = tQ.createQueryFromURI(new URI("network/generic-vnfs/generic-vnf/key1")).getQueryBuilder();
99 GraphTraversal<Vertex, Vertex> expected = __.<Vertex>start().has("vnf-id", "key1").has("aai-node-type", "generic-vnf");
100 GraphTraversal<Vertex, Vertex> containerExpected = __.<Vertex>start().has("aai-node-type", "generic-vnf");
102 assertEquals("query object", expected.toString(), builder.getQuery().toString());
103 assertEquals("container query object", containerExpected.toString(), builder.getContainerQuery().getQuery().toString());
109 public void nestedTraversalClones() throws UnsupportedEncodingException, AAIException, URISyntaxException {
111 QueryBuilder<Vertex> tQ = getNewVertexTraversal();
112 QueryBuilder<Vertex> builder = tQ.createQueryFromURI(new URI("network/generic-vnfs/generic-vnf/key1/l-interfaces/l-interface/key2")).getQueryBuilder();
113 GraphTraversal<Vertex, Vertex> expected = __.<Vertex>start()
114 .has("vnf-id", "key1")
115 .has("aai-node-type", "generic-vnf")
116 .in("org.onap.relationships.inventory.BelongsTo").has(AAIProperties.NODE_TYPE, "l-interface")
117 .has("interface-name", "key2");
118 GraphTraversal<Vertex, Vertex> containerExpected = __.<Vertex>start()
119 .has("vnf-id", "key1")
120 .has("aai-node-type", "generic-vnf")
121 .in("org.onap.relationships.inventory.BelongsTo")
122 .has(AAIProperties.NODE_TYPE, "l-interface");
124 assertEquals("query object", expected.toString(), builder.getQuery().toString());
125 assertEquals("container query object", containerExpected.toString(), builder.getContainerQuery().getQuery().toString());
131 public void abstractEdgeToVertexTraversalTest() throws AAIException {
133 Vertex gvnf = g.addV("aai-node-type","generic-vnf","vnf-id","gvnf").next();
134 Vertex vnfc1 = g.addV("aai-node-type","vnfc","vnfc-name","a-name").next();
136 testEdgeRules.addEdge(g, gvnf, vnfc1);
138 QueryBuilder<Vertex> tQ = getNewVertexTraversalWithTestEdgeRules(gvnf);
139 tQ.createEdgeTraversal(EdgeType.COUSIN, "vnf", "vnfc");
141 List<Vertex> list = tQ.toList();
143 assertEquals("Has 1 vertexes ", 1, list.size());
144 assertTrue("Has vertex on the default edge ", list.contains(vnfc1));
150 public void abstractEdgeToVertexTraversalSingleOutRuleTest() throws AAIException {
152 Vertex vce = g.addV("aai-node-type","vce","vnf-id","vce").next();
153 Vertex vnfc1 = g.addV("aai-node-type","vnfc","vnfc-name","a-name").next();
155 testEdgeRules.addEdge(g, vce, vnfc1);
157 QueryBuilder<Vertex> tQ1 = getNewVertexTraversalWithTestEdgeRules(vce);
158 tQ1.createEdgeTraversal(EdgeType.COUSIN, "vnf", "vnfc");
160 QueryBuilder<Vertex> tQ2 = getNewVertexTraversalWithTestEdgeRules(vnfc1);
161 tQ2.createEdgeTraversal(EdgeType.COUSIN, "vnfc", "vnf");
163 List<Vertex> list1 = tQ1.toList();
164 List<Vertex> list2 = tQ2.toList();
166 assertEquals("1 - Has 1 vertexes ", 1, list1.size());
167 assertTrue("1 - traversal results in vnfc ", list1.contains(vnfc1));
168 assertEquals("2 - Has 1 vertexes ", 1, list2.size());
169 assertTrue("2 - traversal results in vce ", list2.contains(vce));
175 public void abstractEdgeToVertexTraversalSingleInRuleTest() throws AAIException {
177 Vertex vce = g.addV("aai-node-type","vce","vnf-id","vce").next();
178 Vertex pserver = g.addV("aai-node-type","pserver","hostname","a-name").next();
180 testEdgeRules.addEdge(g, vce, pserver);
182 QueryBuilder<Vertex> tQ1 = getNewVertexTraversalWithTestEdgeRules(vce);
183 tQ1.createEdgeTraversal(EdgeType.COUSIN, "vnf", "pserver");
185 List<Vertex> list = tQ1.toList();
187 assertEquals("1 - Has 1 vertexes ", 1, list.size());
188 assertTrue("1 - traversal results in vnfc ", list.contains(pserver));
194 public void abstractEdgeToVertexMultiRuleTraversalTest() throws AAIException {
196 Vertex gvnf = g.addV("aai-node-type","generic-vnf","vnf-id","gvnf").next();
197 Vertex vnfc1 = g.addV("aai-node-type","vnfc","vnfc-name","a-name").next();
198 Vertex vnfc2 = g.addV("aai-node-type","vnfc","vnfc-name","b-name").next();
200 testEdgeRules.addEdge(g, gvnf, vnfc1);
201 testEdgeRules.addEdge(g, gvnf, vnfc2, "re-uses");
203 QueryBuilder<Vertex> tQ = getNewVertexTraversalWithTestEdgeRules(gvnf);
204 tQ.createEdgeTraversal(EdgeType.COUSIN, "vnf", "vnfc");
206 List<Vertex> list = tQ.toList();
208 assertEquals("Has 2 vertexes ", 2, list.size());
209 assertTrue("Has vertex on the default edge ", list.contains(vnfc1));
210 assertTrue("Has vertex on the re-uses edge ", list.contains(vnfc2));
216 public void abstractEdgeToVertexMultiRuleOutTraversalTest() throws AAIException {
218 Vertex gvnf = g.addV("aai-node-type","generic-vnf","vnf-id","gvnf").next();
219 Vertex pserver = g.addV("aai-node-type","pserver","hostname","a-name").next();
221 testEdgeRules.addEdge(g, gvnf, pserver);
222 testEdgeRules.addEdge(g, gvnf, pserver, "generic-vnf-pserver-B");
224 QueryBuilder<Vertex> tQ = getNewVertexTraversalWithTestEdgeRules(gvnf);
225 tQ.createEdgeTraversal(EdgeType.COUSIN, "vnf", "pserver");
227 List<Vertex> list = tQ.toList();
229 assertEquals("Has 2 vertexes ", 2, list.size());
230 assertTrue("result has pserver ", list.contains(pserver));
236 public void abstractEdgeToVertexMultiRuleInTraversalTest() throws AAIException {
238 Vertex gvnf = g.addV("aai-node-type","generic-vnf","vnf-id","gvnf").next();
239 Vertex complex = g.addV("aai-node-type","complex","physical-location-id","a-name").next();
241 testEdgeRules.addEdge(g, gvnf, complex);
242 testEdgeRules.addEdge(g, gvnf, complex, "complex-generic-vnf-B");
244 QueryBuilder<Vertex> tQ = getNewVertexTraversalWithTestEdgeRules(gvnf);
245 tQ.createEdgeTraversal(EdgeType.COUSIN, "vnf", "complex");
247 List<Vertex> list = tQ.toList();
249 assertEquals("Has 2 vertexes ", 2, list.size());
250 assertTrue("result has pserver ", list.contains(complex));