use of org.camunda.bpm.engine.management.JobDefinitionQuery in project camunda-bpm-platform by camunda.
the class ProcessDefinitionSuspensionTest method testDelayedSuspendByKeyAndIncludeInstancesFlag_shouldSuspendJobDefinitionAndJob.
@Deployment(resources = { "org/camunda/bpm/engine/test/api/repository/ProcessDefinitionSuspensionTest.testWithOneAsyncServiceTask.bpmn" })
public void testDelayedSuspendByKeyAndIncludeInstancesFlag_shouldSuspendJobDefinitionAndJob() {
Date startTime = new Date();
ClockUtil.setCurrentTime(startTime);
final long hourInMs = 60 * 60 * 1000;
// a process definition with a asynchronous continuation, so that there
// exists a job definition
ProcessDefinition processDefinition = repositoryService.createProcessDefinitionQuery().singleResult();
JobDefinition jobDefinition = managementService.createJobDefinitionQuery().singleResult();
// a running process instance with a failed service task
Map<String, Object> params = new HashMap<String, Object>();
params.put("fail", Boolean.TRUE);
runtimeService.startProcessInstanceById(processDefinition.getId(), params);
// when
// the process definition will be suspended in 2 hours
repositoryService.suspendProcessDefinitionByKey(processDefinition.getKey(), true, new Date(startTime.getTime() + (2 * hourInMs)));
// then
// there exists a job to suspend process definition
Job timerToSuspendProcessDefinition = managementService.createJobQuery().timers().singleResult();
assertNotNull(timerToSuspendProcessDefinition);
// the job definition should still active
JobDefinitionQuery jobDefinitionQuery = managementService.createJobDefinitionQuery();
assertEquals(0, jobDefinitionQuery.suspended().count());
assertEquals(1, jobDefinitionQuery.active().count());
JobDefinition activeJobDefinition = jobDefinitionQuery.active().singleResult();
assertEquals(jobDefinition.getId(), activeJobDefinition.getId());
assertFalse(activeJobDefinition.isSuspended());
// the job is still active
JobQuery jobQuery = managementService.createJobQuery();
assertEquals(0, jobQuery.suspended().count());
// there exists two jobs, a failing job and a timer job
assertEquals(2, jobQuery.active().count());
// when
// execute job
managementService.executeJob(timerToSuspendProcessDefinition.getId());
// then
// 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 job is still active
assertEquals(0, jobQuery.active().count());
assertEquals(1, jobQuery.suspended().count());
Job job = jobQuery.suspended().singleResult();
assertEquals(jobDefinition.getId(), job.getJobDefinitionId());
assertTrue(job.isSuspended());
}
use of org.camunda.bpm.engine.management.JobDefinitionQuery in project camunda-bpm-platform by camunda.
the class ProcessDefinitionSuspensionTest method testSuspendByIdAndIncludeInstancesFlag_shouldSuspendAlsoJobDefinitionAndRetainJob.
@Deployment(resources = { "org/camunda/bpm/engine/test/api/repository/ProcessDefinitionSuspensionTest.testWithOneAsyncServiceTask.bpmn" })
public void testSuspendByIdAndIncludeInstancesFlag_shouldSuspendAlsoJobDefinitionAndRetainJob() {
// a process definition with a asynchronous continuation, so that there
// exists a job definition
ProcessDefinition processDefinition = repositoryService.createProcessDefinitionQuery().singleResult();
JobDefinition jobDefinition = managementService.createJobDefinitionQuery().singleResult();
// a running process instance with a failed service task
Map<String, Object> params = new HashMap<String, Object>();
params.put("fail", Boolean.TRUE);
runtimeService.startProcessInstanceById(processDefinition.getId(), params);
// when
// the process definition will be suspended
repositoryService.suspendProcessDefinitionById(processDefinition.getId(), false, null);
// then
// the job definition should be suspended...
JobDefinitionQuery jobDefinitionQuery = managementService.createJobDefinitionQuery();
assertEquals(0, jobDefinitionQuery.active().count());
assertEquals(1, jobDefinitionQuery.suspended().count());
JobDefinition suspendedJobDefinition = jobDefinitionQuery.suspended().singleResult();
assertEquals(jobDefinition.getId(), suspendedJobDefinition.getId());
assertTrue(suspendedJobDefinition.isSuspended());
// ...and the corresponding job should be still active
JobQuery jobQuery = managementService.createJobQuery();
assertEquals(0, jobQuery.suspended().count());
assertEquals(1, jobQuery.active().count());
Job job = jobQuery.active().singleResult();
assertEquals(jobDefinition.getId(), job.getJobDefinitionId());
assertFalse(job.isSuspended());
}
use of org.camunda.bpm.engine.management.JobDefinitionQuery in project camunda-bpm-platform by camunda.
the class ProcessDefinitionSuspensionTest method testSuspendByKey_shouldSuspendJobDefinitionAndRetainJob.
@Deployment(resources = { "org/camunda/bpm/engine/test/api/repository/ProcessDefinitionSuspensionTest.testWithOneAsyncServiceTask.bpmn" })
public void testSuspendByKey_shouldSuspendJobDefinitionAndRetainJob() {
// given
// a process definition with a asynchronous continuation, so that there
// exists a job definition
ProcessDefinition processDefinition = repositoryService.createProcessDefinitionQuery().singleResult();
JobDefinition jobDefinition = managementService.createJobDefinitionQuery().singleResult();
// a running process instance with a failed service task
Map<String, Object> params = new HashMap<String, Object>();
params.put("fail", Boolean.TRUE);
runtimeService.startProcessInstanceById(processDefinition.getId(), params);
// when
// the process definition will be suspended
repositoryService.suspendProcessDefinitionByKey(processDefinition.getKey());
// then
// the job definition should be suspended...
JobDefinitionQuery jobDefinitionQuery = managementService.createJobDefinitionQuery();
assertEquals(0, jobDefinitionQuery.active().count());
assertEquals(1, jobDefinitionQuery.suspended().count());
JobDefinition suspendedJobDefinition = jobDefinitionQuery.suspended().singleResult();
assertEquals(jobDefinition.getId(), suspendedJobDefinition.getId());
assertTrue(suspendedJobDefinition.isSuspended());
// ...and the corresponding job should be still active
JobQuery jobQuery = managementService.createJobQuery();
assertEquals(0, jobQuery.suspended().count());
assertEquals(1, jobQuery.active().count());
Job job = jobQuery.active().singleResult();
assertEquals(jobDefinition.getId(), job.getJobDefinitionId());
assertFalse(job.isSuspended());
}
use of org.camunda.bpm.engine.management.JobDefinitionQuery in project camunda-bpm-platform by camunda.
the class ProcessDefinitionSuspensionTest method testMultipleActivationByKey_shouldActivateJobDefinitionAndRetainJob.
public void testMultipleActivationByKey_shouldActivateJobDefinitionAndRetainJob() {
String key = "oneFailingServiceTaskProcess";
// Deploy five versions of the same process, so that there exists
// five job definitions
int nrOfProcessDefinitions = 5;
for (int i = 0; i < nrOfProcessDefinitions; i++) {
repositoryService.createDeployment().addClasspathResource("org/camunda/bpm/engine/test/api/repository/ProcessDefinitionSuspensionTest.testWithOneAsyncServiceTask.bpmn").deploy();
// a running process instance with a failed service task
Map<String, Object> params = new HashMap<String, Object>();
params.put("fail", Boolean.TRUE);
runtimeService.startProcessInstanceByKey(key, params);
}
// the process definition, job definition, process instance and job will be suspended
repositoryService.suspendProcessDefinitionByKey(key, true, null);
assertEquals(0, repositoryService.createProcessDefinitionQuery().active().count());
assertEquals(5, repositoryService.createProcessDefinitionQuery().suspended().count());
assertEquals(0, managementService.createJobDefinitionQuery().active().count());
assertEquals(5, managementService.createJobDefinitionQuery().suspended().count());
// when
// the process definition will be activated
repositoryService.activateProcessDefinitionByKey(key);
// then
// the job definitions should be activated...
JobDefinitionQuery jobDefinitionQuery = managementService.createJobDefinitionQuery();
assertEquals(0, jobDefinitionQuery.suspended().count());
assertEquals(5, jobDefinitionQuery.active().count());
// ...and the corresponding jobs should be still suspended
JobQuery jobQuery = managementService.createJobQuery();
assertEquals(0, jobQuery.active().count());
assertEquals(5, 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 ProcessDefinitionSuspensionTest method testDelayedMultipleActivationByKeyAndIncludeInstances_shouldActivateJobDefinitionAndJob.
public void testDelayedMultipleActivationByKeyAndIncludeInstances_shouldActivateJobDefinitionAndJob() {
Date startTime = new Date();
ClockUtil.setCurrentTime(startTime);
final long hourInMs = 60 * 60 * 1000;
String key = "oneFailingServiceTaskProcess";
// Deploy five versions of the same process, so that there exists
// five job definitions
int nrOfProcessDefinitions = 5;
for (int i = 0; i < nrOfProcessDefinitions; i++) {
repositoryService.createDeployment().addClasspathResource("org/camunda/bpm/engine/test/api/repository/ProcessDefinitionSuspensionTest.testWithOneAsyncServiceTask.bpmn").deploy();
// a running process instance with a failed service task
Map<String, Object> params = new HashMap<String, Object>();
params.put("fail", Boolean.TRUE);
runtimeService.startProcessInstanceByKey(key, params);
}
// the process definition, job definition, process instance and job will be suspended
repositoryService.suspendProcessDefinitionByKey(key, true, null);
assertEquals(0, repositoryService.createProcessDefinitionQuery().active().count());
assertEquals(5, repositoryService.createProcessDefinitionQuery().suspended().count());
assertEquals(0, managementService.createJobDefinitionQuery().active().count());
assertEquals(5, managementService.createJobDefinitionQuery().suspended().count());
// when
// the process definition will be activated
repositoryService.activateProcessDefinitionByKey(key, true, new Date(startTime.getTime() + (2 * hourInMs)));
// then
// there exists a timer job to activate the process definition delayed
Job timerToActivateProcessDefinition = managementService.createJobQuery().timers().singleResult();
assertNotNull(timerToActivateProcessDefinition);
// the job definitions should be still suspended
JobDefinitionQuery jobDefinitionQuery = managementService.createJobDefinitionQuery();
assertEquals(5, jobDefinitionQuery.suspended().count());
assertEquals(0, jobDefinitionQuery.active().count());
// ...and the corresponding jobs should be still suspended
JobQuery jobQuery = managementService.createJobQuery();
assertEquals(5, jobQuery.suspended().count());
assertEquals(1, jobQuery.active().count());
// when
// execute job
managementService.executeJob(timerToActivateProcessDefinition.getId());
// then
// the job definitions should be activated...
assertEquals(5, jobDefinitionQuery.active().count());
assertEquals(0, jobDefinitionQuery.suspended().count());
// ...and the corresponding jobs should be activated too
assertEquals(5, jobQuery.active().count());
assertEquals(0, jobQuery.suspended().count());
// Clean DB
for (org.camunda.bpm.engine.repository.Deployment deployment : repositoryService.createDeploymentQuery().list()) {
repositoryService.deleteDeployment(deployment.getId(), true);
}
}
Aggregations