diff options
author | talio <tali.orenbach@amdocs.com> | 2019-05-14 11:18:46 +0300 |
---|---|---|
committer | Avi Gaffa <avi.gaffa@amdocs.com> | 2019-05-14 09:58:40 +0000 |
commit | f14d6849126ef4abcec067ac848d125aa8184d2e (patch) | |
tree | 9173a654459ae139abb094aa76189ed24163a29c | |
parent | 80276b1b3ca9b832bfa0fd30b73af45ffaffef9c (diff) |
Fix test coverage
Fix test coverage for ComponentPropertyDeclarator.java
Change-Id: I421a6c3cae0a7e2735e82114adf550d8e1ba041e
Issue-ID: SDC-2298
Signed-off-by: talio <tali.orenbach@amdocs.com>
-rw-r--r-- | catalog-be/src/test/java/org/openecomp/sdc/be/components/property/ComponentPropertyDeclaratorTest.java | 118 |
1 files changed, 118 insertions, 0 deletions
diff --git a/catalog-be/src/test/java/org/openecomp/sdc/be/components/property/ComponentPropertyDeclaratorTest.java b/catalog-be/src/test/java/org/openecomp/sdc/be/components/property/ComponentPropertyDeclaratorTest.java new file mode 100644 index 0000000000..adae5784ba --- /dev/null +++ b/catalog-be/src/test/java/org/openecomp/sdc/be/components/property/ComponentPropertyDeclaratorTest.java @@ -0,0 +1,118 @@ +/* + * ============LICENSE_START============================================================================================================= + * Copyright (c) 2019 <Company or Individual>. + * =================================================================== + * Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with the License. You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS + * OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License. + * ============LICENSE_END=============================================================================================================== + * + */ +package org.openecomp.sdc.be.components.property; + +import static org.junit.Assert.assertEquals; +import static org.junit.Assert.assertTrue; +import static org.mockito.ArgumentMatchers.any; +import static org.mockito.Mockito.when; + +import fj.data.Either; +import java.util.Collections; +import java.util.List; +import java.util.Objects; +import java.util.Optional; +import org.apache.commons.collections.CollectionUtils; +import org.junit.Before; +import org.junit.Test; +import org.junit.runner.RunWith; +import org.mockito.InjectMocks; +import org.mockito.Mock; +import org.mockito.junit.MockitoJUnitRunner; +import org.openecomp.sdc.be.components.impl.PropertyBusinessLogic; +import org.openecomp.sdc.be.components.utils.InputsBuilder; +import org.openecomp.sdc.be.components.utils.PropertyDataDefinitionBuilder; +import org.openecomp.sdc.be.components.utils.ServiceBuilder; +import org.openecomp.sdc.be.datatypes.elements.PropertyDataDefinition; +import org.openecomp.sdc.be.model.Component; +import org.openecomp.sdc.be.model.ComponentInstanceProperty; +import org.openecomp.sdc.be.model.InputDefinition; +import org.openecomp.sdc.be.model.PropertyDefinition; +import org.openecomp.sdc.be.model.Service; +import org.openecomp.sdc.be.model.jsontitan.operations.ToscaOperationFacade; +import org.openecomp.sdc.be.model.operations.api.StorageOperationStatus; + +@RunWith(MockitoJUnitRunner.class) +public class ComponentPropertyDeclaratorTest { + + @InjectMocks + private ComponentPropertyDeclarator testSubject; + @Mock + private ToscaOperationFacade toscaOperationFacade; + + private static final String PROPERTY_UID = "propertyUid"; + private static final String SERVICE_UID = "serviceUid"; + private Service service; + + @Before + public void init() { + service = new ServiceBuilder().setUniqueId(SERVICE_UID).build(); + } + + + @Test + public void createDeclaredProperty_success() { + PropertyDataDefinition propertyDataDefinition = getPropertyForDeclaration(); + PropertyDataDefinition declaredProperty = testSubject.createDeclaredProperty(propertyDataDefinition); + + assertTrue(Objects.nonNull(declaredProperty)); + assertEquals(propertyDataDefinition.getUniqueId(), declaredProperty.getUniqueId()); + } + + @Test + public void updatePropertiesValues_success() { + PropertyDataDefinition propertyForDeclaration = getPropertyForDeclaration(); + when(toscaOperationFacade.updatePropertyOfComponent(any(Component.class), any(PropertyDefinition.class))) + .thenReturn(Either.left(new PropertyDefinition(propertyForDeclaration))); + + Either<List<PropertyDataDefinition>, StorageOperationStatus> updateEither = + (Either<List<PropertyDataDefinition>, StorageOperationStatus>) testSubject + .updatePropertiesValues(service, + SERVICE_UID, Collections + .singletonList( + propertyForDeclaration)); + + assertTrue(updateEither.isLeft()); + + List<PropertyDataDefinition> properties = updateEither.left().value(); + assertTrue(CollectionUtils.isNotEmpty(properties)); + assertEquals(1, properties.size()); + assertEquals(propertyForDeclaration, properties.get(0)); + } + + @Test + public void resolvePropertiesOwner_success() { + Optional<Component> ownerCandidate = testSubject.resolvePropertiesOwner(service, SERVICE_UID); + + assertTrue(ownerCandidate.isPresent()); + assertEquals(service, ownerCandidate.get()); + } + + @Test + public void addPropertiesListToInput_success() { + InputDefinition input = InputsBuilder.create().setPropertyId(PROPERTY_UID).build(); + PropertyDataDefinition propertyForDeclaration = getPropertyForDeclaration(); + + testSubject.addPropertiesListToInput(propertyForDeclaration, input); + + List<ComponentInstanceProperty> inputProperties = input.getProperties(); + assertTrue(CollectionUtils.isNotEmpty(inputProperties)); + assertEquals(1, inputProperties.size()); + assertEquals(propertyForDeclaration.getUniqueId(), inputProperties.get(0).getUniqueId()); + } + + private PropertyDataDefinition getPropertyForDeclaration() { + return new PropertyDataDefinitionBuilder().setUniqueId(PROPERTY_UID).build(); + } +}
\ No newline at end of file |