From 17482a68a5bb27239b360612ca27fe207e0db513 Mon Sep 17 00:00:00 2001 From: Tal Gitelman Date: Mon, 13 Nov 2017 18:47:15 +0200 Subject: [PATCH] Bug fix Change-Id: I202efb7bacb903ca63193b4814fba366e96591b4 Issue-ID: SDC-533 Signed-off-by: Tal Gitelman --- .../openecomp/sdc/be/tosca/ToscaExportHandler.java | 28 +++++++++++++++++++--- 1 file changed, 25 insertions(+), 3 deletions(-) diff --git a/catalog-be/src/main/java/org/openecomp/sdc/be/tosca/ToscaExportHandler.java b/catalog-be/src/main/java/org/openecomp/sdc/be/tosca/ToscaExportHandler.java index e65c4b5001..1f29eb2113 100644 --- a/catalog-be/src/main/java/org/openecomp/sdc/be/tosca/ToscaExportHandler.java +++ b/catalog-be/src/main/java/org/openecomp/sdc/be/tosca/ToscaExportHandler.java @@ -938,12 +938,12 @@ public class ToscaExportHandler { if(CollectionUtils.isEmpty(filteredRelations)){ result = true; } else { - result = !filteredRelations.stream().filter(rel -> !addRequirement(componentInstance, originComponent, component.getComponentInstances(), rel, toscaRequirements)).findFirst().isPresent(); + result = !filteredRelations.stream().filter(rel -> !addRequirement(component,componentInstance, originComponent, component.getComponentInstances(), rel, toscaRequirements)).findFirst().isPresent(); } return result; } - private boolean addRequirement(ComponentInstance fromInstance, Component originComponent, List instancesList, RequirementCapabilityRelDef rel, List> toscaRequirements){ + private boolean addRequirement(Component component,ComponentInstance fromInstance, Component originComponent, List instancesList, RequirementCapabilityRelDef rel, List> toscaRequirements){ boolean result = true; Map originComponents = new HashMap<>(); @@ -962,7 +962,13 @@ public class ToscaExportHandler { result = false; } if(result){ - reqOpt = findRequirement(reqMap, reqAndRelationshipPair.getRequirementUid()); + + if(component.getComponentType().equals(ComponentTypeEnum.SERVICE)) { + reqOpt = findRequirement(reqMap, reqAndRelationshipPair); + } + else { + reqOpt = findRequirement(reqMap, reqAndRelationshipPair.getRequirementUid()); + } if(!reqOpt.isPresent()){ log.debug("Failed to find a requirement with uniqueId {} on a component with uniqueId {}", reqAndRelationshipPair.getRequirementUid(), originComponent.getUniqueId()); result = false; @@ -1020,7 +1026,23 @@ public class ToscaExportHandler { } return Optional.empty(); } + + private Optional findRequirement(Map> reqMap, RequirementAndRelationshipPair reqAndRelationshipPair) { + for(List reqList: reqMap.values()){ + Optional reqOpt = reqList.stream().filter(r -> + isRequirmentBelongTo(reqAndRelationshipPair, r)) + .findFirst(); + if(reqOpt.isPresent()){ + return reqOpt; + } + } + return Optional.empty(); + } + private boolean isRequirmentBelongTo(RequirementAndRelationshipPair reqAndRelationshipPair, RequirementDefinition r) { + return StringUtils.isNotEmpty(r.getOwnerId()) && r.getOwnerId().equals(reqAndRelationshipPair.getRequirementOwnerId()) + && StringUtils.isNotEmpty(r.getName()) && r.getName().equals(reqAndRelationshipPair.getRequirement()); + } private Either convertCapabilities(Component component, SubstitutionMapping substitutionMappings) { -- 2.16.6