Flowable7.0.1框架严重bug,流程跳转到指定节点导致流程中断

一、Bug描述

使用7.0.1版本的 moveActivityIdsToSingleActivityId 或 moveExecutionsToSingleActivityId实现节点跳转,程序不会报错,但是act_ru_task 没有生成新的任务,导致流程中断,这是相当严重的bug。

经过多次测试,发现单实例没问题,如果是多实例就会产生上边说的问题,导致流程中断

java 复制代码
runtimeService.createChangeActivityStateBuilder()
                .processInstanceId(processInstanceId)
                .moveActivityIdsToSingleActivityId("当前的任务的节点id", "需要跳转的目标节点")
                .changeState();


runtimeService.createChangeActivityStateBuilder()
                .processInstanceId(processInstanceId)
                .moveExecutionsToSingleActivityId(realExecutionIds,
targetRealActivityId).changeState();

二、问题复现

1、退回发起人节点

从审核人2退回发起人,经过测试发现退到发起人是没有问题的。

2、其他节点退回非发起人节点

从审核人2退回审核人1或审核人3退回审核人1或审核人2,测试发现,会产生流程中断,退回后的节点没有产生新任务,经过断点发现没有调用获取人员的UEL表达式,如下图所示

三、解决方案

1、退回低版本

7.0.1 -->7.0.0.M1

6.8.1-->6.8.0

2、修改源代码

调用退回api的时候,会调用

复制代码
org.flowable.engine.impl.dynamic.AbstractDynamicStateManager的createEmbeddedSubProcessAndExecutions 方法

本地代码创建和源码完全同包名、同方法名的类,将低版本的6.8.0或6.7.2版本中的

复制代码
createEmbeddedSubProcessAndExecutions方法的实现替换掉高版的实现即可。

四、总结

github 上issue也有好几人人遇到该问题,https://github.com/flowable/flowable-engine/issues/3944

但是官方还没推出该bug的解决方案,建议还是先降低版本,最方便也最省事,等官方解决了可以再切回来。

相关推荐
Lucifer三思而后行3 小时前
ORA 600 [qkaQknLTPruneKaf:1] BUG 分析与处理
bug
月临水10 小时前
软件测试笔记1(测试的概念、测试和开发模型介绍、BUG介绍)
软件测试·笔记·bug
种时光的人10 小时前
多线程出bug不知道如何调试?java线程几种常见状态
java·python·bug
测试工程喵10 小时前
如何高效定位Bug:测试工程师的问题诊断艺术
功能测试·测试用例·bug·模块测试·缺陷管理·bug定位
灵犀海棠2 天前
vue3项目启动bug
bug
家庭云计算专家3 天前
ONLYOFFICE深度解锁系列.2-Excel 跨文件数据整合实战指南-可道云的另一个严重bug
云计算·编辑器·bug·excel
不会编程的程序員3 天前
【解决方法】关于解决QGC地面站4.4.3中文BUG,无法标注航点的问题
bug
liuluyang5303 天前
linux 4.14内核jffs2文件系统不自动释放空间的bug
linux·elasticsearch·bug·jffs2
weixin_398187754 天前
YOLOv8 Bug 及解决方案汇总 【2024.1.24更新】【环境安装】【训练 & 断点续训】OMPError / KeyError
yolo·机器学习·bug