我有模型有嵌套的通话活动。我使用spring boot camunda启动器创建了单元测试。测试看起来像
@RunWith(SpringRunner.class)
@SpringBootTest(webEnvironment = SpringBootTest.WebEnvironment.DEFINED_PORT)
public class DiagramTest {
@Autowired
private ProcessEngine processEngine;
@Rule
@ClassRule
public static ProcessEngineRule rule;
@PostConstruct
void initRule() {
rule = TestCoverageProcessEngineRuleBuilder.create(processEngine).build();
}
@Before
public void setup() {
ProcessEngineTests.init(processEngine);
}
@Test
@Deployment(resources = {"process.bpmn", "subprocess.bpmn", "sub-subprocess.bpmn"})
@RequiredHistoryLevel(ProcessEngineConfiguration.HISTORY_NONE)
public void ruleUsageExample() {
RuntimeService runtimeService = rule.getRuntimeService();
runtimeService.startProcessInstanceByKey("process"); }
我的问题是,在大多数组件上,我之前/之后使用async,并且因为这些子流程无法启动。当我删除async -s时,它可以按预期工作。在camunda bpmn中测试异步行为的正确方法应该是什么?
答案 0 :(得分:2)
我不确定这是否可以解决您的问题,但不能在评论中显示。
这里的问题是流程实例被持久化,然后通过线程池中的下一个线程执行,因此执行单元测试的线程结束。 您需要通过查询流程引擎来测试作业是否完成,然后手动执行作业。 我正在使用此实用程序方法:
public boolean waitUntilNoActiveJobs(ProcessEngine processEngine, long wait) {
long timeout = System.currentTimeMillis() + wait;
while (System.currentTimeMillis() < timeout) {
long jobCount = processEngine.getManagementService().createJobQuery().active().count();
if (jobCount == 0) {
return true;
}
final List<Job> jobs = processEngine.getManagementService().createJobQuery().list();
jobs.forEach(job -> processEngine.getManagementService().executeJob(job.getId()));
System.out.println("Waiting for " + jobs + " jobs");
}
return false;
}
在测试结束时调用它,参数似乎很明显。