refactored validator to be more generic 14/75714/1
authorBenjamin, Max (mb388a) <mb388a@us.att.com>
Sat, 12 Jan 2019 02:35:13 +0000 (21:35 -0500)
committerBenjamin, Max (mb388a) <mb388a@us.att.com>
Sat, 12 Jan 2019 02:37:03 +0000 (21:37 -0500)
removed overloaded method from class for JUEL
changed test back to DelegateExecution
added methods to allow validations with DelegateExecution
refactored validator to be more generic

Change-Id: I6c6d7a50e8b5470ffa5619cc83966f5ad68e66fe
Issue-ID: SO-1383
Signed-off-by: Benjamin, Max (mb388a) <mb388a@us.att.com>
18 files changed:
bpmn/MSOCommonBPMN/src/main/java/org/onap/so/bpmn/common/validation/BuildingBlockValidator.java [deleted file]
bpmn/MSOCommonBPMN/src/main/java/org/onap/so/bpmn/common/validation/BuildingBlockValidatorRunner.java
bpmn/MSOCommonBPMN/src/main/java/org/onap/so/bpmn/common/validation/FlowValidator.java [new file with mode: 0644]
bpmn/MSOCommonBPMN/src/main/java/org/onap/so/bpmn/common/validation/FlowValidatorRunner.java [new file with mode: 0644]
bpmn/MSOCommonBPMN/src/main/java/org/onap/so/bpmn/common/validation/PostBuildingBlockValidator.java
bpmn/MSOCommonBPMN/src/main/java/org/onap/so/bpmn/common/validation/PostWorkflowValidator.java
bpmn/MSOCommonBPMN/src/main/java/org/onap/so/bpmn/common/validation/PreBuildingBlockValidator.java
bpmn/MSOCommonBPMN/src/main/java/org/onap/so/bpmn/common/validation/PreWorkflowValidator.java
bpmn/MSOCommonBPMN/src/main/java/org/onap/so/bpmn/common/validation/WorkflowValidator.java [deleted file]
bpmn/MSOCommonBPMN/src/main/java/org/onap/so/bpmn/common/validation/WorkflowValidatorRunner.java
bpmn/MSOCommonBPMN/src/test/java/org/onap/so/bpmn/common/validation/BuildingBlockValidatorRunnerTest.java
bpmn/MSOCommonBPMN/src/test/java/org/onap/so/bpmn/common/validation/MyPreValidatorFour.java
bpmn/MSOCommonBPMN/src/test/java/org/onap/so/bpmn/common/validation/MyPreValidatorOne.java
bpmn/MSOCommonBPMN/src/test/java/org/onap/so/bpmn/common/validation/MyPreValidatorThree.java
bpmn/MSOCommonBPMN/src/test/java/org/onap/so/bpmn/common/validation/MyPreValidatorTwo.java
bpmn/MSOCommonBPMN/src/test/java/org/onap/so/bpmn/common/validation/WorkflowPreValidatorOne.java
bpmn/MSOCommonBPMN/src/test/java/org/onap/so/bpmn/common/validation/WorkflowPreValidatorTwo.java
bpmn/MSOCommonBPMN/src/test/java/org/onap/so/bpmn/common/validation/WorkflowValidatorRunnerTest.java

diff --git a/bpmn/MSOCommonBPMN/src/main/java/org/onap/so/bpmn/common/validation/BuildingBlockValidator.java b/bpmn/MSOCommonBPMN/src/main/java/org/onap/so/bpmn/common/validation/BuildingBlockValidator.java
deleted file mode 100644 (file)
index d4467b8..0000000
+++ /dev/null
@@ -1,44 +0,0 @@
-/*-
- * ============LICENSE_START=======================================================
- * ONAP - SO
- * ================================================================================
- * Copyright (C) 2017 - 2018 AT&T Intellectual Property. All rights reserved.
- * ================================================================================
- * 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.onap.so.bpmn.common.validation;
-
-import java.util.Set;
-
-import org.onap.so.bpmn.common.BuildingBlockExecution;
-
-public interface BuildingBlockValidator {
-
-       
-       /**
-        * Name of the building block to be validated
-        * @return
-        */
-       public Set<String> forBuildingBlock();
-       
-       /**
-        * Determines whether or not the building block should be executed
-        * 
-        * @param execution
-        * @return
-        */
-       public boolean validate(BuildingBlockExecution execution);
-       
-}
index d26ae7b..a5d871e 100644 (file)
@@ -52,99 +52,23 @@ import org.springframework.stereotype.Component;
  *
  */
 @Component
