Update the license for 2017-2018 license
[aai/traversal.git] / aai-traversal / src / test / java / org / onap / aai / rest / search / TopologySummaryQueryTest.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 TopologySummaryQueryTest extends QueryTest {
34
35         public TopologySummaryQueryTest() throws AAIException, NoEdgeRuleFoundException {
36                 super();
37         }
38
39         @Test
40         public void run() {
41                 super.run();
42         }
43         
44         @Override
45         protected void createGraph() throws AAIException, NoEdgeRuleFoundException {
46                 Vertex vnf = graph.addVertex(T.label, "generic-vnf", T.id, "0", "aai-node-type", "generic-vnf", "vnf-id", "vnfuuid");
47                 Vertex vnfint = graph.addVertex(T.label, "l-interface", T.id, "10", "aai-node-type", "l-interface", "interface-name", "xe0/0/0");
48                 Vertex vnfc = graph.addVertex(T.label, "vnfc", T.id, "1", "aai-node-type", "vnfc");
49                 Vertex vserver = graph.addVertex(T.label, "vserver", T.id, "2", "aai-node-type", "vserver");
50                 Vertex vserverint = graph.addVertex(T.label, "l-interface", T.id, "11", "aai-node-type", "l-interface", "interface-name", "xe0/0/0");
51                 Vertex tenant = graph.addVertex(T.label, "tenant", T.id, "3", "aai-node-type", "tenant");
52                 Vertex region = graph.addVertex(T.label, "could-region", T.id, "4", "aai-node-type", "cloud-region");
53                 Vertex image = graph.addVertex(T.label, "image", T.id, "5", "aai-node-type", "image");
54                 Vertex flavor = graph.addVertex(T.label, "flavor", T.id, "6", "aai-node-type", "flavor");
55                 Vertex pserver = graph.addVertex(T.label, "pserver", T.id, "7", "aai-node-type", "pserver");
56                 Vertex pserverint = graph.addVertex(T.label, "p-interface", T.id, "9", "aai-node-type", "p-interface", "interface-name", "xe0/0/0");
57                 Vertex complex = graph.addVertex(T.label, "complex", T.id, "8", "aai-node-type", "complex");
58                 
59                 GraphTraversalSource g = graph.traversal();
60                 rules.addEdge(g, vnf, vnfc);
61                 rules.addEdge(g, vnf, vserver);
62                 rules.addEdge(g, vnfc, vserver);
63                 rules.addTreeEdge(g, vserver, tenant);
64                 rules.addTreeEdge(g, tenant, region);
65                 rules.addEdge(g, vserver, image);
66                 rules.addEdge(g, vserver, flavor);
67                 rules.addEdge(g, vserver, pserver);
68                 rules.addEdge(g, pserver, complex);
69                 rules.addEdge(g, region, complex);
70                 rules.addTreeEdge(g, pserver, pserverint);
71                 rules.addTreeEdge(g, vnf, vnfint);
72                 rules.addTreeEdge(g, vserver, vserverint);
73                 
74                 expectedResult.add(vnf);
75                 expectedResult.add(vnfc);
76                 expectedResult.add(vserver);
77                 expectedResult.add(tenant);
78                 expectedResult.add(region);
79                 expectedResult.add(image);
80                 expectedResult.add(flavor);
81                 expectedResult.add(pserver);
82                 expectedResult.add(complex);
83                 
84         }
85
86         @Override
87         protected String getQueryName() {
88                 return "topology-summary";
89         }
90
91         @Override
92         protected void addStartNode(GraphTraversal<Vertex, Vertex> g) {
93                 g.has("vnf-id", "vnfuuid");
94                 
95         }
96
97         @Override
98         protected void addParam(Map<String, Object> params) {
99                 return;         
100         }
101
102 }