Activiti流程并行网关测试

论坛 期权论坛 脚本     
匿名技术用户   2021-1-2 14:36   11   0

流程图:

代码:

package com.ytdx.parallelGateWay;

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

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;

/**
 * Activiti并行网关测试
 * @author lhy
 *
 */
public class ParallelGateWayTest {

 ProcessEngine processEngine = ProcessEngines.getDefaultProcessEngine();
 
 /**
  * 部署流程定义(从inputStream)
  */
 @Test
 public void deploymentProcess_inputStream(){
  InputStream inputStreamBpmn = this.getClass().getClassLoader().getResourceAsStream("parallelGateWay.bpmn");
  InputStream inputStreamPng = this.getClass().getClassLoader().getResourceAsStream("parallelGateWay.png");
  Deployment deployment = processEngine.getRepositoryService()                                                   //与流程定义和部署对象相关的Service
    .createDeployment()                                                                                    //创建一个部署对象
    .name("并行网关")                                                                                         //添加部署的名称
    .addInputStream("parallelGateWay.bpmn", inputStreamBpmn)
    .addInputStream("parallelGateWay.png", inputStreamPng)
    .deploy();                                                                                             //完成部署
  System.out.println("部署ID:"+deployment.getId());
  System.out.println("部署名称:"+deployment.getName());
 }
 
 /**
  * 启动流程实例
  */
 @Test
 public void startProcessInstance(){
  String processDefinitionKey = "parallelGateWay";                                                       //流程定义的key
  ProcessInstance pi = processEngine.getRuntimeService()                                                 //与正在执行的流程实例和执行对象相关的Service
    .startProcessInstanceByKey(processDefinitionKey);                                              //使用流程定义的key启动流程实例,key对应parallelGateWay.bpmn文件中id的属性值,使用key值启动,默认是按照最新版本的流程定义启动
  System.out.println("流程实例ID:"+pi.getId());                                                             //流程实例ID    101
  System.out.println("流程定义ID:"+pi.getProcessDefinitionId());                                            //流程定义ID   helloworld:1:4
 }
 
 /**
  * 查询当前人的个人任务
  */
 @Test
 public void findPersonalTask(){
  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(){
  String taskId = "3407";
  processEngine.getTaskService()                                               //与正在执行的任务管理相关的Service
      .complete(taskId);
  System.out.println("完成任务:任务ID:"+taskId);
 }
}

总结:

1) 一个流程中流程实例只有1个,执行对象有多个

2) 并行网关的功能是基于进入和外出的顺序流的:

分支(fork): 并行后的所有外出顺序流,为每个顺序流都创建一个并发分支。

汇聚(join): 所有到达并行网关,在此等待的进入分支, 直到所有进入顺序流的分支都到达以后, 流程就会通过汇聚网关。

3) 并行网关的进入和外出都是使用相同节点标识

4) 如果同一个并行网关有多个进入和多个外出顺序流, 它就同时具有分支和汇聚功能。 这时,网关会先汇聚所有进入的顺序流,然后再切分成多个并行分支。

5) 并行网关不会解析条件。 即使顺序流中定义了条件,也会被忽略。

并行网关不需要是“平衡的”(比如, 对应并行网关的进入和外出节点数目不一定相等)。

分享到 :
0 人收藏
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

积分:7942463
帖子:1588486
精华:0
期权论坛 期权论坛
发布
内容

下载期权论坛手机APP