use of org.camunda.bpm.engine.management.JobDefinition in project camunda-bpm-platform by camunda.
the class ManagementServiceTest method testSetJobRetriesByJobDefinitionId.
@Deployment(resources = { "org/camunda/bpm/engine/test/api/mgmt/ManagementServiceTest.testGetJobExceptionStacktrace.bpmn20.xml" })
public void testSetJobRetriesByJobDefinitionId() {
ProcessInstance processInstance = runtimeService.startProcessInstanceByKey("exceptionInJobExecution");
executeAvailableJobs();
JobQuery query = managementService.createJobQuery().processInstanceId(processInstance.getId());
JobDefinition jobDefinition = managementService.createJobDefinitionQuery().singleResult();
Job timerJob = query.singleResult();
assertNotNull("No job found for process instance", timerJob);
assertEquals(0, timerJob.getRetries());
managementService.setJobRetriesByJobDefinitionId(jobDefinition.getId(), 5);
timerJob = query.singleResult();
assertEquals(5, timerJob.getRetries());
}
use of org.camunda.bpm.engine.management.JobDefinition in project camunda-bpm-platform by camunda.
the class SuspendJobDefinitionTest method testSuspensionJobDefinitionIncludeJobsdUsingBuilder.
@Deployment(resources = { "org/camunda/bpm/engine/test/api/mgmt/SuspensionTest.testBase.bpmn" })
public void testSuspensionJobDefinitionIncludeJobsdUsingBuilder() {
// given
// a deployed process definition with asynchronous continuation
// a running process instance with a failed job
runtimeService.startProcessInstanceByKey("suspensionProcess", Variables.createVariables().putValue("fail", true));
// a job definition (which was created for the asynchronous continuation)
JobDefinitionQuery query = managementService.createJobDefinitionQuery();
JobDefinition jobDefinition = query.singleResult();
assertFalse(jobDefinition.isSuspended());
JobQuery jobQuery = managementService.createJobQuery();
assertEquals(0, jobQuery.suspended().count());
assertEquals(1, jobQuery.active().count());
// when
// suspend the job definition and the job
managementService.updateJobDefinitionSuspensionState().byJobDefinitionId(jobDefinition.getId()).includeJobs(true).suspend();
// then
// there exists a suspended job definition and job
assertEquals(1, query.suspended().count());
assertEquals(1, jobQuery.suspended().count());
assertEquals(0, jobQuery.active().count());
}
use of org.camunda.bpm.engine.management.JobDefinition in project camunda-bpm-platform by camunda.
the class SuspendJobDefinitionTest method testSuspensionByProcessDefinitionKey_shouldExecuteDelayedAndRetainJobs.
@Deployment(resources = { "org/camunda/bpm/engine/test/api/mgmt/SuspensionTest.testBase.bpmn" })
public void testSuspensionByProcessDefinitionKey_shouldExecuteDelayedAndRetainJobs() {
// 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, 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 still active
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.JobDefinition in project camunda-bpm-platform by camunda.
the class SuspendJobDefinitionTest method testSuspensionByProcessDefinitionIdUsingBuilder.
@Deployment(resources = { "org/camunda/bpm/engine/test/api/mgmt/SuspensionTest.testBase.bpmn" })
public void testSuspensionByProcessDefinitionIdUsingBuilder() {
// given
// a deployed process definition with asynchronous continuation
// a running process instance with a failed job
runtimeService.startProcessInstanceByKey("suspensionProcess", Variables.createVariables().putValue("fail", true));
// a job definition (which was created for the asynchronous continuation)
JobDefinitionQuery query = managementService.createJobDefinitionQuery();
JobDefinition jobDefinition = query.singleResult();
assertFalse(jobDefinition.isSuspended());
ProcessDefinition processDefinition = repositoryService.createProcessDefinitionQuery().singleResult();
// when
// suspend the job definition
managementService.updateJobDefinitionSuspensionState().byProcessDefinitionId(processDefinition.getId()).suspend();
// then
// there exists a suspended job definition
assertEquals(1, query.suspended().count());
}
use of org.camunda.bpm.engine.management.JobDefinition in project camunda-bpm-platform by camunda.
the class SuspendJobDefinitionTest method testSuspensionById_shouldExecuteImmediatelyAndRetainJobs.
@Deployment(resources = { "org/camunda/bpm/engine/test/api/mgmt/SuspensionTest.testBase.bpmn" })
public void testSuspensionById_shouldExecuteImmediatelyAndRetainJobs() {
// given
// a deployed process definition with asynchronous continuation
// 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.suspendJobDefinitionById(jobDefinition.getId(), false, null);
// 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().active();
assertEquals(1, jobQuery.count());
Job activeJob = jobQuery.singleResult();
assertEquals(jobDefinition.getId(), activeJob.getJobDefinitionId());
assertFalse(activeJob.isSuspended());
jobQuery = managementService.createJobQuery().suspended();
assertEquals(0, jobQuery.count());
}
Aggregations