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.rest.search;
24 import org.apache.tinkerpop.gremlin.process.traversal.dsl.graph.GraphTraversal;
25 import org.apache.tinkerpop.gremlin.process.traversal.dsl.graph.GraphTraversalSource;
26 import org.apache.tinkerpop.gremlin.structure.T;
27 import org.apache.tinkerpop.gremlin.structure.Vertex;
28 import org.junit.Test;
30 import org.onap.aai.exceptions.AAIException;
31 import org.onap.aai.serialization.db.exceptions.NoEdgeRuleFoundException;
33 public class ColocatedDevicesQueryTest extends QueryTest {
34 public ColocatedDevicesQueryTest() throws AAIException, NoEdgeRuleFoundException {
43 protected void createGraph() throws AAIException, NoEdgeRuleFoundException {
46 //Set up the test graph
47 Vertex complex1 = graph.addVertex(T.label, "complex", T.id, "0", "aai-node-type", "complex", "physical-location-id", "clli1");
48 Vertex pserver1 = graph.addVertex(T.label, "pserver", T.id, "1", "aai-node-type", "pserver", "hostname", "pservername1");
49 Vertex pserverint1 = graph.addVertex(T.label, "p-interface", T.id, "2", "aai-node-type", "p-interface", "interface-name", "xe0/0/0");
50 Vertex pnf1 = graph.addVertex(T.label, "pnf", T.id, "3", "aai-node-type", "pnf", "pnf-name", "pnfname1");
51 Vertex pnfint1 = graph.addVertex(T.label, "p-interface", T.id, "4", "aai-node-type", "p-interface", "interface-name", "ge0/0/0");
52 Vertex plink1 = graph.addVertex(T.label, "physical-link", T.id, "5", "aai-node-type", "physical-link", "link-name", "ge0/0/0-to-xe0/0/0");
54 Vertex complex2 = graph.addVertex(T.label, "complex", T.id, "6", "aai-node-type", "complex", "physical-location-id", "clli2");
55 Vertex pserver2 = graph.addVertex(T.label, "pserver", T.id, "7", "aai-node-type", "pserver", "hostname", "pservername2");
56 Vertex pserverint2 = graph.addVertex(T.label, "p-interface", T.id, "8", "aai-node-type", "p-interface", "interface-name", "xe0/0/1");
57 Vertex pserver3 = graph.addVertex(T.label, "pserver", T.id, "9", "aai-node-type", "pserver", "hostname", "pservername3");
58 Vertex pserverint3 = graph.addVertex(T.label, "p-interface", T.id, "10", "aai-node-type", "p-interface", "interface-name", "xe0/0/3");
59 Vertex plink2 = graph.addVertex(T.label, "physical-link", T.id, "11", "aai-node-type", "physical-link", "link-name", "xe0/0/1-to-xe0/0/3");
61 Vertex pnf2 = graph.addVertex(T.label, "pnf", T.id, "12", "aai-node-type", "pnf", "pnf-name", "pnfname2");
62 Vertex pnfint2 = graph.addVertex(T.label, "p-interface", T.id, "13", "aai-node-type", "p-interface", "interface-name", "ge0/0/2");
63 Vertex pnf3 = graph.addVertex(T.label, "pnf", T.id, "14", "aai-node-type", "pnf", "pnf-name", "pnfname3");
64 Vertex pnfint3 = graph.addVertex(T.label, "p-interface", T.id, "15", "aai-node-type", "p-interface", "interface-name", "ge0/0/3");
65 Vertex plink3 = graph.addVertex(T.label, "physical-link", T.id, "16", "aai-node-type", "physical-link", "link-name", "ge0/0/2-to-ge0/0/3");
67 GraphTraversalSource g = graph.traversal();
68 rules.addEdge(g, pserver1, complex1);
69 rules.addTreeEdge(g, pserver1, pserverint1);
70 rules.addEdge(g, pnf1, complex1);
71 rules.addTreeEdge(g, pnf1, pnfint1);
72 rules.addEdge(g, pserverint1, plink1);
73 rules.addEdge(g, pnfint1, plink1);
75 rules.addEdge(g, pserver2, complex1);
76 rules.addTreeEdge(g, pserver2, pserverint2);
77 rules.addEdge(g, pserver3, complex2);
78 rules.addTreeEdge(g, pserver3, pserverint3);
79 rules.addEdge(g, pserverint2, plink2);
80 rules.addEdge(g, pserverint3, plink2);
82 rules.addEdge(g, pnf2, complex2);
83 rules.addTreeEdge(g, pnf2, pnfint2);
84 rules.addEdge(g, pnf3, complex2);
85 rules.addTreeEdge(g, pnf3, pnfint3);
86 rules.addEdge(g, pnfint2, plink3);
87 rules.addEdge(g, pnfint3, plink3);
90 expectedResult.add(pnf1);
91 expectedResult.add(pnfint1);
92 expectedResult.add(pserver1);
93 expectedResult.add(pserverint1);
94 expectedResult.add(plink1);
95 expectedResult.add(pserver2);
96 expectedResult.add(pserverint2);
97 expectedResult.add(plink2);
102 protected String getQueryName() {
103 return "colocated-devices";
106 protected void addStartNode(GraphTraversal<Vertex, Vertex> g) {
107 g.has("hostname", "pservername1");
111 protected void addParam(Map<String, Object> params) {