/* * Copyright 2014 Red Hat, Inc. and/or its affiliates. * * 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.jbpm.services.ejb.client; import static org.junit.Assert.assertEquals; import static org.junit.Assert.assertNotNull; import static org.junit.Assert.assertNull; import static org.kie.scanner.MavenRepository.getMavenRepository; import java.io.File; import java.net.MalformedURLException; import java.util.ArrayList; import java.util.HashMap; import java.util.List; import java.util.Map; import org.jbpm.kie.services.impl.KModuleDeploymentUnit; import org.jbpm.kie.test.util.AbstractKieServicesBaseTest; import org.jbpm.services.api.model.DeploymentUnit; import org.jbpm.services.ejb.api.DefinitionServiceEJBRemote; import org.jbpm.services.ejb.api.DeploymentServiceEJBRemote; import org.jbpm.services.ejb.api.ProcessServiceEJBRemote; import org.jbpm.services.ejb.api.RuntimeDataServiceEJBRemote; import org.jbpm.services.ejb.api.UserTaskServiceEJBRemote; import org.jbpm.services.ejb.client.helper.DeploymentServiceWrapper; import org.junit.After; import org.junit.Before; import org.junit.Test; import org.kie.api.KieServices; import org.kie.api.builder.ReleaseId; import org.kie.api.runtime.process.ProcessInstance; import org.kie.api.task.model.TaskSummary; import org.kie.internal.query.QueryFilter; import org.kie.scanner.MavenRepository; public class ClientEjbTimerServiceTest extends AbstractKieServicesBaseTest { private static final String application = "sample-war-ejb-app"; private List<DeploymentUnit> units = new ArrayList<DeploymentUnit>(); private static final String ARTIFACT_ID = "custom-data-project"; private static final String GROUP_ID = "org.jbpm.test"; private static final String VERSION = "1.0"; private Long processInstanceId; @Before public void prepare() throws MalformedURLException { configureServices(); KieServices ks = KieServices.Factory.get(); ReleaseId releaseId = ks.newReleaseId(GROUP_ID, ARTIFACT_ID, VERSION); File kjar = new File("src/test/resources/kjar/custom-data-project-1.0.jar"); File pom = new File("src/test/resources/kjar/pom.xml"); MavenRepository repository = getMavenRepository(); repository.installArtifact(releaseId, kjar, pom); } @After public void cleanup() { if (processInstanceId != null) { // let's abort process instance to leave the system in clear state processService.abortProcessInstance(processInstanceId); } cleanupSingletonSessionId(); if (units != null && !units.isEmpty()) { for (DeploymentUnit unit : units) { deploymentService.undeploy(unit); } units.clear(); } close(); } @Override protected void close() { // do nothing } @Before public void setup() { configureServices(); } @Override protected void configureServices() { try { ClientServiceFactory factory = ServiceFactoryProvider.getProvider("JBoss"); DeploymentServiceEJBRemote deploymentService = factory.getService(application, DeploymentServiceEJBRemote.class); ProcessServiceEJBRemote processService = factory.getService(application, ProcessServiceEJBRemote.class); RuntimeDataServiceEJBRemote runtimeDataService = factory.getService(application, RuntimeDataServiceEJBRemote.class); DefinitionServiceEJBRemote definitionService = factory.getService(application, DefinitionServiceEJBRemote.class); UserTaskServiceEJBRemote userTaskService = factory.getService(application, UserTaskServiceEJBRemote.class); setBpmn2Service(definitionService); setProcessService(processService); setRuntimeDataService(runtimeDataService); setUserTaskService(userTaskService); setDeploymentService(new DeploymentServiceWrapper(deploymentService)); } catch (Exception e) { throw new RuntimeException("Unable to configure services"); } } @Test public void testStartProcess() throws InterruptedException { assertNotNull(deploymentService); KModuleDeploymentUnit deploymentUnit = new KModuleDeploymentUnit(GROUP_ID, ARTIFACT_ID, VERSION); deploymentService.deploy(deploymentUnit); units.add(deploymentUnit); assertNotNull(processService); Map<String, Object> params = new HashMap<String, Object>(); params.put("expiresAt", "2s"); long processInstanceId = processService.startProcess(deploymentUnit.getIdentifier(), "timer-test.timer-process", params); assertNotNull(processInstanceId); ProcessInstance pi = processService.getProcessInstance(processInstanceId); assertNotNull(pi); Thread.sleep(3000); pi = processService.getProcessInstance(processInstanceId); assertNull(pi); } @Test public void testStartProcessWithHTDeadline() throws InterruptedException { assertNotNull(deploymentService); KModuleDeploymentUnit deploymentUnit = new KModuleDeploymentUnit(GROUP_ID, ARTIFACT_ID, VERSION); deploymentService.deploy(deploymentUnit); units.add(deploymentUnit); assertNotNull(processService); processInstanceId = processService.startProcess(deploymentUnit.getIdentifier(), "htdeadlinetest"); List<TaskSummary> krisTasks = runtimeDataService.getTasksAssignedAsPotentialOwner("krisv", new QueryFilter()); assertEquals(1, krisTasks.size()); List<TaskSummary> johnTasks = runtimeDataService.getTasksAssignedAsPotentialOwner("john", new QueryFilter()); assertEquals(0, johnTasks.size()); List<TaskSummary> maryTasks = runtimeDataService.getTasksAssignedAsPotentialOwner("mary", new QueryFilter()); assertEquals(0, maryTasks.size()); // now wait for 2 seconds for first reassignment Thread.sleep(3000); krisTasks = runtimeDataService.getTasksAssignedAsPotentialOwner("krisv", new QueryFilter()); assertEquals(0, krisTasks.size()); johnTasks = runtimeDataService.getTasksAssignedAsPotentialOwner("john", new QueryFilter()); assertEquals(1, johnTasks.size()); maryTasks = runtimeDataService.getTasksAssignedAsPotentialOwner("mary", new QueryFilter()); assertEquals(0, maryTasks.size()); userTaskService.start(johnTasks.get(0).getId(), "john"); // now wait for 2 more seconds for second reassignment Thread.sleep(2000); krisTasks = runtimeDataService.getTasksAssignedAsPotentialOwner("krisv", new QueryFilter()); assertEquals(0, krisTasks.size()); johnTasks = runtimeDataService.getTasksAssignedAsPotentialOwner("john", new QueryFilter()); assertEquals(1, johnTasks.size()); maryTasks = runtimeDataService.getTasksAssignedAsPotentialOwner("mary", new QueryFilter()); assertEquals(0, maryTasks.size()); // now wait for 1 seconds to make sure that reassignment did not happen any more since task was already started Thread.sleep(3000); krisTasks = runtimeDataService.getTasksAssignedAsPotentialOwner("krisv", new QueryFilter()); assertEquals(0, krisTasks.size()); johnTasks = runtimeDataService.getTasksAssignedAsPotentialOwner("john", new QueryFilter()); assertEquals(0, johnTasks.size()); maryTasks = runtimeDataService.getTasksAssignedAsPotentialOwner("mary", new QueryFilter()); assertEquals(1, maryTasks.size()); userTaskService.start(maryTasks.get(0).getId(), "mary"); userTaskService.complete(maryTasks.get(0).getId(), "mary", null); // now wait for 2 seconds to make sure that reassignment did not happen any more since task was completed Thread.sleep(2000); ProcessInstance processInstance = processService.getProcessInstance(processInstanceId); assertNull(processInstance); processInstanceId = null; } }