73fe2c885ddd2546dfecfd2f7764313af74b0e00
[aai/aai-common.git] / aai-core / src / test / java / org / onap / aai / query / builder / ExcludeQueryTest.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.query.builder;
21
22 import org.apache.tinkerpop.gremlin.process.traversal.dsl.graph.GraphTraversalSource;
23 import org.apache.tinkerpop.gremlin.structure.Graph;
24 import org.apache.tinkerpop.gremlin.structure.T;
25 import org.apache.tinkerpop.gremlin.structure.Vertex;
26 import org.apache.tinkerpop.gremlin.tinkergraph.structure.TinkerGraph;
27 import org.junit.Before;
28 import org.junit.Test;
29 import org.onap.aai.AAISetup;
30 import org.onap.aai.db.props.AAIProperties;
31 import org.onap.aai.exceptions.AAIException;
32 import org.onap.aai.introspection.Loader;
33 import org.onap.aai.introspection.ModelType;
34 /*
35  * import org.onap.aai.serialization.db.EdgeRules;
36
37 import org.onap.aai.serialization.db.EdgeType;
38  */
39 import org.onap.aai.serialization.db.EdgeSerializer;
40 import org.springframework.beans.factory.annotation.Autowired;
41 import org.onap.aai.edges.enums.EdgeType;
42 import org.springframework.test.annotation.DirtiesContext;
43
44 import java.util.ArrayList;
45 import java.util.List;
46
47 import static org.junit.Assert.assertTrue;
48 @DirtiesContext(classMode = DirtiesContext.ClassMode.BEFORE_CLASS)
49 public class ExcludeQueryTest extends AAISetup {
50
51         @Autowired
52         EdgeSerializer edgeSer;
53         
54         private Loader loader;
55         
56         @Before
57         public void setup() throws Exception {
58                 loader = loaderFactory.createLoaderForVersion(ModelType.MOXY, schemaVersions.getDefaultVersion());
59         }
60         
61         private QueryBuilder<Vertex> buildTestQuery(QueryBuilder<Vertex> qb) throws AAIException{
62                 return qb.createEdgeTraversal(EdgeType.TREE, "cloud-region","availability-zone").getVerticesExcludeByProperty("hypervisor-type", "hypervisortype-11").store("x").cap("x").unfold().dedup();
63         }
64         
65         @Test
66         public void gremlinQueryExcludeTest() throws AAIException {
67                 Graph graph = TinkerGraph.open();
68                 GraphTraversalSource g = graph.traversal();
69                 
70                 Vertex cloudregion = graph.addVertex(T.label, "cloud-region", T.id, "0", "aai-node-type", "cloud-region", "cloud-region-id", "cloud-region-id-1", "cloud-owner", "cloud-owner-1");
71                 Vertex availibityzone = graph.addVertex(T.label, "availability-zone", T.id, "1", "aai-node-type", "availability-zone", "availability-zone-name", "az-name-1", "hypervisor-type", "hypervisortype-1");
72                 Vertex availibityzone11 = graph.addVertex(T.label, "availability-zone", T.id, "11", "aai-node-type", "availability-zone", "availability-zone-name", "az-name-11", "hypervisor-type", "hypervisortype-11");
73                 
74                 
75                 Vertex cloudregion1 = graph.addVertex(T.label, "cloud-region", T.id, "3", "aai-node-type", "cloud-region", "cloud-region-id", "cloud-region-id-10", "cloud-owner", "cloud-owner-10");
76                 Vertex availibityzone1 = graph.addVertex(T.label, "availability-zone", T.id, "4", "aai-node-type", "availability-zone", "availability-zone-name", "az-name-10", "hypervisor-type", "hypervisortype-10");
77                 Vertex availibityzone12 = graph.addVertex(T.label, "availability-zone", T.id, "12", "aai-node-type", "availability-zone", "availability-zone-name", "az-name-12", "hypervisor-type", "hypervisortype-12");
78                 
79                 edgeSer.addTreeEdge(g, cloudregion, availibityzone);
80                 edgeSer.addTreeEdge(g, cloudregion, availibityzone11);
81                 
82                 
83                 
84                 edgeSer.addTreeEdge(g, cloudregion1, availibityzone1);
85                 edgeSer.addTreeEdge(g, cloudregion1, availibityzone12);
86                 
87                 List<Vertex> expected = new ArrayList<>();
88                 expected.add(availibityzone);
89                 
90                 GremlinTraversal<Vertex> qb =  new GremlinTraversal<>(loader, g, cloudregion);
91                 QueryBuilder q = buildTestQuery(qb);
92                 
93                 List<Vertex> results = q.toList();
94
95                 assertTrue("results match", expected.containsAll(results) && results.containsAll(expected));
96         }
97
98         @Test
99         public void traversalQueryExcludeTest() throws AAIException {
100                 Graph graph = TinkerGraph.open();
101                 GraphTraversalSource g = graph.traversal();
102                 
103                 
104                 Vertex cloudregion = graph.addVertex(T.label, "cloud-region", T.id, "0", "aai-node-type", "cloud-region", "cloud-region-id", "cloud-region-id-1", "cloud-owner", "cloud-owner-1");
105                 Vertex availibityzone = graph.addVertex(T.label, "availability-zone", T.id, "1", "aai-node-type", "availability-zone", "availability-zone-name", "az-name-1", "hypervisor-type", "hypervisortype-1");
106                 Vertex availibityzone11 = graph.addVertex(T.label, "availability-zone", T.id, "11", "aai-node-type", "availability-zone", "availability-zone-name", "az-name-11", "hypervisor-type", "hypervisortype-11");
107                 
108                 
109                 Vertex cloudregion1 = graph.addVertex(T.label, "cloud-region", T.id, "3", "aai-node-type", "cloud-region", "cloud-region-id", "cloud-region-id-10", "cloud-owner", "cloud-owner-10");
110                 Vertex availibityzone1 = graph.addVertex(T.label, "availability-zone", T.id, "4", "aai-node-type", "availability-zone", "availability-zone-name", "az-name-10", "hypervisor-type", "hypervisortype-10");
111                 Vertex availibityzone12 = graph.addVertex(T.label, "availability-zone", T.id, "12", "aai-node-type", "availability-zone", "availability-zone-name", "az-name-12", "hypervisor-type", "hypervisortype-12");
112                 
113                 edgeSer.addTreeEdge(g, cloudregion, availibityzone);
114                 edgeSer.addTreeEdge(g, cloudregion, availibityzone11);
115                 
116                 
117                 
118                 edgeSer.addTreeEdge(g, cloudregion1, availibityzone1);
119                 edgeSer.addTreeEdge(g, cloudregion1, availibityzone12);
120                 
121                 List<Vertex> expected = new ArrayList<>();
122                 expected.add(availibityzone);
123                 
124                 
125                 
126                 
127                 TraversalQuery<Vertex> qb =  new TraversalQuery<>(loader, g, cloudregion);
128                 QueryBuilder<Vertex> q = buildTestQuery(qb);
129                 
130                 List<Vertex> results = q.toList();
131
132                 assertTrue("results match", expected.containsAll(results) && results.containsAll(expected));
133         }
134
135
136
137 }