WorkflowAction, traverseNetworkCollection refactoring stage 3 56/109356/2
authorKrzysztof Gajewski <krzysztof.gajewski@nokia.com>
Fri, 19 Jun 2020 15:07:02 +0000 (17:07 +0200)
committerKrzysztof Gajewski <krzysztof.gajewski@nokia.com>
Thu, 25 Jun 2020 08:06:44 +0000 (10:06 +0200)
- invert if's;
- extract one logical function;

Issue-ID: SO-2634
Signed-off-by: Krzysztof Gajewski <krzysztof.gajewski@nokia.com>
Change-Id: I13ae784088fdbe1f4b6b16fc439d70597c1fe811

bpmn/so-bpmn-tasks/src/main/java/org/onap/so/bpmn/infrastructure/workflow/tasks/WorkflowAction.java

index 71e1abd..99a8250 100644 (file)
@@ -848,64 +848,66 @@ public class WorkflowAction {
 
     private void traverseNetworkCollectionResourceCustomization(List<Resource> resourceList,
             CollectionResourceCustomization collectionResourceCustomization) {
-        if (collectionResourceCustomization != null) {
-            resourceList.add(new Resource(WorkflowType.NETWORKCOLLECTION,
-                    collectionResourceCustomization.getModelCustomizationUUID(), false));
-            logger.debug("Found a network collection");
-            if (collectionResourceCustomization.getCollectionResource() != null) {
-                if (collectionResourceCustomization.getCollectionResource().getInstanceGroup() != null) {
-                    String toscaNodeType = collectionResourceCustomization.getCollectionResource().getInstanceGroup()
-                            .getToscaNodeType();
-                    if (toscaNodeType != null && toscaNodeType.contains(NETWORKCOLLECTION)) {
-                        int minNetworks = 0;
-                        org.onap.so.db.catalog.beans.InstanceGroup instanceGroup =
-                                collectionResourceCustomization.getCollectionResource().getInstanceGroup();
-                        CollectionResourceInstanceGroupCustomization collectionInstCust = null;
-                        if (!instanceGroup.getCollectionInstanceGroupCustomizations().isEmpty()) {
-                            for (CollectionResourceInstanceGroupCustomization collectionInstanceGroupTemp : instanceGroup
-                                    .getCollectionInstanceGroupCustomizations()) {
-                                if (collectionInstanceGroupTemp.getModelCustomizationUUID().equalsIgnoreCase(
-                                        collectionResourceCustomization.getModelCustomizationUUID())) {
-                                    collectionInstCust = collectionInstanceGroupTemp;
-                                    break;
-                                }
-                            }
-                            if (collectionInstCust != null
-                                    && collectionInstCust.getSubInterfaceNetworkQuantity() != null) {
-                                minNetworks = collectionInstCust.getSubInterfaceNetworkQuantity();
-                            }
-                        }
-                        logger.debug("minNetworks: {}", minNetworks);
-                        CollectionNetworkResourceCustomization collectionNetworkResourceCust = null;
-                        for (CollectionNetworkResourceCustomization collectionNetworkTemp : instanceGroup
-                                .getCollectionNetworkResourceCustomizations()) {
-                            if (collectionNetworkTemp.getNetworkResourceCustomization().getModelCustomizationUUID()
-                                    .equalsIgnoreCase(collectionResourceCustomization.getModelCustomizationUUID())) {
-                                collectionNetworkResourceCust = collectionNetworkTemp;
-                                break;
-                            }
-                        }
-                        for (int i = 0; i < minNetworks; i++) {
-                            if (collectionNetworkResourceCust != null && collectionInstCust != null) {
-                                Resource resource = new Resource(WorkflowType.VIRTUAL_LINK,
-                                        collectionNetworkResourceCust.getModelCustomizationUUID(), false);
-                                resource.setVirtualLinkKey(Integer.toString(i));
-                                resourceList.add(resource);
-                            }
-                        }
-                    } else {
-                        logger.debug("Instance Group tosca node type does not contain NetworkCollection:  {}",
-                                toscaNodeType);
-                    }
-                } else {
-                    logger.debug("No Instance Group found for network collection.");
+        if (collectionResourceCustomization == null) {
+            logger.debug("No Network Collection Customization found");
+            return;
+        }
+        resourceList.add(new Resource(WorkflowType.NETWORKCOLLECTION,
+                collectionResourceCustomization.getModelCustomizationUUID(), false));
+        logger.debug("Found a network collection");
+        if (collectionResourceCustomization.getCollectionResource() == null) {
+            logger.debug("No Network Collection found. collectionResource is null");
+            return;
+        }
+        if (collectionResourceCustomization.getCollectionResource().getInstanceGroup() == null) {
+            logger.debug("No Instance Group found for network collection.");
+            return;
+        }
+        String toscaNodeType =
+                collectionResourceCustomization.getCollectionResource().getInstanceGroup().getToscaNodeType();
+        if (!toscaNodeTypeHasNetworkCollection(toscaNodeType)) {
+            logger.debug("Instance Group tosca node type does not contain NetworkCollection:  {}", toscaNodeType);
+            return;
+        }
+        int minNetworks = 0;
+        org.onap.so.db.catalog.beans.InstanceGroup instanceGroup =
+                collectionResourceCustomization.getCollectionResource().getInstanceGroup();
+        CollectionResourceInstanceGroupCustomization collectionInstCust = null;
+        if (!instanceGroup.getCollectionInstanceGroupCustomizations().isEmpty()) {
+            for (CollectionResourceInstanceGroupCustomization collectionInstanceGroupTemp : instanceGroup
+                    .getCollectionInstanceGroupCustomizations()) {
+                if (collectionInstanceGroupTemp.getModelCustomizationUUID()
+                        .equalsIgnoreCase(collectionResourceCustomization.getModelCustomizationUUID())) {
+                    collectionInstCust = collectionInstanceGroupTemp;
+                    break;
                 }
-            } else {
-                logger.debug("No Network Collection found. collectionResource is null");
             }
-        } else {
-            logger.debug("No Network Collection Customization found");
+            if (collectionInstCust != null && collectionInstCust.getSubInterfaceNetworkQuantity() != null) {
+                minNetworks = collectionInstCust.getSubInterfaceNetworkQuantity();
+            }
+        }
+        logger.debug("minNetworks: {}", minNetworks);
+        CollectionNetworkResourceCustomization collectionNetworkResourceCust = null;
+        for (CollectionNetworkResourceCustomization collectionNetworkTemp : instanceGroup
+                .getCollectionNetworkResourceCustomizations()) {
+            if (collectionNetworkTemp.getNetworkResourceCustomization().getModelCustomizationUUID()
+                    .equalsIgnoreCase(collectionResourceCustomization.getModelCustomizationUUID())) {
+                collectionNetworkResourceCust = collectionNetworkTemp;
+                break;
+            }
         }
+        for (int i = 0; i < minNetworks; i++) {
+            if (collectionNetworkResourceCust != null && collectionInstCust != null) {
+                Resource resource = new Resource(WorkflowType.VIRTUAL_LINK,
+                        collectionNetworkResourceCust.getModelCustomizationUUID(), false);
+                resource.setVirtualLinkKey(Integer.toString(i));
+                resourceList.add(resource);
+            }
+        }
+    }
+
+    private boolean toscaNodeTypeHasNetworkCollection(String toscaNodeType) {
+        return toscaNodeType != null && toscaNodeType.contains(NETWORKCOLLECTION);
     }
 
     private void traverseNetworkCollectionCustomization(List<Resource> resourceList,