2 * ============LICENSE_START=======================================================
4 * ================================================================================
5 * Copyright (C) 2019 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=========================================================
21 package org.openecomp.sdc.be.model.jsonjanusgraph.operations;
23 import static org.assertj.core.api.Assertions.assertThat;
24 import static org.junit.jupiter.api.Assertions.assertEquals;
25 import static org.mockito.ArgumentMatchers.any;
26 import static org.mockito.ArgumentMatchers.anyMap;
27 import static org.mockito.ArgumentMatchers.eq;
28 import static org.mockito.Mockito.doReturn;
29 import static org.mockito.Mockito.times;
30 import static org.mockito.Mockito.verify;
31 import static org.mockito.Mockito.when;
33 import fj.data.Either;
34 import java.util.Collections;
35 import java.util.HashMap;
36 import java.util.Iterator;
38 import org.apache.tinkerpop.gremlin.structure.Direction;
39 import org.apache.tinkerpop.gremlin.structure.Edge;
40 import org.apache.tinkerpop.gremlin.structure.Vertex;
41 import org.janusgraph.core.JanusGraphVertex;
42 import org.junit.jupiter.api.Test;
43 import org.junit.jupiter.api.extension.ExtendWith;
44 import org.mockito.InjectMocks;
45 import org.mockito.Mock;
46 import org.mockito.Mockito;
47 import org.mockito.junit.jupiter.MockitoExtension;
48 import org.openecomp.sdc.be.dao.janusgraph.JanusGraphDao;
49 import org.openecomp.sdc.be.dao.janusgraph.JanusGraphOperationStatus;
50 import org.openecomp.sdc.be.dao.jsongraph.GraphVertex;
51 import org.openecomp.sdc.be.dao.jsongraph.types.EdgeLabelEnum;
52 import org.openecomp.sdc.be.dao.jsongraph.types.JsonParseFlagEnum;
53 import org.openecomp.sdc.be.dao.jsongraph.types.VertexTypeEnum;
54 import org.openecomp.sdc.be.datatypes.elements.AttributeDataDefinition;
55 import org.openecomp.sdc.be.datatypes.elements.MapCapabilityProperty;
56 import org.openecomp.sdc.be.datatypes.elements.MapListCapabilityDataDefinition;
57 import org.openecomp.sdc.be.datatypes.elements.MapListRequirementDataDefinition;
58 import org.openecomp.sdc.be.datatypes.enums.GraphPropertyEnum;
59 import org.openecomp.sdc.be.datatypes.enums.JsonPresentationFields;
60 import org.openecomp.sdc.be.model.ComponentParametersView;
61 import org.openecomp.sdc.be.model.DistributionStatusEnum;
62 import org.openecomp.sdc.be.model.OutputDefinition;
63 import org.openecomp.sdc.be.model.PolicyDefinition;
64 import org.openecomp.sdc.be.model.User;
65 import org.openecomp.sdc.be.model.jsonjanusgraph.datamodel.ToscaElement;
66 import org.openecomp.sdc.be.model.operations.api.StorageOperationStatus;
67 import org.openecomp.sdc.be.model.operations.impl.UniqueIdBuilder;
69 @ExtendWith(MockitoExtension.class)
70 class TopologyTemplateOperationTest {
72 private static final String CONTAINER_ID = "containerId";
74 private TopologyTemplateOperation topologyTemplateOperation;
76 private JanusGraphDao janusGraphDao;
79 void overrideToscaDataOfToscaElement_failedToFetchContainerVertex() {
80 when(janusGraphDao.getVertexById(CONTAINER_ID, JsonParseFlagEnum.NoParse)).thenReturn(Either.right(
81 JanusGraphOperationStatus.INVALID_ID));
82 StorageOperationStatus storageOperationStatus = topologyTemplateOperation.overrideToscaDataOfToscaElement(CONTAINER_ID,
83 EdgeLabelEnum.CALCULATED_CAP_PROPERTIES, Collections.emptyMap());
84 assertThat(storageOperationStatus).isEqualTo(StorageOperationStatus.INVALID_ID);
88 void overrideToscaDataOfToscaElement_failedToFetchDataVertex() {
89 GraphVertex containerVertex = new GraphVertex();
90 when(janusGraphDao.getVertexById(CONTAINER_ID, JsonParseFlagEnum.NoParse)).thenReturn(Either.left(containerVertex));
91 when(janusGraphDao.getChildVertex(containerVertex, EdgeLabelEnum.CALCULATED_CAP_PROPERTIES, JsonParseFlagEnum.ParseJson)).thenReturn(
93 JanusGraphOperationStatus.NOT_FOUND));
94 StorageOperationStatus storageOperationStatus = topologyTemplateOperation.overrideToscaDataOfToscaElement(CONTAINER_ID,
95 EdgeLabelEnum.CALCULATED_CAP_PROPERTIES, Collections.emptyMap());
96 assertThat(storageOperationStatus).isEqualTo(StorageOperationStatus.NOT_FOUND);
100 void updateToscaDataDeepElements_failedToFetchContainerVertex() {
101 when(janusGraphDao.getVertexById(CONTAINER_ID, JsonParseFlagEnum.NoParse)).thenReturn(Either.right(
102 JanusGraphOperationStatus.INVALID_ID));
103 StorageOperationStatus storageOperationStatus = topologyTemplateOperation.updateToscaDataDeepElementsBlockToToscaElement(CONTAINER_ID,
104 EdgeLabelEnum.CALCULATED_CAP_PROPERTIES, new MapCapabilityProperty(), "");
105 assertThat(storageOperationStatus).isEqualTo(StorageOperationStatus.INVALID_ID);
109 void updateToscaDataDeepElements_failedToFetchDataVertex() {
110 GraphVertex containerVertex = new GraphVertex();
111 when(janusGraphDao.getVertexById(CONTAINER_ID, JsonParseFlagEnum.NoParse)).thenReturn(Either.left(containerVertex));
112 when(janusGraphDao.getChildVertex(containerVertex, EdgeLabelEnum.CALCULATED_CAP_PROPERTIES, JsonParseFlagEnum.ParseJson)).thenReturn(
114 JanusGraphOperationStatus.NOT_FOUND));
115 StorageOperationStatus storageOperationStatus = topologyTemplateOperation.updateToscaDataDeepElementsBlockToToscaElement(CONTAINER_ID,
116 EdgeLabelEnum.CALCULATED_CAP_PROPERTIES, new MapCapabilityProperty(), "");
117 assertThat(storageOperationStatus).isEqualTo(StorageOperationStatus.NOT_FOUND);
121 void addPolicyToToscaElementSuccessTest() {
122 JanusGraphOperationStatus status = JanusGraphOperationStatus.OK;
123 StorageOperationStatus result = addPolicyToToscaElementWithStatus(status);
124 assertThat(result).isEqualTo(StorageOperationStatus.OK);
128 void addPolicyToToscaElementFailureTest() {
129 JanusGraphOperationStatus status = JanusGraphOperationStatus.ALREADY_EXIST;
130 StorageOperationStatus result = addPolicyToToscaElementWithStatus(status);
131 assertThat(result).isEqualTo(StorageOperationStatus.ENTITY_ALREADY_EXISTS);
135 void testAssociateOrAddCalcCapReqToComponent() {
136 StorageOperationStatus result;
137 GraphVertex graphVertex = new GraphVertex();
138 Map<String, MapListRequirementDataDefinition> calcRequirements = new HashMap<>();
139 Map<String, MapListCapabilityDataDefinition> calcCapabilty = new HashMap<>();
140 Map<String, MapCapabilityProperty> calCapabilitiesProps = new HashMap<>();
141 addPolicyToToscaElementWithStatus(JanusGraphOperationStatus.OK);
142 result = topologyTemplateOperation.associateOrAddCalcCapReqToComponent(graphVertex, calcRequirements, calcCapabilty, calCapabilitiesProps);
143 assertEquals(StorageOperationStatus.OK, result);
147 void testSetDataTypesFromGraph() {
148 GraphVertex containerVertex = new GraphVertex();
149 ComponentParametersView filter = new ComponentParametersView(true);
150 filter.setIgnoreComponentInstancesInterfaces(true);
151 filter.setIgnoreDataType(false);
152 String componentName = "componentName";
153 String componentId = UniqueIdBuilder.buildResourceUniqueId();
154 containerVertex.setVertex(Mockito.mock(JanusGraphVertex.class));
155 containerVertex.setJsonMetadataField(JsonPresentationFields.NAME, componentName);
156 containerVertex.setUniqueId(componentId);
157 containerVertex.setLabel(VertexTypeEnum.TOPOLOGY_TEMPLATE);
158 when(janusGraphDao.getChildVertex(any(GraphVertex.class), any(EdgeLabelEnum.class), any(JsonParseFlagEnum.class))).thenReturn(Either.right(
159 JanusGraphOperationStatus.GENERAL_ERROR));
160 Either<ToscaElement, StorageOperationStatus> storageOperationStatus = topologyTemplateOperation.getToscaElement(containerVertex, filter);
161 assertThat(storageOperationStatus).isEqualTo(Either.right(StorageOperationStatus.GENERAL_ERROR));
165 void testSetOutputsFromGraph() {
166 final GraphVertex containerVertex = new GraphVertex();
167 final ComponentParametersView filter = new ComponentParametersView(true);
168 filter.setIgnoreOutputs(false);
169 final String componentName = "componentName";
170 final String componentId = UniqueIdBuilder.buildResourceUniqueId();
171 containerVertex.setVertex(Mockito.mock(JanusGraphVertex.class));
172 containerVertex.setJsonMetadataField(JsonPresentationFields.NAME, componentName);
173 containerVertex.setUniqueId(componentId);
174 containerVertex.setLabel(VertexTypeEnum.TOPOLOGY_TEMPLATE);
175 doReturn(Either.right(JanusGraphOperationStatus.GENERAL_ERROR)).when(janusGraphDao)
176 .getChildVertex(any(GraphVertex.class), any(EdgeLabelEnum.class), any(JsonParseFlagEnum.class));
177 final Either<ToscaElement, StorageOperationStatus> storageOperationStatus
178 = topologyTemplateOperation.getToscaElement(containerVertex, filter);
179 assertThat(storageOperationStatus).isEqualTo(Either.right(StorageOperationStatus.GENERAL_ERROR));
180 verify(janusGraphDao, times(1)).getChildVertex(any(GraphVertex.class), any(EdgeLabelEnum.class), any(JsonParseFlagEnum.class));
184 void testUpdateDistributionStatus() {
185 Either<GraphVertex, StorageOperationStatus> result;
186 String uniqueId = "uniqueId";
187 User user = new User();
188 String userId = "userId";
189 user.setUserId(userId);
190 Iterator<Edge> edgeIterator = new Iterator<Edge>() {
192 public boolean hasNext() {
201 GraphVertex graphVertex = Mockito.mock(GraphVertex.class);
202 JanusGraphVertex janusGraphVertex = Mockito.mock(JanusGraphVertex.class);
203 when(graphVertex.getVertex()).thenReturn(janusGraphVertex);
204 when(janusGraphVertex.edges(Direction.IN, EdgeLabelEnum.LAST_DISTRIBUTION_STATE_MODIFIER.name())).thenReturn(edgeIterator);
206 .getVertexByPropertyAndLabel(GraphPropertyEnum.USERID, userId, VertexTypeEnum.USER, JsonParseFlagEnum.NoParse)).thenReturn(
207 Either.left(graphVertex));
208 when(janusGraphDao.getVertexById(uniqueId, JsonParseFlagEnum.ParseMetadata)).thenReturn(Either.left(graphVertex));
209 when(janusGraphDao.createEdge(graphVertex, graphVertex, EdgeLabelEnum.LAST_DISTRIBUTION_STATE_MODIFIER, null)).thenReturn(
210 JanusGraphOperationStatus.OK);
211 when(janusGraphDao.updateVertex(graphVertex)).thenReturn(Either.left(graphVertex));
212 result = topologyTemplateOperation.updateDistributionStatus(uniqueId, user, DistributionStatusEnum.DISTRIBUTED);
213 assertThat(result.isLeft()).isTrue();
217 void testAssociateOutputsToComponent_OK() {
218 GraphVertex containerVertex = new GraphVertex();
219 String componentName = "componentName";
220 String componentId = UniqueIdBuilder.buildResourceUniqueId();
221 containerVertex.setVertex(Mockito.mock(JanusGraphVertex.class));
222 containerVertex.setJsonMetadataField(JsonPresentationFields.NAME, componentName);
223 containerVertex.setUniqueId(componentId);
224 containerVertex.setLabel(VertexTypeEnum.TOPOLOGY_TEMPLATE);
225 final Map<String, AttributeDataDefinition> outputs = new HashMap<>();
226 outputs.put("out-1", new OutputDefinition());
228 when(janusGraphDao.createVertex(any(GraphVertex.class))).thenReturn(Either.left(containerVertex));
229 when(janusGraphDao.createEdge(any(Vertex.class), any(Vertex.class), eq(EdgeLabelEnum.OUTPUTS), anyMap()))
230 .thenReturn(JanusGraphOperationStatus.OK);
232 final StorageOperationStatus result = topologyTemplateOperation.associateOutputsToComponent(containerVertex, outputs, CONTAINER_ID);
233 assertEquals(StorageOperationStatus.OK, result);
237 void testAssociateOutputsToComponent_Fail_createVertex() {
238 GraphVertex containerVertex = new GraphVertex();
239 String componentName = "componentName";
240 String componentId = UniqueIdBuilder.buildResourceUniqueId();
241 containerVertex.setVertex(Mockito.mock(JanusGraphVertex.class));
242 containerVertex.setJsonMetadataField(JsonPresentationFields.NAME, componentName);
243 containerVertex.setUniqueId(componentId);
244 containerVertex.setLabel(VertexTypeEnum.TOPOLOGY_TEMPLATE);
245 final Map<String, AttributeDataDefinition> outputs = new HashMap<>();
246 outputs.put("out-1", new OutputDefinition());
248 when(janusGraphDao.createVertex(any(GraphVertex.class))).thenReturn(Either.right(JanusGraphOperationStatus.NOT_CREATED));
250 final StorageOperationStatus result = topologyTemplateOperation.associateOutputsToComponent(containerVertex, outputs, CONTAINER_ID);
251 assertEquals(StorageOperationStatus.SCHEMA_ERROR, result);
254 @SuppressWarnings("unchecked")
255 private StorageOperationStatus addPolicyToToscaElementWithStatus(JanusGraphOperationStatus status) {
256 GraphVertex componentV = new GraphVertex();
257 componentV.setVertex(Mockito.mock(JanusGraphVertex.class));
258 GraphVertex dataV = new GraphVertex();
259 dataV.setVertex(Mockito.mock(JanusGraphVertex.class));
260 String componentName = "componentName";
261 String componentId = UniqueIdBuilder.buildResourceUniqueId();
262 String policyTypeName = "org.openecomp.policies.placement.valet.Affinity";
263 componentV.setJsonMetadataField(JsonPresentationFields.NAME, componentName);
264 componentV.setUniqueId(componentId);
265 PolicyDefinition policy = new PolicyDefinition();
266 policy.setPolicyTypeName(policyTypeName);
268 Either<GraphVertex, JanusGraphOperationStatus> toscaDataVertexRes = Either.right(
269 JanusGraphOperationStatus.NOT_FOUND);
270 when(janusGraphDao.getChildVertex(componentV, EdgeLabelEnum.POLICIES, JsonParseFlagEnum.ParseJson)).thenReturn(toscaDataVertexRes);
271 Either<GraphVertex, JanusGraphOperationStatus> createVertex = Either.left(dataV);
272 when(janusGraphDao.createVertex(any(GraphVertex.class))).thenReturn(createVertex);
273 when(janusGraphDao.createEdge(any(JanusGraphVertex.class), any(JanusGraphVertex.class), any(EdgeLabelEnum.class),
274 any(HashMap.class))).thenReturn(status);
275 return topologyTemplateOperation.addPolicyToToscaElement(componentV, policy, counter);