-public class BuildingBlockValidatorRunner {
-
-       private static Logger logger = LoggerFactory.getLogger(BuildingBlockValidatorRunner.class);
-       @Autowired
-       private ApplicationContext context;
-       
-       @Autowired
-       private ExceptionBuilder exceptionBuilder;
-       
-       private List<PreBuildingBlockValidator> preBuildingBlockValidators;
-       private List<PostBuildingBlockValidator> postBuildingBlockValidators;
-
+public class BuildingBlockValidatorRunner extends FlowValidatorRunner<PreBuildingBlockValidator, PostBuildingBlockValidator> {
        
        @PostConstruct
        protected void init() {
                
-               preBuildingBlockValidators = new ArrayList<>(
+               preFlowValidators = new ArrayList<>(
                                Optional.ofNullable(context.getBeansOfType(PreBuildingBlockValidator.class)).orElse(new HashMap<>()).values());
-               postBuildingBlockValidators = new ArrayList<>(
+               postFlowValidators = new ArrayList<>(
                                Optional.ofNullable(context.getBeansOfType(PostBuildingBlockValidator.class)).orElse(new HashMap<>()).values());
        }
        
-       public boolean preValidate(String bbName, BuildingBlockExecution execution) {
-               return validate(preBuildingBlockValidators, bbName, execution);
-       }
-       
-       
-       public boolean postValidate(String bbName, BuildingBlockExecution execution) {
-               return validate(postBuildingBlockValidators, bbName, execution);
-       }
-       
-       
-       protected boolean validate(List<? extends BuildingBlockValidator> validators, String bbName, BuildingBlockExecution execution) {
-               List<Pair<String, Boolean>> results = runValidations(validators, bbName, execution);
-               
-               if (!results.isEmpty()) {
-                       exceptionBuilder.buildAndThrowWorkflowException(execution, 7000,
-                                       "Failed Validations:\n" + results.stream().map(item -> item.getValue0()).collect(Collectors.joining("\n")));
-               }
-               
-               return true;
-               
-       }
-       protected List<Pair<String, Boolean>> runValidations(List<? extends BuildingBlockValidator> validators, String bbName, BuildingBlockExecution execution) {
-               
-               List<BuildingBlockValidator> filtered = filterValidators(validators, bbName);
-               
-               List<Pair<String,Boolean>> results = new ArrayList<>();
-               filtered.forEach(item -> results.add(new Pair<>(item.getClass().getName(), item.validate(execution))));
-               
-               return results.stream().filter(item -> item.getValue1().equals(false)).collect(Collectors.toList());
-       }
-       
-       protected List<BuildingBlockValidator> filterValidators(List<? extends BuildingBlockValidator> validators, String bbName) {
-               return validators.stream()
-                               .filter(item -> {
-                                       return item.forBuildingBlock().contains(bbName);
-                               })
-                               .sorted(Comparator.comparing(item -> {
-                                       Priority p = Optional.ofNullable(item.getClass().getAnnotation(Priority.class)).orElse(new Priority() {
-                                               public int value() {
-                                                       return 1000;
-                                               }
-
-                                               @Override
-                                               public Class<? extends Annotation> annotationType() {
-                                                       return Priority.class;
-                                               }
-                                       });
-                                       return p.value();
-                               })).collect(Collectors.toList());
-       }
-       
-       protected <T> List<T> buildalidatorList(Reflections reflections, Class<T> clazz) {
-               List<T> result = new ArrayList<>();
-               try {
-                       for (Class<? extends T> klass : reflections.getSubTypesOf(clazz)) {
-                               result.add(klass.newInstance());
-                       }
-               } catch (InstantiationException | IllegalAccessException e) {
-                       logger.error("failed to build validator list for " + clazz.getName(), e);
-                       throw new RuntimeException(e);
-               }
-               
-               return result;
-       }
-       
-       protected List<PreBuildingBlockValidator> getPreBuildingBlockValidators() {
-               return this.preBuildingBlockValidators;
+       protected List<PreBuildingBlockValidator> getPreFlowValidators() {
+               return this.preFlowValidators;
        }
        
-       protected List<PostBuildingBlockValidator> getPostBuildingBlockValidators() {
-               return this.postBuildingBlockValidators;
+       protected List<PostBuildingBlockValidator> getPostFlowValidators() {
+               return this.postFlowValidators;
        }
        
 }
diff --git a/bpmn/MSOCommonBPMN/src/main/java/org/onap/so/bpmn/common/validation/FlowValidator.java b/bpmn/MSOCommonBPMN/src/main/java/org/onap/so/bpmn/common/validation/FlowValidator.java
new file mode 100644 (file)
index 0000000..9995b95
--- /dev/null
@@ -0,0 +1,23 @@
+package org.onap.so.bpmn.common.validation;
+
+import java.util.Set;
+
+import org.onap.so.bpmn.common.BuildingBlockExecution;
+
+public interface FlowValidator {
+
+       /**
+        * Names of items to be validated
+        * @return
+        */
+       public Set<String> forItems();
+       
+       /**
+        * Determines whether or not the workflow should be executed
+        * 
+        * @param execution
+        * @return
+        */
+       public boolean validate(BuildingBlockExecution execution);
+       
+}
diff --git a/bpmn/MSOCommonBPMN/src/main/java/org/onap/so/bpmn/common/validation/FlowValidatorRunner.java b/bpmn/MSOCommonBPMN/src/main/java/org/onap/so/bpmn/common/validation/FlowValidatorRunner.java
new file mode 100644 (file)
index 0000000..c2e7d1f
--- /dev/null
@@ -0,0 +1,160 @@
+/*-
+ * ============LICENSE_START=======================================================
+ * ONAP - SO
+ * ================================================================================
+ * Copyright (C) 2017 - 2018 AT&T Intellectual Property. All rights reserved.
+ * ================================================================================
+ * 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.onap.so.bpmn.common.validation;
+
+import java.lang.annotation.Annotation;
+import java.util.ArrayList;
+import java.util.Comparator;
+import java.util.List;
+import java.util.Optional;
+import java.util.stream.Collectors;
+
+import javax.annotation.Priority;
+
+import org.camunda.bpm.engine.delegate.DelegateExecution;
+import org.javatuples.Pair;
+import org.onap.so.bpmn.common.BuildingBlockExecution;
+import org.onap.so.bpmn.common.DelegateExecutionImpl;
+import org.onap.so.client.exception.ExceptionBuilder;
+import org.reflections.Reflections;
+import org.slf4j.Logger;
+import org.slf4j.LoggerFactory;
+import org.springframework.beans.factory.annotation.Autowired;
+import org.springframework.context.ApplicationContext;
+import org.springframework.stereotype.Component;
+
+
+/**
+ * Controls running all pre and post validation for flows.
+ * 
+ * To define a validation you must make it a spring bean and implement either {@link org.onap.so.bpmn.common.validation.PreFlowValidator} or 
+ * {@link org.onap.so.bpmn.common.validation.PostFlowValidator} your validation will automatically be
+ * run by this class.
+ *
+ */
+@Component
+public abstract class FlowValidatorRunner<S extends FlowValidator, E extends FlowValidator> {
+
+       private static Logger logger = LoggerFactory.getLogger(FlowValidatorRunner.class);
+       @Autowired
+       protected ApplicationContext context;
+       
+       @Autowired
+       protected ExceptionBuilder exceptionBuilder;
+       
+       protected List<S> preFlowValidators;
+       protected List<E> postFlowValidators;
+
+       
+
+       /**
+        * Changed to object because JUEL does not support overloaded methods
+        * 
+        * @param bbName
+        * @param execution
+        * @return
+        */
+       public boolean preValidate(String bbName, Object execution) {
+               return validateHelper(bbName, preFlowValidators, execution);
+       }
+       
+       /**
+        * Changed to object because JUEL does not support overloaded methods
+        * 
+        * @param bbName
+        * @param execution
+        * @return
+        */
+       public boolean postValidate(String bbName, Object execution) {
+               return validateHelper(bbName, postFlowValidators, execution);
+       }
+       
+       protected boolean validateHelper(String bbName, List<? extends FlowValidator> validators, Object obj) {
+               
+               if (obj instanceof DelegateExecution) {
+                       return validate(validators, bbName, new DelegateExecutionImpl((DelegateExecution)obj));
+               } else if (obj instanceof BuildingBlockExecution) {
+                       return validate(validators, bbName, (BuildingBlockExecution)obj);
+               } else {
+                       return false;
+               }
+       }
+       
+       protected boolean validate(List<? extends FlowValidator> validators, String bbName, BuildingBlockExecution execution) {
+               List<Pair<String, Boolean>> results = runValidations(validators, bbName, execution);
+               
+               if (!results.isEmpty()) {
+                       exceptionBuilder.buildAndThrowWorkflowException(execution, 7000,
+                                       "Failed Validations:\n" + results.stream().map(item -> item.getValue0()).collect(Collectors.joining("\n")));
+               }
+               
+               return true;
+               
+       }
+       protected List<Pair<String, Boolean>> runValidations(List<? extends FlowValidator> validators, String bbName, BuildingBlockExecution execution) {
+               
+               List<FlowValidator> filtered = filterValidators(validators, bbName);
+               
+               List<Pair<String,Boolean>> results = new ArrayList<>();
+               filtered.forEach(item -> results.add(new Pair<>(item.getClass().getName(), item.validate(execution))));
+               
+               return results.stream().filter(item -> item.getValue1().equals(false)).collect(Collectors.toList());
+       }
+       
+       protected List<FlowValidator> filterValidators(List<? extends FlowValidator> validators, String bbName) {
+               return validators.stream()
+                               .filter(item -> {
+                                       return item.forItems().contains(bbName);
+                               })
+                               .sorted(Comparator.comparing(item -> {
+                                       Priority p = Optional.ofNullable(item.getClass().getAnnotation(Priority.class)).orElse(new Priority() {
+                                               public int value() {
+                                                       return 1000;
+                                               }
+
+                                               @Override
+                                               public Class<? extends Annotation> annotationType() {
+                                                       return Priority.class;
+                                               }
+                                       });
+                                       return p.value();
+                               })).collect(Collectors.toList());
+       }
+       
+       protected <T> List<T> buildalidatorList(Reflections reflections, Class<T> clazz) {
+               List<T> result = new ArrayList<>();
+               try {
+                       for (Class<? extends T> klass : reflections.getSubTypesOf(clazz)) {
+                               result.add(klass.newInstance());
+                       }
+               } catch (InstantiationException | IllegalAccessException e) {
+                       logger.error("failed to build validator list for " + clazz.getName(), e);
+                       throw new RuntimeException(e);
+               }
+               
+               return result;
+       }
+       
+       protected abstract List<S> getPreFlowValidators();
+       
+       protected abstract List<E> getPostFlowValidators();
+       
+}
diff --git a/bpmn/MSOCommonBPMN/src/main/java/org/onap/so/bpmn/common/validation/WorkflowValidator.java b/bpmn/MSOCommonBPMN/src/main/java/org/onap/so/bpmn/common/validation/WorkflowValidator.java
deleted file mode 100644 (file)
index 348f913..0000000
+++ /dev/null
@@ -1,44 +0,0 @@
-/*-
- * ============LICENSE_START=======================================================
- * ONAP - SO
- * ================================================================================
- * Copyright (C) 2017 - 2018 AT&T Intellectual Property. All rights reserved.
- * ================================================================================
- * 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.onap.so.bpmn.common.validation;
-
-import java.util.Set;
-
-import org.camunda.bpm.engine.delegate.DelegateExecution;
-
-public interface WorkflowValidator {
-
-       
-       /**
-        * Name of the workflow action to be validated
-        * @return
-        */
-       public Set<String> forWorkflowAction();
-       
-       /**
-        * Determines whether or not the workflow should be executed
-        * 
-        * @param execution
-        * @return
-        */
-       public boolean validate(DelegateExecution execution);
-       
-}
index 44fbc6d..d8c8601 100644 (file)
@@ -51,99 +51,23 @@ import org.springframework.stereotype.Component;
  *
  */
 @Component
-public class WorkflowValidatorRunner {
+public class WorkflowValidatorRunner extends FlowValidatorRunner<PreWorkflowValidator, PostWorkflowValidator> {
 
-       private static Logger logger = LoggerFactory.getLogger(WorkflowValidatorRunner.class);
-       @Autowired
-       private ApplicationContext context;
-       
-       @Autowired
-       private ExceptionBuilder exceptionBuilder;
-       
-       private List<PreWorkflowValidator> preWorkflowValidators;
-       private List<PostWorkflowValidator> postWorkflowValidators;
-
-       
        @PostConstruct
        protected void init() {
                
-               preWorkflowValidators = new ArrayList<>(
+               preFlowValidators = new ArrayList<>(
                                Optional.ofNullable(context.getBeansOfType(PreWorkflowValidator.class)).orElse(new HashMap<>()).values());
-               postWorkflowValidators = new ArrayList<>(
+               postFlowValidators = new ArrayList<>(
                                Optional.ofNullable(context.getBeansOfType(PostWorkflowValidator.class)).orElse(new HashMap<>()).values());
        }
-       
-       public boolean preValidate(String workflow, DelegateExecution execution) {
-               return validate(preWorkflowValidators, workflow, execution);
-       }
-       
-       
-       public boolean postValidate(String workflow, DelegateExecution execution) {
-               return validate(postWorkflowValidators, workflow, execution);
-       }
-       
-       
-       protected boolean validate(List<? extends WorkflowValidator> validators, String workflow, DelegateExecution execution) {
-               List<Pair<String, Boolean>> results = runValidations(validators, workflow, execution);
-               
-               if (!results.isEmpty()) {
-                       exceptionBuilder.buildAndThrowWorkflowException(execution, 7000,
-                                       "Failed Validations:\n" + results.stream().map(item -> item.getValue0()).collect(Collectors.joining("\n")));
-               }
-               
-               return true;
-               
-       }
-       protected List<Pair<String, Boolean>> runValidations(List<? extends WorkflowValidator> validators, String workflow, DelegateExecution execution) {
-               
-               List<WorkflowValidator> filtered = filterValidators(validators, workflow);
-               
-               List<Pair<String,Boolean>> results = new ArrayList<>();
-               filtered.forEach(item -> results.add(new Pair<>(item.getClass().getName(), item.validate(execution))));
-               
-               return results.stream().filter(item -> item.getValue1().equals(false)).collect(Collectors.toList());
-       }
-       
-       protected List<WorkflowValidator> filterValidators(List<? extends WorkflowValidator> validators, String workflow) {
-               return validators.stream()
-                               .filter(item -> {
-                                       return item.forWorkflowAction().contains(workflow);
-                               })
-                               .sorted(Comparator.comparing(item -> {
-                                       Priority p = Optional.ofNullable(item.getClass().getAnnotation(Priority.class)).orElse(new Priority() {
-                                               public int value() {
-                                                       return 1000;
-                                               }
 
-                                               @Override
-                                               public Class<? extends Annotation> annotationType() {
-                                                       return Priority.class;
-                                               }
-                                       });
-                                       return p.value();
-                               })).collect(Collectors.toList());
-       }
-       
-       protected <T> List<T> buildalidatorList(Reflections reflections, Class<T> clazz) {
-               List<T> result = new ArrayList<>();
-               try {
-                       for (Class<? extends T> klass : reflections.getSubTypesOf(clazz)) {
-                               result.add(klass.newInstance());
-                       }
-               } catch (InstantiationException | IllegalAccessException e) {
-                       logger.error("failed to build validator list for " + clazz.getName(), e);
-                       throw new RuntimeException(e);
-               }
-               
-               return result;
-       }
-       
-       protected List<PreWorkflowValidator> getPreWorkflowValidators() {
-               return this.preWorkflowValidators;
+       protected List<PreWorkflowValidator> getPreFlowValidators() {
+               return this.preFlowValidators;
        }
        
-       protected List<PostWorkflowValidator> getPostWorkflowValidators() {
-               return this.postWorkflowValidators;
+       protected List<PostWorkflowValidator> getPostFlowValidators() {
+               return this.postFlowValidators;
        }
        
 }
index 9478b8f..7246af0 100644 (file)
@@ -57,11 +57,11 @@ public class BuildingBlockValidatorRunnerTest {
                MyPreValidatorOne one = new MyPreValidatorOne();
                MyPreValidatorTwo two = new MyPreValidatorTwo();
                MyPreValidatorThree three = new MyPreValidatorThree();
-               List<BuildingBlockValidator> validators = Arrays.asList(one, two, three);
+               List<FlowValidator> validators = Arrays.asList(one, two, three);
 
-               List<BuildingBlockValidator> result = runner.filterValidators(validators, "test");
+               List<FlowValidator> result = runner.filterValidators(validators, "test");
 
-               List<BuildingBlockValidator> expected = Arrays.asList(two, one);
+               List<FlowValidator> expected = Arrays.asList(two, one);
                
                assertEquals(expected, result);
        }
@@ -75,7 +75,7 @@ public class BuildingBlockValidatorRunnerTest {
                        runner.preValidate("test", execution);
                        fail("exception not thrown");
                } catch (BpmnError e) {
-                       WorkflowException workflowException = execution.getVariable("WorkflowException");
+                       WorkflowException workflowException = (WorkflowException)execution.getVariable("WorkflowException");
                        assertEquals("Failed Validations:\norg.onap.so.bpmn.common.validation.MyPreValidatorTwo\norg.onap.so.bpmn.common.validation.MyPreValidatorOne", workflowException.getErrorMessage());
                }
                runner.preValidate("test2", mock(BuildingBlockExecution.class));
index 1b52f04..7aa4224 100644 (file)
@@ -30,7 +30,7 @@ import org.springframework.stereotype.Component;
 public class MyPreValidatorFour implements PreBuildingBlockValidator {
 
        @Override
-       public Set<String> forBuildingBlock() {
+       public Set<String> forItems() {
                return Collections.singleton("test2");
        }
 
index d6afea9..302bb2b 100644 (file)
@@ -30,7 +30,7 @@ import org.springframework.stereotype.Component;
 public class MyPreValidatorOne implements PreBuildingBlockValidator {
 
        @Override
-       public Set<String> forBuildingBlock() {
+       public Set<String> forItems() {
                
                return Collections.singleton("test");
        }
index f7e93d5..ca1a959 100644 (file)
@@ -30,7 +30,7 @@ import org.springframework.stereotype.Component;
 public class MyPreValidatorThree implements PreBuildingBlockValidator {
 
        @Override
-       public Set<String> forBuildingBlock() {
+       public Set<String> forItems() {
                return Collections.singleton("test2");
        }
 
index 0c15fd8..b74c914 100644 (file)
@@ -33,7 +33,7 @@ import org.springframework.stereotype.Component;
 public class MyPreValidatorTwo implements PreBuildingBlockValidator {
 
        @Override
-       public Set<String> forBuildingBlock() {
+       public Set<String> forItems() {
                return Collections.singleton("test");
        }
 
index 9ad87b5..6538fe5 100644 (file)
@@ -23,20 +23,20 @@ package org.onap.so.bpmn.common.validation;
 import java.util.Collections;
 import java.util.Set;
 
-import org.camunda.bpm.engine.delegate.DelegateExecution;
+import org.onap.so.bpmn.common.BuildingBlockExecution;
 import org.springframework.stereotype.Component;
 
 @Component
 public class WorkflowPreValidatorOne implements PreWorkflowValidator {
 
        @Override
-       public Set<String> forWorkflowAction() {
+       public Set<String> forItems() {
                
                return Collections.singleton("test");
        }
 
        @Override
-       public boolean validate(DelegateExecution exeuction) {
+       public boolean validate(BuildingBlockExecution exeuction) {
                return false;
        }
 
index 2157c67..e20f0f2 100644 (file)
@@ -25,7 +25,7 @@ import java.util.Set;
 
 import javax.annotation.Priority;
 
-import org.camunda.bpm.engine.delegate.DelegateExecution;
+import org.onap.so.bpmn.common.BuildingBlockExecution;
 import org.springframework.stereotype.Component;
 
 @Priority(1)
@@ -33,12 +33,12 @@ import org.springframework.stereotype.Component;
 public class WorkflowPreValidatorTwo implements PreWorkflowValidator {
 
        @Override
-       public Set<String> forWorkflowAction() {
+       public Set<String> forItems() {
                return Collections.singleton("test");
        }
 
        @Override
-       public boolean validate(DelegateExecution execution) {
+       public boolean validate(BuildingBlockExecution execution) {
                return false;
        }
 
index 313fe6b..0dd2f41 100644 (file)
@@ -36,7 +36,6 @@ import org.junit.Test;
 import org.junit.rules.ExpectedException;
 import org.junit.runner.RunWith;
 import org.onap.so.bpmn.common.BuildingBlockExecution;
-import org.onap.so.bpmn.common.DelegateExecutionImpl;
 import org.onap.so.bpmn.core.WorkflowException;
 import org.springframework.beans.factory.annotation.Autowired;
 import org.springframework.test.context.ContextConfiguration;
@@ -57,11 +56,11 @@ public class WorkflowValidatorRunnerTest {
                
                WorkflowPreValidatorOne one = new WorkflowPreValidatorOne();
                WorkflowPreValidatorTwo two = new WorkflowPreValidatorTwo();            
-               List<WorkflowValidator> validators = Arrays.asList(one, two);
+               List<FlowValidator> validators = Arrays.asList(one, two);
 
-               List<WorkflowValidator> result = runner.filterValidators(validators, "test");
+               List<FlowValidator> result = runner.filterValidators(validators, "test");
 
-               List<WorkflowValidator> expected = Arrays.asList(two, one);
+               List<FlowValidator> expected = Arrays.asList(two, one);
                
                assertEquals(expected, result);
        }