Replaced all tabs with spaces in java and pom.xml
[so.git] / bpmn / mso-infrastructure-bpmn / src / test / java / org / onap / so / bpmn / common / BPMNUtil.java
index 5f0722a..f417a55 100644 (file)
@@ -25,14 +25,11 @@ import static org.junit.Assert.assertNotNull;
 import static org.junit.Assert.assertNull;
 import static org.junit.Assert.assertTrue;
 import static org.junit.Assert.fail;
-
 import java.util.ArrayList;
 import java.util.HashMap;
 import java.util.List;
 import java.util.Map;
-
 import javax.ws.rs.core.Response;
-
 import org.camunda.bpm.engine.HistoryService;
 import org.camunda.bpm.engine.ProcessEngineServices;
 import org.camunda.bpm.engine.RuntimeService;
@@ -52,306 +49,303 @@ import org.springframework.stereotype.Component;
 @Component
 public class BPMNUtil {
 
-       private static WorkflowAsyncResource workflowResource;
-       
-       @Autowired
-       public void setWorkflowResource(WorkflowAsyncResource workflowResource) {
-               BPMNUtil.workflowResource = workflowResource;
-       }
-
-       public static String getVariable(ProcessEngineServices processEngineServices, String processDefinitionID, String name) {
-               String pID = getProcessInstanceId(processEngineServices,
-                               processDefinitionID);
-               return getVariable( processEngineServices,  processDefinitionID,  name,  pID);
-       }
-       
-       public static String getVariable(ProcessEngineServices processEngineServices, String processDefinitionID, String name, String processInstanceId) {
-               assertProcessInstanceFinished(processEngineServices, processInstanceId);
-               HistoricVariableInstance responseData = processEngineServices.getHistoryService()
-                           .createHistoricVariableInstanceQuery().processInstanceId(processInstanceId)
-                           .variableName(name)
-                           .singleResult();
-               
-               if (responseData != null) {
-                       return (responseData.getValue() != null ? responseData.getValue().toString(): null); 
-               }
-               return null;
-       }
-
-       /*
-       @SuppressWarnings("unchecked")
-       public static <T extends Object> T getRawVariable(HistoryService historyService, String processDefinitionID, String name) {
-               //String pID = getProcessInstanceId(processEngineServices,
-               //              processDefinitionID);
-               assertProcessInstanceFinished(historyService, pID);
-               Object responseData = historyService
-                           .createHistoricVariableInstanceQuery().processInstanceId(pID)
-                           .variableName(name)
-                           .singleResult()
-                           .getValue();
-               return (T) responseData;
-       }
-       */
-       
-       @SuppressWarnings("unchecked")
-       public static <T> T getRawVariable(ProcessEngineServices processEngineServices, String processDefinitionID, String name) {
-               String pID = getProcessInstanceId(processEngineServices,
-                               processDefinitionID);
-               return getRawVariable( processEngineServices,  processDefinitionID,  name,  pID);
-       }
-       
-       @SuppressWarnings("unchecked")
-       public static <T> T getRawVariable(ProcessEngineServices processEngineServices, String processDefinitionID, String name, String processInstanceId) {
-               assertProcessInstanceFinished(processEngineServices, processInstanceId);
-               Object responseData = processEngineServices.getHistoryService()
-                           .createHistoricVariableInstanceQuery().processInstanceId(processInstanceId)
-                           .variableName(name)
-                           .singleResult()
-                           .getValue();
-               return (T) responseData;
-       }
-
-       
-       public static void assertAnyProcessInstanceFinished(ProcessEngineServices processEngineServices, String processDefinitionID) {
-               String pID = getProcessInstanceId(processEngineServices,
-                               processDefinitionID);
-               assertNotNull(pID);
-           assertTrue(processEngineServices.getHistoryService().createHistoricProcessInstanceQuery().processInstanceId(pID).finished().count() > 0);
-       }
-       
-       public static void assertNoProcessInstance(ProcessEngineServices processEngineServices, String processDefinitionID) {
-               assertNull(getProcessInstanceId(processEngineServices, processDefinitionID));
-       }
-       
-       public static void assertProcessInstanceFinished(HistoryService historyService, String pid) {
-           assertEquals(1, historyService.createHistoricProcessInstanceQuery().processInstanceId(pid).finished().count());
-       }
-       
-       public static void assertProcessInstanceFinished(ProcessEngineServices processEngineServices, String pid) {
-           assertEquals(1, processEngineServices.getHistoryService().createHistoricProcessInstanceQuery().processInstanceId(pid).finished().count());
-       }
-       
-       public static void assertProcessInstanceNotFinished(ProcessEngineServices processEngineServices, String processDefinitionID) {
-               String pID = getProcessInstanceId(processEngineServices,
-                               processDefinitionID);           
-           assertEquals(0, processEngineServices.getHistoryService().createHistoricProcessInstanceQuery().processInstanceId(pID).finished().count());
-       }
-       
-       private static String getProcessInstanceId(
-                       ProcessEngineServices processEngineServices, String processDefinitionID) {
-               List<HistoricProcessInstance> historyList =  processEngineServices.getHistoryService().createHistoricProcessInstanceQuery().list();
-               String pID = null;
-               for (HistoricProcessInstance hInstance: historyList) {
-                       if (hInstance.getProcessDefinitionKey().equals(processDefinitionID)) {
-                               pID = hInstance.getId();
-                               break;
-                       }
-               }
-               return pID;
-       }
-       
-       public static void cleanHistory(ProcessEngineServices processEngineServices) {
-               List<HistoricProcessInstance> historyList = processEngineServices.getHistoryService().createHistoricProcessInstanceQuery().list();
-               List<String> pidList = new ArrayList<>();
-               for (HistoricProcessInstance hInstance : historyList) {
-                       pidList.add(hInstance.getId());
-               }
-               if (pidList.size() > 0) {
-                       processEngineServices.getHistoryService().deleteHistoricProcessInstances(pidList);
-               }
-       }
-       
-       private static String getProcessInstanceId(
-                       HistoryService historyService, String processDefinitionID) {
-               List<HistoricProcessInstance> historyList =  historyService.createHistoricProcessInstanceQuery().list();
-               String pID = null;
-               for (HistoricProcessInstance hInstance: historyList) {
-                       if (hInstance.getProcessDefinitionKey().equals(processDefinitionID)) {
-                               pID = hInstance.getId();
-                               break;
-                       }
-               }
-               return pID;
-       }
-
-       public static boolean isProcessInstanceFinished(ProcessEngineServices processEngineServices, String pid) {
-           return processEngineServices.getHistoryService().createHistoricProcessInstanceQuery().processInstanceId(pid).finished().count() == 1 ? true: false;
-       }
-
-       
-       private static void buildVariable(String key, String value, Map<String,Object> variableValueType) {
-               Map<String, Object> host = new HashMap<>();
-               host.put("value", value);
-               host.put("type", "String");
-               variableValueType.put(key, host);
-       }
-       
-       public static WorkflowResponse executeWorkFlow(ProcessEngineServices processEngineServices, String processKey, Map<String,String> variables) {
-               VariableMapImpl variableMap = new VariableMapImpl();
-
-               Map<String, Object> variableValueType = new HashMap<>();
-               for (String key : variables.keySet()) {
-                       buildVariable(key, variables.get(key), variableValueType);
-               }
-               buildVariable("mso-service-request-timeout","600", variableValueType);
-               variableMap.put("variables", variableValueType);
-               
-               workflowResource.setProcessEngineServices4junit(processEngineServices);
-               Response response = workflowResource.startProcessInstanceByKey(
-                                       processKey, variableMap);
-               WorkflowResponse workflowResponse = (WorkflowResponse) response.getEntity();
-               return workflowResponse;
-       }
-       
-       public static WorkflowResponse executeWorkFlow(RuntimeService runtimeService, String processKey, Map<String,String> variables, WorkflowResource workflowResource) {
-               
-               VariableMapImpl variableMap = new VariableMapImpl();
-
-               Map<String, Object> variableValueType = new HashMap<String, Object>();
-               for (String key : variables.keySet()) {
-                       buildVariable(key, variables.get(key), variableValueType);
-               }
-               buildVariable("mso-service-request-timeout","600", variableValueType);
-               variableMap.put("variables", variableValueType);
-               
-
-               Response response = workflowResource.startProcessInstanceByKey(
-                                       processKey, variableMap);
-               WorkflowResponse workflowResponse = (WorkflowResponse) response.getEntity();
-               return workflowResponse;
-       }
-
-       //Check the runtime service to see whether the process is completed
-       public static void waitForWorkflowToFinish(ProcessEngineServices processEngineServices, String pid) throws InterruptedException {
-               // Don't wait forever
-               long waitTime = 120000;
-               long endTime = System.currentTimeMillis() + waitTime;
-
-               while (true) {
-                       if (processEngineServices.getRuntimeService().createProcessInstanceQuery().processInstanceId(pid).singleResult() == null) {
-                               break;
-                       }
-
-                       if (System.currentTimeMillis() >= endTime) {
-                               fail("Process " + pid + " did not finish in " + waitTime + "ms");
-                       }
-
-                       Thread.sleep(200);
-               }
-       }
-       
-       
-       //Check the runtime service to see whether the process is completed
-       public static void waitForWorkflowToFinish(RuntimeService runtimeService, String pid) throws InterruptedException {
-               // Don't wait forever
-               long waitTime = 120000;
-               long endTime = System.currentTimeMillis() + waitTime;
-
-               while (true) {
-                       if (runtimeService.createProcessInstanceQuery().processInstanceId(pid).singleResult() == null) {
-                               break;
-                       }
-
-                       if (System.currentTimeMillis() >= endTime) {
-                               fail("Process " + pid + " did not finish in " + waitTime + "ms");
-                       }
-
-                       Thread.sleep(200);
-               }
-       }
-       
-       
-       /**
-        * Executes the Asynchronous workflow in synchronous fashion and returns the WorkflowResponse object
-        * @param processEngineServices
-        * @param processKey
-        * @param variables
-        * @return
-        * @throws InterruptedException
-        */
-       public static WorkflowResponse executeAsyncWorkflow(ProcessEngineServices processEngineServices, String processKey, Map<String,String> variables) throws InterruptedException {
-               ProcessThread pthread = new ProcessThread(processKey, processEngineServices, variables);
-               pthread.start();
-               BPMNUtil.assertProcessInstanceNotFinished(processEngineServices, processKey);
-               String pid = getProcessInstanceId(processEngineServices, processKey);
-               //Caution: If there is a problem with workflow, this may wait for ever
-               while (true) {
-                       pid = getProcessInstanceId(processEngineServices, processKey);
-                       if (!isProcessInstanceFinished(processEngineServices,pid)) {
-                               Thread.sleep(200);
-                       } else{
-                               break;
-                       }
-               }
-               //need to retrieve for second time ?
-               pid = getProcessInstanceId(processEngineServices, processKey);
-               waitForWorkflowToFinish(processEngineServices, pid);
-               return pthread.workflowResponse;
-       }
-
-       /**
-        * Execute workflow using async resource
-        * @param processEngineServices
-        * @param processKey
-        * @param asyncResponse
-        * @param variables
-        * @throws InterruptedException 
-        */
-       private static void executeAsyncFlow(ProcessEngineServices processEngineServices, String processKey, Map<String,String> variables) throws InterruptedException {
-               VariableMapImpl variableMap = new VariableMapImpl();
-
-               Map<String, Object> variableValueType = new HashMap<>();
-               for (String key : variables.keySet()) {
-                       buildVariable(key, variables.get(key), variableValueType);
-               }
-               buildVariable("mso-service-request-timeout","600", variableValueType);
-               variableMap.put("variables", variableValueType);
-               
-               workflowResource.setProcessEngineServices4junit(processEngineServices);
-               workflowResource.startProcessInstanceByKey(processKey, variableMap);
-       }
-       
-       /**
-        * Helper class which executes workflow in a thread
-        *
-        */
-       static class ProcessThread extends Thread {
-               
-               public WorkflowResponse workflowResponse = null;
-               public String processKey;
-               public boolean started;
-               public ProcessEngineServices processEngineServices;
-               public Map<String,String> variables;
-               
-               public ProcessThread(String processKey, ProcessEngineServices processEngineServices, Map<String,String> variables) {
-                       this.processKey = processKey;
-                       this.processEngineServices = processEngineServices;
-                       this.variables = variables;
-               }
-               
-               public void run() {
-                       started = true;
-                       /*doAnswer(new Answer<Void>() {
-                           public Void answer(InvocationOnMock invocation) {
-                             Response response = (Response) invocation.getArguments()[0];
-                             try {
-                             workflowResponse = (WorkflowResponse) response.getEntity();
-                             } catch (ClassCastException e) {
-                                 String workflowResponseString = (String)response.getEntity();
-                                 workflowResponse = new WorkflowResponse();
-                                 workflowResponse.setResponse(workflowResponseString);
-                                 workflowResponse.setMessageCode(200);
-                             }
-                             return null;
-                           }
-                       }).when(asyncResponse).setResponse(any(Response.class));
-                       */
-                       try {
-                               executeAsyncFlow(processEngineServices, processKey, variables);
-                       } catch (InterruptedException e) {
-                               // TODO Auto-generated catch block
-                               e.printStackTrace();
-                       }
-               }
-       }
+    private static WorkflowAsyncResource workflowResource;
+
+    @Autowired
+    public void setWorkflowResource(WorkflowAsyncResource workflowResource) {
+        BPMNUtil.workflowResource = workflowResource;
+    }
+
+    public static String getVariable(ProcessEngineServices processEngineServices, String processDefinitionID,
+            String name) {
+        String pID = getProcessInstanceId(processEngineServices, processDefinitionID);
+        return getVariable(processEngineServices, processDefinitionID, name, pID);
+    }
+
+    public static String getVariable(ProcessEngineServices processEngineServices, String processDefinitionID,
+            String name, String processInstanceId) {
+        assertProcessInstanceFinished(processEngineServices, processInstanceId);
+        HistoricVariableInstance responseData =
+                processEngineServices.getHistoryService().createHistoricVariableInstanceQuery()
+                        .processInstanceId(processInstanceId).variableName(name).singleResult();
+
+        if (responseData != null) {
+            return (responseData.getValue() != null ? responseData.getValue().toString() : null);
+        }
+        return null;
+    }
+
+    /*
+     * @SuppressWarnings("unchecked") public static <T extends Object> T getRawVariable(HistoryService historyService,
+     * String processDefinitionID, String name) { //String pID = getProcessInstanceId(processEngineServices, //
+     * processDefinitionID); assertProcessInstanceFinished(historyService, pID); Object responseData = historyService
+     * .createHistoricVariableInstanceQuery().processInstanceId(pID) .variableName(name) .singleResult() .getValue();
+     * return (T) responseData; }
+     */
+
+    @SuppressWarnings("unchecked")
+    public static <T> T getRawVariable(ProcessEngineServices processEngineServices, String processDefinitionID,
+            String name) {
+        String pID = getProcessInstanceId(processEngineServices, processDefinitionID);
+        return getRawVariable(processEngineServices, processDefinitionID, name, pID);
+    }
+
+    @SuppressWarnings("unchecked")
+    public static <T> T getRawVariable(ProcessEngineServices processEngineServices, String processDefinitionID,
+            String name, String processInstanceId) {
+        assertProcessInstanceFinished(processEngineServices, processInstanceId);
+        Object responseData = processEngineServices.getHistoryService().createHistoricVariableInstanceQuery()
+                .processInstanceId(processInstanceId).variableName(name).singleResult().getValue();
+        return (T) responseData;
+    }
+
+
+    public static void assertAnyProcessInstanceFinished(ProcessEngineServices processEngineServices,
+            String processDefinitionID) {
+        String pID = getProcessInstanceId(processEngineServices, processDefinitionID);
+        assertNotNull(pID);
+        assertTrue(processEngineServices.getHistoryService().createHistoricProcessInstanceQuery().processInstanceId(pID)
+                .finished().count() > 0);
+    }
+
+    public static void assertNoProcessInstance(ProcessEngineServices processEngineServices,
+            String processDefinitionID) {
+        assertNull(getProcessInstanceId(processEngineServices, processDefinitionID));
+    }
+
+    public static void assertProcessInstanceFinished(HistoryService historyService, String pid) {
+        assertEquals(1, historyService.createHistoricProcessInstanceQuery().processInstanceId(pid).finished().count());
+    }
+
+    public static void assertProcessInstanceFinished(ProcessEngineServices processEngineServices, String pid) {
+        assertEquals(1, processEngineServices.getHistoryService().createHistoricProcessInstanceQuery()
+                .processInstanceId(pid).finished().count());
+    }
+
+    public static void assertProcessInstanceNotFinished(ProcessEngineServices processEngineServices,
+            String processDefinitionID) {
+        String pID = getProcessInstanceId(processEngineServices, processDefinitionID);
+        assertEquals(0, processEngineServices.getHistoryService().createHistoricProcessInstanceQuery()
+                .processInstanceId(pID).finished().count());
+    }
+
+    private static String getProcessInstanceId(ProcessEngineServices processEngineServices,
+            String processDefinitionID) {
+        List<HistoricProcessInstance> historyList =
+                processEngineServices.getHistoryService().createHistoricProcessInstanceQuery().list();
+        String pID = null;
+        for (HistoricProcessInstance hInstance : historyList) {
+            if (hInstance.getProcessDefinitionKey().equals(processDefinitionID)) {
+                pID = hInstance.getId();
+                break;
+            }
+        }
+        return pID;
+    }
+
+    public static void cleanHistory(ProcessEngineServices processEngineServices) {
+        List<HistoricProcessInstance> historyList =
+                processEngineServices.getHistoryService().createHistoricProcessInstanceQuery().list();
+        List<String> pidList = new ArrayList<>();
+        for (HistoricProcessInstance hInstance : historyList) {
+            pidList.add(hInstance.getId());
+        }
+        if (pidList.size() > 0) {
+            processEngineServices.getHistoryService().deleteHistoricProcessInstances(pidList);
+        }
+    }
+
+    private static String getProcessInstanceId(HistoryService historyService, String processDefinitionID) {
+        List<HistoricProcessInstance> historyList = historyService.createHistoricProcessInstanceQuery().list();
+        String pID = null;
+        for (HistoricProcessInstance hInstance : historyList) {
+            if (hInstance.getProcessDefinitionKey().equals(processDefinitionID)) {
+                pID = hInstance.getId();
+                break;
+            }
+        }
+        return pID;
+    }
+
+    public static boolean isProcessInstanceFinished(ProcessEngineServices processEngineServices, String pid) {
+        return processEngineServices.getHistoryService().createHistoricProcessInstanceQuery().processInstanceId(pid)
+                .finished().count() == 1 ? true : false;
+    }
+
+
+    private static void buildVariable(String key, String value, Map<String, Object> variableValueType) {
+        Map<String, Object> host = new HashMap<>();
+        host.put("value", value);
+        host.put("type", "String");
+        variableValueType.put(key, host);
+    }
+
+    public static WorkflowResponse executeWorkFlow(ProcessEngineServices processEngineServices, String processKey,
+            Map<String, String> variables) {
+        VariableMapImpl variableMap = new VariableMapImpl();
+
+        Map<String, Object> variableValueType = new HashMap<>();
+        for (String key : variables.keySet()) {
+            buildVariable(key, variables.get(key), variableValueType);
+        }
+        buildVariable("mso-service-request-timeout", "600", variableValueType);
+        variableMap.put("variables", variableValueType);
+
+        workflowResource.setProcessEngineServices4junit(processEngineServices);
+        Response response = workflowResource.startProcessInstanceByKey(processKey, variableMap);
+        WorkflowResponse workflowResponse = (WorkflowResponse) response.getEntity();
+        return workflowResponse;
+    }
+
+    public static WorkflowResponse executeWorkFlow(RuntimeService runtimeService, String processKey,
+            Map<String, String> variables, WorkflowResource workflowResource) {
+
+        VariableMapImpl variableMap = new VariableMapImpl();
+
+        Map<String, Object> variableValueType = new HashMap<String, Object>();
+        for (String key : variables.keySet()) {
+            buildVariable(key, variables.get(key), variableValueType);
+        }
+        buildVariable("mso-service-request-timeout", "600", variableValueType);
+        variableMap.put("variables", variableValueType);
+
+
+        Response response = workflowResource.startProcessInstanceByKey(processKey, variableMap);
+        WorkflowResponse workflowResponse = (WorkflowResponse) response.getEntity();
+        return workflowResponse;
+    }
+
+    // Check the runtime service to see whether the process is completed
+    public static void waitForWorkflowToFinish(ProcessEngineServices processEngineServices, String pid)
+            throws InterruptedException {
+        // Don't wait forever
+        long waitTime = 120000;
+        long endTime = System.currentTimeMillis() + waitTime;
+
+        while (true) {
+            if (processEngineServices.getRuntimeService().createProcessInstanceQuery().processInstanceId(pid)
+                    .singleResult() == null) {
+                break;
+            }
+
+            if (System.currentTimeMillis() >= endTime) {
+                fail("Process " + pid + " did not finish in " + waitTime + "ms");
+            }
+
+            Thread.sleep(200);
+        }
+    }
+
+
+    // Check the runtime service to see whether the process is completed
+    public static void waitForWorkflowToFinish(RuntimeService runtimeService, String pid) throws InterruptedException {
+        // Don't wait forever
+        long waitTime = 120000;
+        long endTime = System.currentTimeMillis() + waitTime;
+
+        while (true) {
+            if (runtimeService.createProcessInstanceQuery().processInstanceId(pid).singleResult() == null) {
+                break;
+            }
+
+            if (System.currentTimeMillis() >= endTime) {
+                fail("Process " + pid + " did not finish in " + waitTime + "ms");
+            }
+
+            Thread.sleep(200);
+        }
+    }
+
+
+    /**
+     * Executes the Asynchronous workflow in synchronous fashion and returns the WorkflowResponse object
+     * 
+     * @param processEngineServices
+     * @param processKey
+     * @param variables
+     * @return
+     * @throws InterruptedException
+     */
+    public static WorkflowResponse executeAsyncWorkflow(ProcessEngineServices processEngineServices, String processKey,
+            Map<String, String> variables) throws InterruptedException {
+        ProcessThread pthread = new ProcessThread(processKey, processEngineServices, variables);
+        pthread.start();
+        BPMNUtil.assertProcessInstanceNotFinished(processEngineServices, processKey);
+        String pid = getProcessInstanceId(processEngineServices, processKey);
+        // Caution: If there is a problem with workflow, this may wait for ever
+        while (true) {
+            pid = getProcessInstanceId(processEngineServices, processKey);
+            if (!isProcessInstanceFinished(processEngineServices, pid)) {
+                Thread.sleep(200);
+            } else {
+                break;
+            }
+        }
+        // need to retrieve for second time ?
+        pid = getProcessInstanceId(processEngineServices, processKey);
+        waitForWorkflowToFinish(processEngineServices, pid);
+        return pthread.workflowResponse;
+    }
+
+    /**
+     * Execute workflow using async resource
+     * 
+     * @param processEngineServices
+     * @param processKey
+     * @param asyncResponse
+     * @param variables
+     * @throws InterruptedException
+     */
+    private static void executeAsyncFlow(ProcessEngineServices processEngineServices, String processKey,
+            Map<String, String> variables) throws InterruptedException {
+        VariableMapImpl variableMap = new VariableMapImpl();
+
+        Map<String, Object> variableValueType = new HashMap<>();
+        for (String key : variables.keySet()) {
+            buildVariable(key, variables.get(key), variableValueType);
+        }
+        buildVariable("mso-service-request-timeout", "600", variableValueType);
+        variableMap.put("variables", variableValueType);
+
+        workflowResource.setProcessEngineServices4junit(processEngineServices);
+        workflowResource.startProcessInstanceByKey(processKey, variableMap);
+    }
+
+    /**
+     * Helper class which executes workflow in a thread
+     *
+     */
+    static class ProcessThread extends Thread {
+
+        public WorkflowResponse workflowResponse = null;
+        public String processKey;
+        public boolean started;
+        public ProcessEngineServices processEngineServices;
+        public Map<String, String> variables;
+
+        public ProcessThread(String processKey, ProcessEngineServices processEngineServices,
+                Map<String, String> variables) {
+            this.processKey = processKey;
+            this.processEngineServices = processEngineServices;
+            this.variables = variables;
+        }
+
+        public void run() {
+            started = true;
+            /*
+             * doAnswer(new Answer<Void>() { public Void answer(InvocationOnMock invocation) { Response response =
+             * (Response) invocation.getArguments()[0]; try { workflowResponse = (WorkflowResponse)
+             * response.getEntity(); } catch (ClassCastException e) { String workflowResponseString =
+             * (String)response.getEntity(); workflowResponse = new WorkflowResponse();
+             * workflowResponse.setResponse(workflowResponseString); workflowResponse.setMessageCode(200); } return
+             * null; } }).when(asyncResponse).setResponse(any(Response.class));
+             */
+            try {
+                executeAsyncFlow(processEngineServices, processKey, variables);
+            } catch (InterruptedException e) {
+                // TODO Auto-generated catch block
+                e.printStackTrace();
+            }
+        }
+    }
 }