All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.camunda.bpm.engine.test.ProcessEngineTestCase Maven / Gradle / Ivy

There is a newer version: 7.23.0-alpha2
Show newest version
/* Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 * 
 *      http://www.apache.org/licenses/LICENSE-2.0
 * 
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */

package org.camunda.bpm.engine.test;

import java.io.FileNotFoundException;
import java.util.Date;

import junit.framework.TestCase;

import org.camunda.bpm.engine.FormService;
import org.camunda.bpm.engine.HistoryService;
import org.camunda.bpm.engine.IdentityService;
import org.camunda.bpm.engine.ManagementService;
import org.camunda.bpm.engine.ProcessEngine;
import org.camunda.bpm.engine.ProcessEngineConfiguration;
import org.camunda.bpm.engine.RepositoryService;
import org.camunda.bpm.engine.RuntimeService;
import org.camunda.bpm.engine.TaskService;
import org.camunda.bpm.engine.impl.test.ProcessEngineAssert;
import org.camunda.bpm.engine.impl.test.TestHelper;
import org.camunda.bpm.engine.impl.util.ClockUtil;


/** Convenience for ProcessEngine and services initialization in the form of a JUnit base class.
 * 
 * 

Usage: public class YourTest extends ProcessEngineTestCase

* *

The ProcessEngine and the services available to subclasses through protected member fields. * The processEngine will be initialized by default with the camunda.cfg.xml resource * on the classpath. To specify a different configuration file, override the * {@link #getConfigurationResource()} method. * Process engines will be cached statically. The first time the setUp is called for a given * configuration resource, the process engine will be constructed.

* *

You can declare a deployment with the {@link Deployment} annotation. * This base class will make sure that this deployment gets deployed in the * setUp and {@link RepositoryService#deleteDeploymentCascade(String, boolean) cascade deleted} * in the tearDown. *

* *

This class also lets you {@link #setCurrentTime(Date) set the current time used by the * process engine}. This can be handy to control the exact time that is used by the engine * in order to verify e.g. e.g. due dates of timers. Or start, end and duration times * in the history service. In the tearDown, the internal clock will automatically be * reset to use the current system time rather then the time that was set during * a test method. In other words, you don't have to clean up your own time messing mess ;-) *

* * @author Tom Baeyens */ public class ProcessEngineTestCase extends TestCase { protected String configurationResource = "camunda.cfg.xml"; protected String configurationResourceCompat = "activiti.cfg.xml"; protected String deploymentId = null; protected ProcessEngine processEngine; protected RepositoryService repositoryService; protected RuntimeService runtimeService; protected TaskService taskService; protected HistoryService historicDataService; protected IdentityService identityService; protected ManagementService managementService; protected FormService formService; /** uses 'camunda.cfg.xml' as it's configuration resource */ public ProcessEngineTestCase() { } public void assertProcessEnded(final String processInstanceId) { ProcessEngineAssert.assertProcessEnded(processEngine, processInstanceId); } @Override protected void setUp() throws Exception { super.setUp(); if (processEngine==null) { initializeProcessEngine(); initializeServices(); } deploymentId = TestHelper.annotationDeploymentSetUp(processEngine, getClass(), getName()); } protected void initializeProcessEngine() { try { processEngine = TestHelper.getProcessEngine(getConfigurationResource()); } catch (RuntimeException ex) { if (ex.getCause() != null && ex.getCause() instanceof FileNotFoundException) { processEngine = ProcessEngineConfiguration .createProcessEngineConfigurationFromResource(configurationResourceCompat) .buildProcessEngine(); } else { throw ex; } } } protected void initializeServices() { repositoryService = processEngine.getRepositoryService(); runtimeService = processEngine.getRuntimeService(); taskService = processEngine.getTaskService(); historicDataService = processEngine.getHistoryService(); identityService = processEngine.getIdentityService(); managementService = processEngine.getManagementService(); formService = processEngine.getFormService(); } @Override protected void tearDown() throws Exception { TestHelper.annotationDeploymentTearDown(processEngine, deploymentId, getClass(), getName()); ClockUtil.reset(); super.tearDown(); } public static void closeProcessEngines() { TestHelper.closeProcessEngines(); } public void setCurrentTime(Date currentTime) { ClockUtil.setCurrentTime(currentTime); } public String getConfigurationResource() { return configurationResource; } public void setConfigurationResource(String configurationResource) { this.configurationResource = configurationResource; } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy