Spring Boot Camunda单元测试-之前/之后

时间:2019-05-24 07:59:01

标签: spring spring-boot bpmn camunda

我有模型有嵌套的通话活动。我使用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中测试异步行为的正确方法应该是什么?

1 个答案:

答案 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;
}

在测试结束时调用它,参数似乎很明显。

相关问题