use of org.camunda.bpm.engine.management.JobDefinitionQuery in project camunda-bpm-platform by camunda.
the class SuspendJobDefinitionTest method testSuspensionByProcessDefinitionKeyAndSuspendJobsFlag_shouldRetainJobs.
@Deployment(resources = { "org/camunda/bpm/engine/test/api/mgmt/SuspensionTest.testBase.bpmn" })
public void testSuspensionByProcessDefinitionKeyAndSuspendJobsFlag_shouldRetainJobs() {
// given
// a deployed process definition with asynchronous continuation
ProcessDefinition processDefinition = repositoryService.createProcessDefinitionQuery().singleResult();
// a running process instance with a failed job
Map<String, Object> params = new HashMap<String, Object>();
params.put("fail", Boolean.TRUE);
runtimeService.startProcessInstanceByKey("suspensionProcess", params);
// a job definition (which was created for the asynchronous continuation)
JobDefinition jobDefinition = managementService.createJobDefinitionQuery().singleResult();
// when
// suspend the job definition
managementService.suspendJobDefinitionByProcessDefinitionKey(processDefinition.getKey(), false);
// then
// there exists a suspended job definition
JobDefinitionQuery jobDefinitionQuery = managementService.createJobDefinitionQuery().suspended();
assertEquals(1, jobDefinitionQuery.count());
JobDefinition suspendedJobDefinition = jobDefinitionQuery.singleResult();
assertEquals(jobDefinition.getId(), suspendedJobDefinition.getId());
assertTrue(suspendedJobDefinition.isSuspended());
// the corresponding job is still active
JobQuery jobQuery = managementService.createJobQuery();
assertEquals(0, jobQuery.suspended().count());
assertEquals(1, jobQuery.active().count());
Job activeJob = jobQuery.active().singleResult();
assertEquals(jobDefinition.getId(), activeJob.getJobDefinitionId());
assertFalse(activeJob.isSuspended());
}
use of org.camunda.bpm.engine.management.JobDefinitionQuery in project camunda-bpm-platform by camunda.
the class SuspendJobDefinitionTest method testSuspensionByProcessDefinitionKey_shouldRetainJobs.
@Deployment(resources = { "org/camunda/bpm/engine/test/api/mgmt/SuspensionTest.testBase.bpmn" })
public void testSuspensionByProcessDefinitionKey_shouldRetainJobs() {
// given
// a deployed process definition with asynchronous continuation
ProcessDefinition processDefinition = repositoryService.createProcessDefinitionQuery().singleResult();
// a running process instance with a failed job
Map<String, Object> params = new HashMap<String, Object>();
params.put("fail", Boolean.TRUE);
runtimeService.startProcessInstanceByKey("suspensionProcess", params);
// a job definition (which was created for the asynchronous continuation)
JobDefinition jobDefinition = managementService.createJobDefinitionQuery().singleResult();
// when
// suspend the job definition
managementService.suspendJobDefinitionByProcessDefinitionKey(processDefinition.getKey());
// then
// there exists a suspended job definition
JobDefinitionQuery jobDefinitionQuery = managementService.createJobDefinitionQuery().suspended();
assertEquals(1, jobDefinitionQuery.count());
JobDefinition suspendedJobDefinition = jobDefinitionQuery.singleResult();
assertEquals(jobDefinition.getId(), suspendedJobDefinition.getId());
// there does not exist any active job definition
jobDefinitionQuery = managementService.createJobDefinitionQuery().active();
assertTrue(jobDefinitionQuery.list().isEmpty());
// the corresponding job is still active
JobQuery jobQuery = managementService.createJobQuery();
assertEquals(0, jobQuery.suspended().count());
assertEquals(1, jobQuery.active().count());
Job activeJob = jobQuery.active().singleResult();
assertEquals(jobDefinition.getId(), activeJob.getJobDefinitionId());
assertFalse(activeJob.isSuspended());
}
use of org.camunda.bpm.engine.management.JobDefinitionQuery in project camunda-bpm-platform by camunda.
the class SuspendJobDefinitionTest method testMultipleSuspensionByProcessDefinitionKey_shouldExecuteDelayedAndSuspendJobs.
public void testMultipleSuspensionByProcessDefinitionKey_shouldExecuteDelayedAndSuspendJobs() {
// given
String key = "suspensionProcess";
// Deploy three processes and start for each deployment a process instance
// with a failed job
int nrOfProcessDefinitions = 3;
for (int i = 0; i < nrOfProcessDefinitions; i++) {
repositoryService.createDeployment().addClasspathResource("org/camunda/bpm/engine/test/api/mgmt/SuspensionTest.testBase.bpmn").deploy();
Map<String, Object> params = new HashMap<String, Object>();
params.put("fail", Boolean.TRUE);
runtimeService.startProcessInstanceByKey(key, params);
}
// a job definition (which was created for the asynchronous continuation)
// when
// suspend the job definition
managementService.suspendJobDefinitionByProcessDefinitionKey(key, true, oneWeekLater());
// then
// the job definitions are still active
JobDefinitionQuery jobDefinitionQuery = managementService.createJobDefinitionQuery();
assertEquals(3, jobDefinitionQuery.active().count());
assertEquals(0, jobDefinitionQuery.suspended().count());
// there exists a job for the delayed suspension execution
JobQuery jobQuery = managementService.createJobQuery();
Job delayedSuspensionJob = jobQuery.timers().active().singleResult();
assertNotNull(delayedSuspensionJob);
// execute job
managementService.executeJob(delayedSuspensionJob.getId());
// the job definition should be suspended
assertEquals(0, jobDefinitionQuery.active().count());
assertEquals(3, jobDefinitionQuery.suspended().count());
// the corresponding jobs are suspended
jobQuery = managementService.createJobQuery();
assertEquals(0, jobQuery.active().count());
assertEquals(3, jobQuery.suspended().count());
// Clean DB
for (org.camunda.bpm.engine.repository.Deployment deployment : repositoryService.createDeploymentQuery().list()) {
repositoryService.deleteDeployment(deployment.getId(), true);
}
}
use of org.camunda.bpm.engine.management.JobDefinitionQuery in project camunda-bpm-platform by camunda.
the class SuspendJobDefinitionTest method testSuspensionByProcessDefinitionId_shouldExecuteDelayedAndSuspendJobs.
@Deployment(resources = { "org/camunda/bpm/engine/test/api/mgmt/SuspensionTest.testBase.bpmn" })
public void testSuspensionByProcessDefinitionId_shouldExecuteDelayedAndSuspendJobs() {
// given
// a deployed process definition with asynchronous continuation
ProcessDefinition processDefinition = repositoryService.createProcessDefinitionQuery().singleResult();
// a running process instance with a failed job
Map<String, Object> params = new HashMap<String, Object>();
params.put("fail", Boolean.TRUE);
runtimeService.startProcessInstanceByKey("suspensionProcess", params);
// a job definition (which was created for the asynchronous continuation)
JobDefinition jobDefinition = managementService.createJobDefinitionQuery().singleResult();
// when
// suspend the job definition
managementService.suspendJobDefinitionByProcessDefinitionId(processDefinition.getId(), true, oneWeekLater());
// then
// the job definition is still active
JobDefinitionQuery jobDefinitionQuery = managementService.createJobDefinitionQuery();
assertEquals(1, jobDefinitionQuery.active().count());
assertEquals(0, jobDefinitionQuery.suspended().count());
// there exists a job for the delayed suspension execution
JobQuery jobQuery = managementService.createJobQuery();
Job delayedSuspensionJob = jobQuery.timers().active().singleResult();
assertNotNull(delayedSuspensionJob);
// execute job
managementService.executeJob(delayedSuspensionJob.getId());
// the job definition should be suspended
assertEquals(0, jobDefinitionQuery.active().count());
assertEquals(1, jobDefinitionQuery.suspended().count());
JobDefinition suspendedJobDefinition = jobDefinitionQuery.suspended().singleResult();
assertEquals(jobDefinition.getId(), suspendedJobDefinition.getId());
assertTrue(suspendedJobDefinition.isSuspended());
// the corresponding job is suspended
jobQuery = managementService.createJobQuery();
assertEquals(0, jobQuery.active().count());
assertEquals(1, jobQuery.suspended().count());
Job suspendedJob = jobQuery.suspended().singleResult();
assertEquals(jobDefinition.getId(), suspendedJob.getJobDefinitionId());
assertTrue(suspendedJob.isSuspended());
}
use of org.camunda.bpm.engine.management.JobDefinitionQuery in project camunda-bpm-platform by camunda.
the class SuspendJobDefinitionTest method testMultipleSuspensionByProcessDefinitionKey_shouldExecuteImmediatelyAndRetainJobs.
public void testMultipleSuspensionByProcessDefinitionKey_shouldExecuteImmediatelyAndRetainJobs() {
// given
String key = "suspensionProcess";
// Deploy three processes and start for each deployment a process instance
// with a failed job
int nrOfProcessDefinitions = 3;
for (int i = 0; i < nrOfProcessDefinitions; i++) {
repositoryService.createDeployment().addClasspathResource("org/camunda/bpm/engine/test/api/mgmt/SuspensionTest.testBase.bpmn").deploy();
Map<String, Object> params = new HashMap<String, Object>();
params.put("fail", Boolean.TRUE);
runtimeService.startProcessInstanceByKey(key, params);
}
// a job definition (which was created for the asynchronous continuation)
// when
// suspend the job definition
managementService.suspendJobDefinitionByProcessDefinitionKey(key, false, null);
// then
// all job definitions are suspended
JobDefinitionQuery jobDefinitionQuery = managementService.createJobDefinitionQuery();
assertEquals(3, jobDefinitionQuery.suspended().count());
assertEquals(0, jobDefinitionQuery.active().count());
// but the jobs are still active
JobQuery jobQuery = managementService.createJobQuery();
assertEquals(0, jobQuery.suspended().count());
assertEquals(3, jobQuery.active().count());
// Clean DB
for (org.camunda.bpm.engine.repository.Deployment deployment : repositoryService.createDeploymentQuery().list()) {
repositoryService.deleteDeployment(deployment.getId(), true);
}
}
Aggregations