summaryrefslogtreecommitdiffstats
path: root/openecomp-be/lib/openecomp-tosca-converter-lib/openecomp-tosca-converter-core/src/main/java/org/openecomp/core/impl/GlobalSubstitutionServiceTemplate.java
diff options
context:
space:
mode:
authortalio <tali.orenbach@amdocs.com>2017-11-09 17:49:28 +0200
committertalio <tali.orenbach@amdocs.com>2017-11-09 19:08:01 +0200
commit97f28b8424428318088303a46273118854bc12b1 (patch)
treef881aed20d2f6a079700600cdd274c5adbf535db /openecomp-be/lib/openecomp-tosca-converter-lib/openecomp-tosca-converter-core/src/main/java/org/openecomp/core/impl/GlobalSubstitutionServiceTemplate.java
parente306939ce7bf085d21faa0038da00c2127a368c8 (diff)
import tosca bug
handling conversion of integers Issue - Id : SDC-646 Change-Id: I7e024dc44709dc5288bced05da590f0c7962648a Signed-off-by: talio <tali.orenbach@amdocs.com>
Diffstat (limited to 'openecomp-be/lib/openecomp-tosca-converter-lib/openecomp-tosca-converter-core/src/main/java/org/openecomp/core/impl/GlobalSubstitutionServiceTemplate.java')
-rw-r--r--openecomp-be/lib/openecomp-tosca-converter-lib/openecomp-tosca-converter-core/src/main/java/org/openecomp/core/impl/GlobalSubstitutionServiceTemplate.java27
1 files changed, 24 insertions, 3 deletions
diff --git a/openecomp-be/lib/openecomp-tosca-converter-lib/openecomp-tosca-converter-core/src/main/java/org/openecomp/core/impl/GlobalSubstitutionServiceTemplate.java b/openecomp-be/lib/openecomp-tosca-converter-lib/openecomp-tosca-converter-core/src/main/java/org/openecomp/core/impl/GlobalSubstitutionServiceTemplate.java
index 778445c513..4ff8af495c 100644
--- a/openecomp-be/lib/openecomp-tosca-converter-lib/openecomp-tosca-converter-core/src/main/java/org/openecomp/core/impl/GlobalSubstitutionServiceTemplate.java
+++ b/openecomp-be/lib/openecomp-tosca-converter-lib/openecomp-tosca-converter-core/src/main/java/org/openecomp/core/impl/GlobalSubstitutionServiceTemplate.java
@@ -67,7 +67,7 @@ public class GlobalSubstitutionServiceTemplate extends ServiceTemplate {
setTosca_definitions_version(DEFININTION_VERSION);
}
- public Optional<Map<String, NodeType>> removeExistingGlobalTypes(Map<String, NodeType> nodes){
+ private Optional<Map<String, NodeType>> removeExistingGlobalTypes(Map<String, NodeType> nodes){
Map<String, NodeType> nodeTypesToAdd = new HashMap<>();
ServiceTemplate serviceTemplate = globalServiceTemplates.get("openecomp/nodes.yml");
@@ -75,13 +75,34 @@ public class GlobalSubstitutionServiceTemplate extends ServiceTemplate {
return Optional.of(nodes);
}
- Map<String, NodeType> globalNodeTypes = serviceTemplate.getNode_types();
+ Map<String, NodeType> globalNodeTypes = getAllGlobalNodeTypes();
for(Map.Entry<String, NodeType> nodeTypeEntry : nodes.entrySet()){
if(!globalNodeTypes.containsKey(nodeTypeEntry.getKey())){
- nodeTypesToAdd.put(nodeTypeEntry.getKey(), nodeTypeEntry.getValue());
+ Optional<NodeType> nodeType =
+ ToscaConverterUtil
+ .createObjectFromClass(nodeTypeEntry.getKey(), nodeTypeEntry.getValue(), NodeType.class);
+
+ nodeType
+ .ifPresent(nodeTypeValue -> nodeTypesToAdd.put(nodeTypeEntry.getKey(), nodeTypeValue));
}
}
return Optional.of(nodeTypesToAdd);
}
+
+ private Map<String, NodeType> getAllGlobalNodeTypes(){
+ Map<String, NodeType> globalNodeTypes = new HashMap<>();
+
+ for(Map.Entry<String, ServiceTemplate> serviceTemplateEntry : globalServiceTemplates.entrySet()){
+ if(isNodesServiceTemplate(serviceTemplateEntry.getKey())){
+ globalNodeTypes.putAll(serviceTemplateEntry.getValue().getNode_types());
+ }
+ }
+
+ return globalNodeTypes;
+ }
+
+ private boolean isNodesServiceTemplate(String filename) {
+ return filename.endsWith("nodes.yml") || filename.endsWith("nodes.yaml");
+ }
}