Update the license for 2017-2018 license
[aai/traversal.git] / aai-traversal / src / test / java / org / onap / aai / rest / search / ColocatedDevicesQueryTest.java
1 /**
2  * ============LICENSE_START=======================================================
3  * org.onap.aai
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
10  *
11  *    http://www.apache.org/licenses/LICENSE-2.0
12  *
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=========================================================
19  */
20 package org.onap.aai.rest.search;
21
22 import java.util.Map;
23
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;
29
30 import org.onap.aai.exceptions.AAIException;
31 import org.onap.aai.serialization.db.exceptions.NoEdgeRuleFoundException;
32
33 public class ColocatedDevicesQueryTest extends QueryTest {
34         public ColocatedDevicesQueryTest() throws AAIException, NoEdgeRuleFoundException {
35                 super();
36         }
37         
38         @Test
39         public void run() {
40                 super.run();
41         }
42         @Override
43         protected void createGraph() throws AAIException, NoEdgeRuleFoundException {
44                 
45                 
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");
53                 
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");
60                 
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");
66                 
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);
74                 
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);
81                 
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);
88                 
89                 
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);
98
99
100         }
101         @Override
102         protected String getQueryName() {
103                 return "colocated-devices";
104         }
105         @Override
106         protected void addStartNode(GraphTraversal<Vertex, Vertex> g) {
107                 g.has("hostname", "pservername1");
108         }
109         
110         @Override
111         protected void addParam(Map<String, Object> params) {
112                 return;
113         }
114 }