org.activiti.engine.test.ActivitiTestCase Maven / Gradle / Ivy
/* 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.activiti.engine.test;
import junit.framework.TestCase;
import org.activiti.engine.*;
import org.activiti.engine.impl.ProcessEngineImpl;
import org.activiti.engine.impl.test.TestHelper;
import org.activiti.engine.test.mock.ActivitiMockSupport;
import java.util.Date;
/**
* Convenience for ProcessEngine and services initialization in the form of a JUnit base class.
*
*
* Usage: public class YourTest extends ActivitiTestCase
*
*
*
* The ProcessEngine and the services available to subclasses through protected member fields. The processEngine will be initialized by default with the activiti.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.
*
*
*/
public abstract class ActivitiTestCase extends TestCase {
protected String configurationResource = "activiti.cfg.xml";
protected String deploymentId;
protected ProcessEngineConfiguration processEngineConfiguration;
protected ProcessEngine processEngine;
protected RepositoryService repositoryService;
protected RuntimeService runtimeService;
protected TaskService taskService;
protected HistoryService historicDataService;
protected ManagementService managementService;
private ActivitiMockSupport mockSupport;
/** uses 'activiti.cfg.xml' as it's configuration resource */
public ActivitiTestCase() {
}
public void assertProcessEnded(final String processInstanceId) {
TestHelper.assertProcessEnded(processEngine, processInstanceId);
}
@Override
protected void setUp() throws Exception {
super.setUp();
if (processEngine == null) {
initializeProcessEngine();
initializeServices();
initializeMockSupport();
}
}
@Override
protected void runTest() throws Throwable {
// Support for mockup annotations on test method
TestHelper.annotationMockSupportSetup(getClass(), getName(), mockSupport);
// The deployment of processes denoted by @Deployment should
// be done after the setup(). After all, the mockups must be
// configured in the engine before the actual deployment happens
deploymentId = TestHelper.annotationDeploymentSetUp(processEngine, getClass(), getName());
super.runTest();
// Remove deployment
TestHelper.annotationDeploymentTearDown(processEngine, deploymentId, getClass(), getName());
// Reset mocks
TestHelper.annotationMockSupportTeardown(mockSupport);
}
protected void initializeProcessEngine() {
processEngine = TestHelper.getProcessEngine(getConfigurationResource());
}
protected void initializeServices() {
processEngineConfiguration = ((ProcessEngineImpl) processEngine).getProcessEngineConfiguration();
repositoryService = processEngine.getRepositoryService();
runtimeService = processEngine.getRuntimeService();
taskService = processEngine.getTaskService();
historicDataService = processEngine.getHistoryService();
managementService = processEngine.getManagementService();
}
protected void initializeMockSupport() {
if (ActivitiMockSupport.isMockSupportPossible(processEngine)) {
this.mockSupport = new ActivitiMockSupport(processEngine);
}
}
@Override
protected void tearDown() throws Exception {
// Reset any timers
processEngineConfiguration.getClock().reset();
// Reset any mocks
if (mockSupport != null) {
mockSupport.reset();
}
super.tearDown();
}
public static void closeProcessEngines() {
TestHelper.closeProcessEngines();
}
public void setCurrentTime(Date currentTime) {
processEngineConfiguration.getClock().setCurrentTime(currentTime);
}
public String getConfigurationResource() {
return configurationResource;
}
public void setConfigurationResource(String configurationResource) {
this.configurationResource = configurationResource;
}
public ActivitiMockSupport getMockSupport() {
return mockSupport;
}
public ActivitiMockSupport mockSupport() {
return mockSupport;
}
}