10.activiti工作流-並行網關(parallelGateWay)

1.流程圖

這裏寫圖片描述

2.執行代碼

package h_paralleGateWay;

import java.io.InputStream;
import java.util.HashMap;
import java.util.List;
import java.util.Map;

import org.activiti.engine.ProcessEngine;
import org.activiti.engine.ProcessEngines;
import org.activiti.engine.repository.Deployment;
import org.activiti.engine.runtime.ProcessInstance;
import org.activiti.engine.task.Task;
import org.junit.Test;

public class ParalleGateWayTest {
    ProcessEngine processEngine = ProcessEngines.getDefaultProcessEngine();


    /**部署流程定義(從inputStream)*/
    @Test
    public void deploymentProcessDefinition_inputStream(){
        InputStream inputStreamBpmn = this.getClass().getResourceAsStream("paralleGateWay.bpmn");
        InputStream inputStreamPng = this.getClass().getResourceAsStream("paralleGateWay.png");
        Deployment deployment = processEngine.getRepositoryService()//與流程定義和部署對象相關的Service
                        .createDeployment()//創建一個部署對象
                        .name("排他網關")//添加部署的名稱
                        .addInputStream("paralleGateWay.bpmn", inputStreamBpmn)//
                        .addInputStream("paralleGateWay.png", inputStreamPng)//
                        .deploy();//完成部署
        System.out.println("部署ID:"+deployment.getId());//
        System.out.println("部署名稱:"+deployment.getName());//
    }

    /**啓動流程實例*/
    @Test
    public void startProcessInstance(){
        //流程定義的key
        String processDefinitionKey = "paralleGateWay";
        ProcessInstance pi = processEngine.getRuntimeService()//與正在執行的流程實例和執行對象相關的Service
                        .startProcessInstanceByKey(processDefinitionKey);//使用流程定義的key啓動流程實例,key對應helloworld.bpmn文件中id的屬性值,使用key值啓動,默認是按照最新版本的流程定義啓動
        System.out.println("流程實例ID:"+pi.getId());//流程實例ID    101
        System.out.println("流程定義ID:"+pi.getProcessDefinitionId());//流程定義ID   helloworld:1:4
    }

    /**查詢當前人的個人任務*/
    @Test
    public void findMyPersonalTask(){
        String assignee = "王小五";
        List<Task> list = processEngine.getTaskService()//與正在執行的任務管理相關的Service
                        .createTaskQuery()//創建任務查詢對象
                        /**查詢條件(where部分)*/
                        .taskAssignee(assignee)//指定個人任務查詢,指定辦理人
//                      .taskCandidateUser(candidateUser)//組任務的辦理人查詢
//                      .processDefinitionId(processDefinitionId)//使用流程定義ID查詢
//                      .processInstanceId(processInstanceId)//使用流程實例ID查詢
//                      .executionId(executionId)//使用執行對象ID查詢
                        /**排序*/
                        .orderByTaskCreateTime().asc()//使用創建時間的升序排列
                        /**返回結果集*/
//                      .singleResult()//返回惟一結果集
//                      .count()//返回結果集的數量
//                      .listPage(firstResult, maxResults);//分頁查詢
                        .list();//返回列表
        if(list!=null && list.size()>0){
            for(Task task:list){
                System.out.println("任務ID:"+task.getId());
                System.out.println("任務名稱:"+task.getName());
                System.out.println("任務的創建時間:"+task.getCreateTime());
                System.out.println("任務的辦理人:"+task.getAssignee());
                System.out.println("流程實例ID:"+task.getProcessInstanceId());
                System.out.println("執行對象ID:"+task.getExecutionId());
                System.out.println("流程定義ID:"+task.getProcessDefinitionId());
                System.out.println("########################################################");
            }
        }
    }

    /** 完成我的任務 */

    @Test
    public void completePersonalTask() {
        // 任務id
        String taskId = "4502";
        Map<String, Object> variabes=new HashMap<String, Object>();
        variabes.put("money", 200);
        processEngine.getTaskService().complete(taskId,variabes);

        System.out.println("完成任務:任務id:" + taskId);

    }


}

說明:
1)一個流程中流程實例只有1個,執行對象有多個
2)並行網關的功能是基於進入和外出的順序流的:
分支(fork): 並行後的所有外出順序流,爲每個順序流都創建一個併發分支。
匯聚(join): 所有到達並行網關,在此等待的進入分支, 直到所有進入順序流的分支都到達以後, 流程就會通過匯聚網關。
3)並行網關的進入和外出都是使用相同節點標識
4)如果同一個並行網關有多個進入和多個外出順序流, 它就同時具有分支和匯聚功能。 這時,網關會先匯聚所有進入的順序流,然後再切分成多個並行分支。
5)並行網關不會解析條件。 即使順序流中定義了條件,也會被忽略。
並行網關不需要是“平衡的”(比如, 對應並行網關的進入和外出節點數目不一定相等)。如圖中標示是合法的:
這裏寫圖片描述

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章