Activiti手动执行的应用(UserTask)
工作流模拟某公司请假流程情景如下:
1.开发人员请假流程,如果开发人员请假,如果请假天数小于3天,组长批准,人事批准即可请假。
2.如果请假大约三天,需要项目经理或者产品经理批准,并且项目总监批准
流程图:

流程配置:
流程实现:
package com.easyway.workflow.activiti.gateway; import java.util.logging.Logger;
/**
* execute方法的参数DelegateExecution execution可以在流程中各个结点之间传递流程变量。
* <activiti:taskListener>元素的event属性,它一共包含三种事件:"create"、"assignment"、"complete",分别表示结点执行处理逻辑的时机为:
在处理类实例化时、在结点处理逻辑被指派时、在结点处理逻辑执行完成时,可以根据自己的需要进行指定。
*上述流程定义中,4个任务结点对应的处理类
*
*<activiti:taskListener>元素的event属性,它一共包含三种事件:"create"、"assignment"、"complete",分别表示结点执行处理逻辑的时机为:
在处理类实例化时、在结点处理逻辑被指派时、在结点处理逻辑执行完成时,可以根据自己的需要进行指定。
*
*<userTask id="servicetask2" name="产品经理同意">
<extensionElements>
<activiti:taskListener event="complete" class="com.easyway.workflow.activiti.gateway.ProductManagerUserTaskListener"/>
</extensionElements>
</userTask>
*
*
* 项目经理审批过程
* @author longgangbai
*
*
* 2011-12-17 下午07:45:47
*/
public class DeveloperManagerUserTaskListener implements TaskListener
{ private final Logger log = Logger.getLogger(DeveloperManagerUserTaskListener.class.getName()); /* (non-Javadoc)
* @see org.activiti.engine.delegate.TaskListener#notify(org.activiti.engine.delegate.DelegateTask)
*/
@Override
public void notify(DelegateTask delegateTask) {
try {
Thread.sleep(10000);
} catch (InterruptedException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
log.info("variavles=" + delegateTask.getVariables());
delegateTask.setVariable("项目经理", "请假天数大约3天,同意请假。");
log.info("项目经理,请假天数大约3天,同意请假。."); }
}
package com.easyway.workflow.activiti.gateway; import java.util.logging.Logger;
/**
* execute方法的参数DelegateExecution execution可以在流程中各个结点之间传递流程变量。
*
* <activiti:taskListener>元素的event属性,它一共包含三种事件:"create"、"assignment"、"complete",分别表示结点执行处理逻辑的时机为:
在处理类实例化时、在结点处理逻辑被指派时、在结点处理逻辑执行完成时,可以根据自己的需要进行指定。 * 配置如下
* <userTask id="servicetask4" name="项目总监同意" >
<extensionElements>
<activiti:taskListener event="complete" class="com.easyway.workflow.activiti.gateway.ProductBossUserTaskListener"/>
</extensionElements>
</userTask>
*
*
* 项目总监审批过程
* @author longgangbai
*
* 2011-12-17 下午07:45:47
*/
public class ProductBossUserTaskListener implements TaskListener { private final Logger log = Logger.getLogger(ProductBossUserTaskListener.class.getName()); /* (non-Javadoc)
* @see org.activiti.engine.delegate.TaskListener#notify(org.activiti.engine.delegate.DelegateTask)
*/
@Override
public void notify(DelegateTask execution) {
try {
Thread.sleep(10000);
} catch (InterruptedException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
log.info("variavles=" + execution.getVariables());
execution.setVariable("项目总监", "请假天数大约3天,同意请假。");
log.info("项目总监,请假天数大约3天,同意请假。"); }
}
package com.easyway.workflow.activiti.gateway; import java.util.logging.Logger;
/**
* execute方法的参数DelegateExecution execution可以在流程中各个结点之间传递流程变量。
*
* <activiti:taskListener>元素的event属性,它一共包含三种事件:"create"、"assignment"、"complete",分别表示结点执行处理逻辑的时机为:
在处理类实例化时、在结点处理逻辑被指派时、在结点处理逻辑执行完成时,可以根据自己的需要进行指定。 *
* 配置如下
* <userTask id="servicetask1" name="项目经理同意" >
<extensionElements>
<activiti:taskListener event="complete" class="com.easyway.workflow.activiti.gateway.DeveloperManagerUserTaskListener"/>
</extensionElements>
</userTask>
* 产品经理审批过程
* @author longgangbai
*
* 2011-12-17 下午07:45:47
*/
public class ProductManagerUserTaskListener implements TaskListener { private final Logger log = Logger.getLogger(ProductManagerUserTaskListener.class.getName()); /* (non-Javadoc)
* @see org.activiti.engine.delegate.TaskListener#notify(org.activiti.engine.delegate.DelegateTask)
*/
@Override
public void notify(DelegateTask execution) {
try {
Thread.sleep(10000);
} catch (InterruptedException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
log.info("variavles=" + execution.getVariables());
execution.setVariable("产品经理", "请假天数大约3天,同意请假。");
log.info("产品经理,请假天数大约3天,同意请假。"); }
}
package com.easyway.workflow.activiti.gateway; import java.util.logging.Logger;
/**
*
*
* <activiti:taskListener>元素的event属性,它一共包含三种事件:"create"、"assignment"、"complete",分别表示结点执行处理逻辑的时机为:
在处理类实例化时、在结点处理逻辑被指派时、在结点处理逻辑执行完成时,可以根据自己的需要进行指定。
*
*
* 配置如下:
* <userTask id="servicetask3" name="项目组长同意" >
<extensionElements>
<activiti:taskListener event="complete" class="com.easyway.workflow.activiti.gateway.TeamLeaderUserTaskListener"/>
</extensionElements>
</userTask> * 项目组长批准请假
* 模拟当开发人员请假小于3天,组长比准
* @author longgangbai
*
* 2011-12-17 上午09:07:37
*/
public class TeamLeaderUserTaskListener implements TaskListener { private final Logger log = Logger.getLogger(TeamLeaderUserTaskListener.class.getName()); /* (non-Javadoc)
* @see org.activiti.engine.delegate.TaskListener#notify(org.activiti.engine.delegate.DelegateTask)
*/
@Override
public void notify(DelegateTask execution) {
try {
Thread.sleep(10000);
} catch (InterruptedException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
log.info("variavles=" + execution.getVariables());
execution.setVariable("项目组长", "请假天数小于3天,同意请假。");
log.info("项目组长,请假天数小于3天,同意请假。");
}
}
package com.easyway.workflow.activiti.gateway; import junit.framework.TestCase;
/**
* 主要是在测试之前做一些初始化工作,主要包括流程引擎实例
* 的构建,及其流程提供的基本服务。
* 目的:让开发者熟悉工作流使用过程使用的几个步骤
* 1.加载相关的工作流全局配置文件activiti.cfg.xml配置文件信息
* 2.获取工作流相关的服务(RepositoryService,RuntimeService,
* TaskService,HistoryService,FormService,ManagementService,
* IdentityService等)
* 2.加载工作流文件*.bpmn20.xml信息
*
* 3.部署工作流
* 部署工作流由多种方式,在以后会相继讲解
*
* @author longgangbai
*
* 2011-12-17 下午07:48:59
*/
public abstract class AbstractTest extends TestCase { private ProcessEngine processEngine;
protected String deploymentId;
protected RepositoryService repositoryService;
protected RuntimeService runtimeService;
protected TaskService taskService;
protected FormService formService;
protected HistoryService historyService;
protected IdentityService identityService;
protected ManagementService managementService; /**
* 测试用例开始初始化工作
* 1.创建相关的工作流程对象ProcessEngine
* 2.创建相关的服务
* 3.
*/
@Override
protected void setUp() throws Exception {
super.setUp();
//由于ProcessEngine为线程安全性对象,整个项目可以共用一个
if(processEngine==null) {
//此处使用此种方法调用的activiti的配置文件为 classpath路径下的activiti.cfg.xml
//采用的H2的数据库
processEngine = ProcessEngines.getDefaultProcessEngine();
}
//获取工作流的各种服务信息
repositoryService = processEngine.getRepositoryService();
runtimeService = processEngine.getRuntimeService();
taskService = processEngine.getTaskService();
formService = processEngine.getFormService();
historyService = processEngine.getHistoryService();
identityService = processEngine.getIdentityService();
managementService = processEngine.getManagementService();
//调用扩展的初始化工作
initialize(); } /**
* test销毁方法
*/
@Override
protected void tearDown() throws Exception {
super.tearDown();
destroy();
} /**
* 便于子类的工作的初始化的扩展工作
*
*
* @throws Exception
*/
protected abstract void initialize() throws Exception;
/**
* 便于子类的工作的销毁的扩展工作
*
* @throws Exception
*/
protected abstract void destroy() throws Exception;
}
/**
package com.easyway.workflow.activiti.gateway;
import java.util.Date;
/**
* 测试实例如下
*
* @author longgangbai
*
* 2011-12-18 上午12:00:03
*/
public class ParallelGatewayTest extends AbstractTest {
private String deploymentId;
private Date start = null;
private Date end = null; @Override
protected void initialize() throws Exception {
deploymentId = repositoryService.createDeployment()
.addClasspathResource("diagrams/UserExecuteTask.bpmn20.xml")
.deploy().getId();
} @Override
protected void destroy() throws Exception {
repositoryService.deleteDeployment(deploymentId, true);
} @Deployment
public void testUnbalancedForkJoin() {
//获取流程实例对象
ProcessInstance pi = runtimeService.startProcessInstanceByKey("UserExecuteTask");
//获取任务服务对象的查询
TaskQuery query = taskService.createTaskQuery().processInstanceId(pi.getId()).orderByTaskName().asc();
//获取所有的任务
List<Task> tasks = query.list();
assertEquals(3, tasks.size());
start = new Date(); for(Task task : tasks) {
//执行任务
taskService.complete(task.getId());
System.out.println("name =+"+task.getName());
end = new Date();
System.out.println("" + (end.getTime()-start.getTime()) + "ms.");
}
//查询任务
tasks = query.list();
assertEquals(1, tasks.size());
for(Task task : tasks) {
taskService.complete(task.getId());
System.out.println("name =+"+task.getName());
end = new Date();
System.out.println("" + (end.getTime()-start.getTime()) + "ms.");
}
end = new Date();
System.out.println("" + (end.getTime()-start.getTime()) + "ms.");
}
}
运行结果:
Activiti手动执行的应用(UserTask)的更多相关文章
- jeecg安装——mysql数据库创建+手动执行初始化脚本
国产的开源项目官方文档写得那么详细,已经是很厚道了,可惜俺这种菜鸟还是会碰到各种"小"问题,做个笔记先! 1.新建数据库: CREATE DATABASE jeecg DEFAUL ...
- crontab执行脚本中文乱码,手动执行没有问题
crontab执行脚本中文乱码,手动执行没有问题 产生原因: 这是因为Unix/Linux下使用crontab时的运行环境已经不是用户环境了,因此原本用户下的一些环境变量的设置就失效了.例 ...
- JBPM4入门——7.等待节点的单条线手动执行
本博文只是简要对JBPM4进行介绍,如需更详细内容请自行google 链接: JBPM入门系列文章: JBPM4入门——1.jbpm简要介绍 JBPM4入门——2.在eclipse中安装绘制jbpm流 ...
- 是否需要手动执行DataContext的Dispose方法?
我们知道DataContext实现了IDisposable接口.在C#中,凡是实现了IDisposable接口的类,都推荐的使用using语句.如下: using (DataContext db = ...
- linux定时任务执行没结果,手动执行有结果问题总结
今天写了个脚本手动执行有结果,但是放到系统定时任务跑却没结果,之前也遇到这种问题解决了没记录后面又懵逼了一次~~~ 如下图: 手动执行有结果 放到定时任务中每五分钟执行一次 解决方法: 脚本中加载系统 ...
- crontab 定时执行脚本出错,但手动执行脚本正常
原因: crontab 没有去读环境变量,需要再脚本中手动引入环境变量,可以用source 也可以用export 写死环境变量. 为了定时监控Linux系统CPU.内存.负载的使用情况,写了个Shel ...
- crontab运行python不生效,但是手动执行正常的问题和解决方案
crontab运行python不生效,但是手动执行正常的问题和解决方案 linux默认装的是python2.7,安装了其他版本后直接执行没问题,但在crontab里执行不了,需要使用全路径. 使用 w ...
- Hbase 手动执行MajorCompation
说明: Major Compaction 的作用: 1.将一个Region下的所有StoreFile合并成一个StoreFile文件 2.对于删除.过期.多余版本的数据进行清除 由于MajorComp ...
- Laravel 定时任务 任务调度 可手动执行
1.创建一个命令 php artisan make:command TestCommand 执行成功后会提示: Console command created successfully. 生成了一个新 ...
随机推荐
- DPDK安装方法 17.12.13
DPDK安装方法 17.12.13 Ubuntu: $ git clone https://github.com/DPDK/dpdk.git $ cd dpdk/ $ export RTE_ARCH= ...
- Unity--game
打怪兽--头像状态 Git :https://github.com/vinieo/attck 打怪兽--背景音乐音量 Git :https://github.com/vinieo/ack_bgm 小球 ...
- Django本地开发,引用静态文件,火狐浏览器不能访问静态文件,谷歌浏览器却能访问静态文件
查了一下是settings.py设置问题 # Static files (CSS, JavaScript, Images)# https://docs.djangoproject.com/en/1.1 ...
- Thread.Sleep(0)妙用
Thread.Sleep(0)妙用 我们可能经常会用到 Thread.Sleep 函数来使线程挂起一段时间.那么你有没有正确的理解这个函数的用法呢?思考下面这两个问题: 假设现在是 2008-4-7 ...
- vue模拟后端获取数据——json-server与express
转载自: https://blog.csdn.net/weixin_39728230/article/details/80293892 https://blog.csdn.net/lxkll/arti ...
- tips 移入悬浮功能
前景: 页面部分区域需要移入悬浮效果,当然默认的 title 也是可以的,最多只是格格不入,但是却是最为靠谱的.. 思路: 基于 jq 实例扩展 .使用立即执行函数保持功能独立. 自定义类实现功能封装 ...
- java 虹软ArcFace 2.0,java SDK使用、人脸识别-抽取人脸特征并做比对
java人脸识别 虹软ArcFace 2.0,java SDK使用.人脸识别-抽取人脸特征并做比对 虹软产品地址:http://ai.arcsoft.com.cn/product/arcface.ht ...
- AtCoder Regular Contest 100 Equal Cut
Equal Cut 思路: 枚举中间那个分界点,然后两边找使得切割后差值最小的点,这个可以用双指针 代码: #include<bits/stdc++.h> using namespace ...
- Codeforces 958C3 - Encryption (hard)
C3 - Encryption (hard) 思路: 记sum[i]表示0 - i 的和对 p 取模的值. 1.如果k * p > n,那么与C2的做法一致,O(k*p*n)复杂度低于1e8. ...
- Python Appium 元素定位方法简单介绍
Python Appium 元素定位 常用的八种定位方法(与selenium通用) # id定位 driver.find_element_by_id() # name定位 driver.find_ ...