<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN">
<html>
<body link="#355491" alink="#4262a1" vlink="#355491" style="background: #e2e2e2; margin: 0; padding: 20px;">

<div>
        <table cellpadding="0" bgcolor="#FFFFFF" border="0" cellspacing="0" style="border: 1px solid #dadada; margin-bottom: 30px; width: 100%; -moz-border-radius: 6px; -webkit-border-radius: 6px;">
                <tbody>
                        <tr>

                                <td>

                                        <table border="0" cellpadding="0" cellspacing="0" bgcolor="#FFFFFF" style="border: solid 2px #ccc; background: #dadada; width: 100%; -moz-border-radius: 6px; -webkit-border-radius: 6px;">
                                                <tbody>
                                                        <tr>
                                                                <td bgcolor="#000000" valign="middle" height="58px" style="border-bottom: 1px solid #ccc; padding: 20px; -moz-border-radius-topleft: 3px; -moz-border-radius-topright: 3px; -webkit-border-top-right-radius: 5px; -webkit-border-top-left-radius: 5px;">
                                                                        <h1 style="color: #333333; font: bold 22px Arial, Helvetica, sans-serif; margin: 0; display: block !important;">
                                                                        <!-- To have a header image/logo replace the name below with your img tag -->
                                                                        <!-- Email clients will render the images when the message is read so any image -->
                                                                        <!-- must be made available on a public server, so that all recipients can load the image. -->
                                                                        <a href="http://community.jboss.org/index.jspa" style="text-decoration: none; color: #E1E1E1">Community</a></h1>
                                                                </td>

                                                        </tr>
                                                        <tr>
                                                                <td bgcolor="#FFFFFF" style="font: normal 12px Arial, Helvetica, sans-serif; color:#333333; padding: 20px;  -moz-border-radius-bottomleft: 4px; -moz-border-radius-bottomright: 4px; -webkit-border-bottom-right-radius: 5px; -webkit-border-bottom-left-radius: 5px;"><h3 style="margin: 10px 0 5px; font-size: 17px; font-weight: normal;">
    NullPointerException when timeout transition maps to a Java activity
</h3>
<span style="margin-bottom: 10px;">
    reply from <a href="http://community.jboss.org/people/sameeh.harfoush">Sameeh Harfoush</a> in <i>jBPM</i> - <a href="http://community.jboss.org/message/534833#534833">View the full discussion</a>
</span>
<hr style="margin: 20px 0; border: none; background-color: #dadada; height: 1px;">

<div class="jive-rendered-content"><p>Hello<br/>I tried to eliminate the timer and made the &lt;decision&gt; transition maps to a java activity in order to see if the problem is with the Timer timeout trigger. <br/>After executing the workflow and when the decision handler returns "Approve" the java activity gets executed and throws a NullPointerException (see below). But when I replace the java activity with a &lt;state&gt; the java activity gets executed and no exception is thrown.</p><p style="min-height: 8pt; height: 8pt; padding: 0px;">&#160;</p><p>Below is all the data you asked for.</p><p>Regards</p><p style="min-height: 8pt; height: 8pt; padding: 0px;">&#160;</p><p><strong>Exception:</strong><br/>### EXCEPTION ###########################################<br/>11:26:47,828 INF&#160;&#160; | [DefaultCommandService] exception while executing command org.jbpm.pvm.internal.cmd.CompleteTaskCmd@1f52460<br/>java.lang.NullPointerException<br/>&#160;&#160;&#160; at org.jbpm.pvm.internal.wire.usercode.UserCodeReference.getProcessDefinition(UserCodeReference.java:75)<br/>&#160;&#160;&#160; at org.jbpm.pvm.internal.wire.usercode.UserCodeReference.getObject(UserCodeReference.java:60)<br/>&#160;&#160;&#160; at org.jbpm.pvm.internal.wire.usercode.UserCodeReference.getObject(UserCodeReference.java:51)<br/>&#160;&#160;&#160; at org.jbpm.pvm.internal.model.ExecutionImpl.initializeAssignments(ExecutionImpl.java:759)<br/>&#160;&#160;&#160; at org.jbpm.jpdl.internal.activity.TaskActivity.execute(TaskActivity.java:95)<br/>&#160;&#160;&#160; at org.jbpm.jpdl.internal.activity.TaskActivity.execute(TaskActivity.java:58)<br/>&#160;&#160;&#160; at org.jbpm.pvm.internal.model.op.ExecuteActivity.perform(ExecuteActivity.java:60)<br/>&#160;&#160;&#160; at org.jbpm.pvm.internal.model.ExecutionImpl.performAtomicOperationSync(ExecutionImpl.java:656)<br/>&#160;&#160;&#160; at org.jbpm.pvm.internal.model.ExecutionImpl.performAtomicOperation(ExecutionImpl.java:616)<br/>&#160;&#160;&#160; at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)<br/>&#160;&#160;&#160; at sun.reflect.NativeMethodAccessorImpl.invoke(Unknown Source)<br/>&#160;&#160;&#160; at sun.reflect.DelegatingMethodAccessorImpl.invoke(Unknown Source)<br/>&#160;&#160;&#160; at java.lang.reflect.Method.invoke(Unknown Source)<br/>&#160;&#160;&#160; at org.hibernate.proxy.pojo.javassist.JavassistLazyInitializer.invoke(JavassistLazyInitializer.java:197)<br/>&#160;&#160;&#160; at org.jbpm.pvm.internal.model.ExecutionImpl_$$_javassist_5.performAtomicOperation(ExecutionImpl_$$_javassist_5.java)<br/>&#160;&#160;&#160; at org.jbpm.pvm.internal.model.op.TransitionEndActivity.perform(TransitionEndActivity.java:58)<br/>&#160;&#160;&#160; at org.jbpm.pvm.internal.model.ExecutionImpl.performAtomicOperationSync(ExecutionImpl.java:656)<br/>&#160;&#160;&#160; at org.jbpm.pvm.internal.model.ExecutionImpl.performAtomicOperation(ExecutionImpl.java:616)<br/>&#160;&#160;&#160; at org.jbpm.pvm.internal.model.ExecutionImpl.signal(ExecutionImpl.java:417)<br/>&#160;&#160;&#160; at org.jbpm.pvm.internal.model.ExecutionImpl.signal(ExecutionImpl.java:403)<br/>&#160;&#160;&#160; at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)<br/>&#160;&#160;&#160; at sun.reflect.NativeMethodAccessorImpl.invoke(Unknown Source)<br/>&#160;&#160;&#160; at sun.reflect.DelegatingMethodAccessorImpl.invoke(Unknown Source)<br/>&#160;&#160;&#160; at java.lang.reflect.Method.invoke(Unknown Source)<br/>&#160;&#160;&#160; at org.hibernate.proxy.pojo.javassist.JavassistLazyInitializer.invoke(JavassistLazyInitializer.java:197)<br/>&#160;&#160;&#160; at org.jbpm.pvm.internal.model.ExecutionImpl_$$_javassist_5.signal(ExecutionImpl_$$_javassist_5.java)<br/>&#160;&#160;&#160; at org.jbpm.pvm.internal.task.TaskImpl.complete(TaskImpl.java:194)<br/>&#160;&#160;&#160; at org.jbpm.pvm.internal.task.TaskImpl.complete(TaskImpl.java:186)<br/>&#160;&#160;&#160; at org.jbpm.pvm.internal.cmd.CompleteTaskCmd.execute(CompleteTaskCmd.java:67)<br/>&#160;&#160;&#160; at org.jbpm.pvm.internal.cmd.CompleteTaskCmd.execute(CompleteTaskCmd.java:32)<br/>&#160;&#160;&#160; at org.jbpm.pvm.internal.svc.DefaultCommandService.execute(DefaultCommandService.java:42)<br/>&#160;&#160;&#160; at org.jbpm.pvm.internal.tx.StandardTransactionInterceptor.execute(StandardTransactionInterceptor.java:54)<br/>&#160;&#160;&#160; at org.jbpm.pvm.internal.svc.EnvironmentInterceptor.executeInNewEnvironment(EnvironmentInterceptor.java:53)<br/>&#160;&#160;&#160; at org.jbpm.pvm.internal.svc.EnvironmentInterceptor.execute(EnvironmentInterceptor.java:40)<br/>&#160;&#160;&#160; at org.jbpm.pvm.internal.svc.RetryInterceptor.execute(RetryInterceptor.java:55)<br/>&#160;&#160;&#160; at org.jbpm.pvm.internal.svc.SkipInterceptor.execute(SkipInterceptor.java:43)<br/>&#160;&#160;&#160; at org.jbpm.pvm.internal.svc.TaskServiceImpl.completeTask(TaskServiceImpl.java:88)<br/>&#160;&#160;&#160; at com.roxana.test.jpdl.EmployeeTimesheetTest.executeTransitionInTask(EmployeeTimesheetTest.java:180)<br/>&#160;&#160;&#160; at com.roxana.test.jpdl.EmployeeTimesheetTest.testManagerApproveTimesheet(EmployeeTimesheetTest.java:135)<br/>&#160;&#160;&#160; at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)<br/>&#160;&#160;&#160; at sun.reflect.NativeMethodAccessorImpl.invoke(Unknown Source)<br/>&#160;&#160;&#160; at sun.reflect.DelegatingMethodAccessorImpl.invoke(Unknown Source)<br/>&#160;&#160;&#160; at java.lang.reflect.Method.invoke(Unknown Source)<br/>&#160;&#160;&#160; at junit.framework.TestCase.runTest(TestCase.java:164)<br/>&#160;&#160;&#160; at org.jbpm.test.BaseJbpmTestCase.runTest(BaseJbpmTestCase.java:80)<br/>&#160;&#160;&#160; at junit.framework.TestCase.runBare(TestCase.java:130)<br/>&#160;&#160;&#160; at junit.framework.TestResult$1.protect(TestResult.java:106)<br/>&#160;&#160;&#160; at junit.framework.TestResult.runProtected(TestResult.java:124)<br/>&#160;&#160;&#160; at junit.framework.TestResult.run(TestResult.java:109)<br/>&#160;&#160;&#160; at junit.framework.TestCase.run(TestCase.java:120)<br/>&#160;&#160;&#160; at junit.framework.TestSuite.runTest(TestSuite.java:230)<br/>&#160;&#160;&#160; at junit.framework.TestSuite.run(TestSuite.java:225)<br/>&#160;&#160;&#160; at org.eclipse.jdt.internal.junit.runner.junit3.JUnit3TestReference.run(JUnit3TestReference.java:130)<br/>&#160;&#160;&#160; at org.eclipse.jdt.internal.junit.runner.TestExecution.run(TestExecution.java:38)<br/>&#160;&#160;&#160; at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.runTests(RemoteTestRunner.java:467)<br/>&#160;&#160;&#160; at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.runTests(RemoteTestRunner.java:683)<br/>&#160;&#160;&#160; at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.run(RemoteTestRunner.java:390)<br/>&#160;&#160;&#160; at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.main(RemoteTestRunner.java:197)<br/>### EXCEPTION ###########################################</p><p style="min-height: 8pt; height: 8pt; padding: 0px;">&#160;</p><p><strong>JPDL:</strong><br/><span>&lt;process name="timesheetWorkflow" xmlns="</span><a class="jive-link-external-small" href="http://jbpm.org/4.3/jpdl" target="_blank">http://jbpm.org/4.3/jpdl</a><span>"&gt;</span><br/>&#160;&#160;&#160; &lt;start g="142,11,48,48" name="start"&gt;<br/>&#160;&#160;&#160;&#160;&#160;&#160;&#160; &lt;transition name="start workflow" g="-153,-18"<br/>&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160; to="Employee submits timesheet" /&gt;<br/>&#160;&#160;&#160; &lt;/start&gt;<br/>&#160;&#160;&#160; &lt;task g="84,85,164,47" name="Employee submits timesheet"&gt;<br/>&#160;&#160;&#160;&#160;&#160;&#160;&#160; &lt;assignment-handler&gt;<br/>&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160; &lt;field name="assignee"&gt;<br/>&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160; &lt;string value="sameeh" /&gt;<br/>&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160; &lt;/field&gt;<br/>&#160;&#160;&#160;&#160;&#160;&#160;&#160; &lt;/assignment-handler&gt;<br/>&#160;&#160;&#160;&#160;&#160;&#160;&#160; &lt;transition name="to group" g="-150,-18" to="manager bookkeeper group" /&gt;<br/>&#160;&#160;&#160; &lt;/task&gt;<br/>&#160;&#160;&#160; &lt;group name="manager bookkeeper group"&gt;<br/>&#160;&#160;&#160;&#160;&#160;&#160;&#160; &lt;start&gt;<br/>&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160; &lt;transition name="to manager" to="Manager reviews timesheet" /&gt;<br/>&#160;&#160;&#160;&#160;&#160;&#160;&#160; &lt;/start&gt;<br/>&#160;&#160;&#160;&#160;&#160;&#160;&#160; &lt;task g="105,159,156,52" name="Manager reviews timesheet"&gt;<br/>&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160; &lt;assignment-handler&gt;<br/>&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160; &lt;field name="assignee"&gt;<br/>&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160; &lt;string value="Mahmoud" /&gt;<br/>&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160; &lt;/field&gt;<br/>&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160; &lt;/assignment-handler&gt;</p><p style="min-height: 8pt; height: 8pt; padding: 0px;">&#160;</p><p>&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160; &lt;!--timeout transition can be to other subprocess --&gt;<br/>&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160; &lt;transition g="433,186;435,673:-43,-16" name="Manager timeout"<br/>&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160; to="Manager review SLA"&gt;<br/>&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160; &lt;timer duedate="12 hours" /&gt;<br/>&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160; &lt;/transition&gt;<br/>&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160; &lt;transition g="-68,-18" to="Manager evaluation" /&gt;<br/>&#160;&#160;&#160;&#160;&#160;&#160;&#160; &lt;/task&gt;</p><p style="min-height: 8pt; height: 8pt; padding: 0px;">&#160;</p><p>&#160;&#160;&#160;&#160;&#160;&#160;&#160; &lt;sub-process name="Manager review SLA" sub-process-key="ManagerReviewSLA"<br/>&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160; g="118,106,99,52"&gt;<br/>&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160; &lt;transition name="to accounts" to="Send timesheet to accounts"&gt;&lt;/transition&gt;<br/>&#160;&#160;&#160;&#160;&#160;&#160;&#160; &lt;/sub-process&gt;</p><p style="min-height: 8pt; height: 8pt; padding: 0px;">&#160;</p><p>&#160;&#160;&#160;&#160;&#160;&#160;&#160; &lt;decision g="159,267,48,48" name="Manager evaluation"&gt;<br/>&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160; &lt;handler /&gt;<br/>&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160; &lt;transition g="-93,-11" name="Approve" to="Send timesheet to accounts" /&gt;<br/>&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160; &lt;transition g="348,292;352,673:-82,-206" name="Reject" to="Employee submits timesheet" /&gt;<br/>&#160;&#160;&#160;&#160;&#160;&#160;&#160; &lt;/decision&gt;<br/>&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160; <br/><strong>&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160; &lt;!--&#160;&#160;&#160;&#160; <br/>&#160;&#160;&#160;&#160;&#160;&#160;&#160; &lt;state name="Send timesheet to accounts"&gt; <br/>&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160; &lt;transition g="-83,-8"&#160;&#160;&#160; to="Bookkeeper reviews and posts timesheet" /&gt;<br/>&#160;&#160;&#160;&#160;&#160;&#160;&#160; &lt;/state&gt;<br/>&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160; --&gt;</strong></p><p><strong><br/></strong></p><p><strong>&#160;&#160;&#160;&#160;&#160;&#160;&#160; &lt;java g="102,356,163,52" class="com.roxana.test.jpdl.TimesheetManager"<br/>&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160; method="manageTimesheet" name="Send timesheet to accounts"&gt;<br/>&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160; &lt;transition g="-83,-8" name="to Bookkeeper"<br/>&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160; to="Bookkeeper reviews and posts timesheet" /&gt;<br/>&#160;&#160;&#160;&#160;&#160;&#160;&#160; &lt;/java&gt;</strong><br/> <br/>&#160;&#160;&#160;&#160;&#160;&#160;&#160; &lt;task g="64,453,240,52" name="Bookkeeper reviews and posts timesheet"&gt;<br/>&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160; &lt;assignment-handler&gt;<br/>&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160; &lt;field name="assignee"&gt;<br/>&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160; &lt;string value="Mr.bookkeeper" /&gt;<br/>&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160; &lt;/field&gt;<br/>&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160; &lt;/assignment-handler&gt;<br/>&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160; &lt;transition name="to group end" g="-125,-3"<br/>&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160; to="manager bookkeeper group end" /&gt;<br/>&#160;&#160;&#160;&#160;&#160;&#160;&#160; &lt;/task&gt;</p><p style="min-height: 8pt; height: 8pt; padding: 0px;">&#160;</p><p>&#160;&#160;&#160;&#160;&#160;&#160;&#160; &lt;end name="manager bookkeeper group end" /&gt;<br/>&#160;&#160;&#160;&#160;&#160;&#160;&#160; &lt;transition to="Accounting department pays employee" /&gt;<br/>&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160; <br/>&#160;&#160;&#160; &lt;/group&gt;<br/>&#160;&#160;&#160; &lt;task g="77,567,219,52" name="Accounting department pays employee"&gt;<br/>&#160;&#160;&#160;&#160;&#160;&#160;&#160; &lt;assignment-handler&gt;<br/>&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160; &lt;field name="assignee"&gt;<br/>&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160; &lt;string value="Mr.accountant" /&gt;<br/>&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160; &lt;/field&gt;<br/>&#160;&#160;&#160;&#160;&#160;&#160;&#160; &lt;/assignment-handler&gt;<br/>&#160;&#160;&#160;&#160;&#160;&#160;&#160; &lt;transition g="-42,-18" name="to end" to="end" /&gt;<br/>&#160;&#160;&#160; &lt;/task&gt;<br/>&#160;&#160;&#160; &lt;end g="167,651,48,48" name="end" /&gt;<br/>&#160;&#160;&#160; &lt;timer duedate="72 hours"&gt;&lt;/timer&gt;<br/>&lt;/process&gt;</p><p style="min-height: 8pt; height: 8pt; padding: 0px;">&#160;</p><p><br/><strong>JUnit</strong><br/>package com.roxana.test.jpdl;</p><p style="min-height: 8pt; height: 8pt; padding: 0px;">&#160;</p><p>import java.util.HashMap;<br/>import java.util.Iterator;<br/>import java.util.List;<br/>import java.util.Map;</p><p style="min-height: 8pt; height: 8pt; padding: 0px;">&#160;</p><p>import org.jbpm.api.Execution;<br/>import org.jbpm.api.JobQuery;<br/>import org.jbpm.api.ProcessInstance;<br/>import org.jbpm.api.TaskQuery;<br/>import org.jbpm.api.job.Job;<br/>import org.jbpm.api.job.Timer;<br/>import org.jbpm.api.task.Task;<br/>import org.jbpm.test.JbpmTestCase;</p><p style="min-height: 8pt; height: 8pt; padding: 0px;">&#160;</p><p>public class EmployeeTimesheetTest extends JbpmTestCase {</p><p style="min-height: 8pt; height: 8pt; padding: 0px;">&#160;</p><p>&#160;&#160;&#160; String deploymentId;<br/>&#160;&#160;&#160; String ManagerSlaDeploymentId;</p><p style="min-height: 8pt; height: 8pt; padding: 0px;">&#160;</p><p>&#160;&#160;&#160; protected void setUp() throws Exception {<br/>&#160;&#160;&#160;&#160;&#160;&#160;&#160; super.setUp();<br/>&#160;&#160;&#160;&#160;&#160;&#160;&#160; deploymentId = repositoryService<br/>&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160; .createDeployment()<br/>&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160; .addResourceFromClasspath(<br/>&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160; "com/roxana/test/jpdl/EmployeeTimesheetWorkflow.jpdl.xml")<br/>&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160; .deploy();</p><p style="min-height: 8pt; height: 8pt; padding: 0px;">&#160;</p><p>&#160;&#160;&#160;&#160;&#160;&#160;&#160; ManagerSlaDeploymentId = repositoryService.createDeployment()<br/>&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160; .addResourceFromClasspath(<br/>&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160; "com/roxana/test/jpdl/ManagerReviewSLA.jpdl.xml")<br/>&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160; .deploy();</p><p style="min-height: 8pt; height: 8pt; padding: 0px;">&#160;</p><p>&#160;&#160;&#160; }</p><p style="min-height: 8pt; height: 8pt; padding: 0px;">&#160;</p><p>&#160;&#160;&#160; protected void tearDown() throws Exception {<br/>&#160;&#160;&#160;&#160;&#160;&#160;&#160; repositoryService.deleteDeploymentCascade(deploymentId);<br/>&#160;&#160;&#160;&#160;&#160;&#160;&#160; repositoryService.deleteDeploymentCascade(ManagerSlaDeploymentId);<br/>&#160;&#160;&#160;&#160;&#160;&#160;&#160; super.tearDown();<br/>&#160;&#160;&#160; }</p><p style="min-height: 8pt; height: 8pt; padding: 0px;">&#160;</p><p>&#160;&#160;&#160; public void testManagerApproveTimesheet() {</p><p style="min-height: 8pt; height: 8pt; padding: 0px;">&#160;</p><p>&#160;&#160;&#160;&#160;&#160;&#160;&#160; Map&lt;String, Object&gt; variableMap = new HashMap();<br/>&#160;&#160;&#160;&#160;&#160;&#160;&#160; // variableMap.put("action", "reject");<br/>&#160;&#160;&#160;&#160;&#160;&#160;&#160; variableMap.put("action", "approve");</p><p style="min-height: 8pt; height: 8pt; padding: 0px;">&#160;</p><p>&#160;&#160;&#160;&#160;&#160;&#160;&#160; ProcessInstance processInstance = executionService<br/>&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160; .startProcessInstanceByKey("timesheetWorkflow", variableMap);</p><p style="min-height: 8pt; height: 8pt; padding: 0px;">&#160;</p><p>&#160;&#160;&#160;&#160;&#160;&#160;&#160; String processInstanceId = processInstance.getId();</p><p style="min-height: 8pt; height: 8pt; padding: 0px;">&#160;</p><p>&#160;&#160;&#160;&#160;&#160;&#160;&#160; executeTransitionInTask(processInstance.getId(),<br/>&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160; "Employee submits timesheet", null);// employee</p><p style="min-height: 8pt; height: 8pt; padding: 0px;">&#160;</p><p>&#160;&#160;&#160;&#160;&#160;&#160;&#160; executeTransitionInTask(processInstance.getId(),<br/>&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160; "Manager reviews timesheet", null);// manager<br/>&#160;&#160;&#160; }</p><p style="min-height: 8pt; height: 8pt; padding: 0px;">&#160;</p><p>&#160;&#160;&#160; private void executeTimerInTask(ProcessInstance pi, String transitionName) {<br/>&#160;&#160;&#160;&#160;&#160;&#160;&#160; List&lt;Job&gt; jobslist = managementService.createJobQuery().timers()<br/>&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160; .processInstanceId(pi.getId()).list();<br/>&#160;&#160;&#160;&#160;&#160;&#160;&#160; Job job2 = null;<br/>&#160;&#160;&#160;&#160;&#160;&#160;&#160; for (Iterator&lt;Job&gt; i = jobslist.iterator(); i.hasNext();) {<br/>&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160; job2 = i.next();<br/>&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160; // System.out.println("****"+((Timer)job2).getSignalName());<br/>&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160; if (((Timer) job2).getSignalName().trim().equals(transitionName))<br/>&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160; managementService.executeJob(job2.getId());<br/>&#160;&#160;&#160;&#160;&#160;&#160;&#160; }<br/>&#160;&#160;&#160; }</p><p style="min-height: 8pt; height: 8pt; padding: 0px;">&#160;</p><p>&#160;&#160;&#160; private void executeTransitionInTask(String piId, String taskName,<br/>&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160; String transitionName) {</p><p style="min-height: 8pt; height: 8pt; padding: 0px;">&#160;</p><p>&#160;&#160;&#160;&#160;&#160;&#160;&#160; ProcessInstance pi = executionService.findProcessInstanceById(piId);</p><p style="min-height: 8pt; height: 8pt; padding: 0px;">&#160;</p><p>&#160;&#160;&#160;&#160;&#160;&#160;&#160; if (transitionName != null) {<br/>&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160; executeTimerInTask(pi, transitionName);<br/>&#160;&#160;&#160;&#160;&#160;&#160;&#160; } else {<br/>&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160; TaskQuery taskQuery = taskService.createTaskQuery();<br/>&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160; List&lt;Task&gt; allTasks = taskQuery.list();<br/>&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160; Task task = null;<br/>&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160; for (Iterator&lt;Task&gt; i = allTasks.iterator(); i.hasNext();) {<br/>&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160; task = i.next();<br/>&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160; if (task.getActivityName().trim().equals(taskName))<br/>&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160; break;<br/>&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160; }<br/>&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160; if (task != null) {<br/>&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160; System.out.println("task.getId() = "<br/>&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160; + taskService.getOutcomes(task.getId()));<br/>&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160; taskService.completeTask(task.getId());<br/>&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160; }</p><p style="min-height: 8pt; height: 8pt; padding: 0px;">&#160;</p><p>&#160;&#160;&#160;&#160;&#160;&#160;&#160; }<br/>&#160;&#160;&#160; }<br/>}</p><p><strong>TimesheetManager.java</strong>:</p><p style="min-height: 8pt; height: 8pt; padding: 0px;">&#160;</p><p>package com.roxana.test.jpdl;</p><p style="min-height: 8pt; height: 8pt; padding: 0px;">&#160;</p><p>import java.io.Serializable;</p><p style="min-height: 8pt; height: 8pt; padding: 0px;">&#160;</p><p>public class TimesheetManager implements Serializable {</p><p style="min-height: 8pt; height: 8pt; padding: 0px;">&#160;</p><p>&#160;&#160;&#160; public void manageTimesheet(){<br/>&#160;&#160;&#160;&#160;&#160;&#160;&#160; System.out.println("timesheet sent to accounting");<br/>&#160;&#160;&#160; }<br/>}</p></div>

<div style="background-color: #f4f4f4; padding: 10px; margin-top: 20px;">
    <p style="margin: 0;">Reply to this message by <a href="http://community.jboss.org/message/534833#534833">going to Community</a></p>
        <p style="margin: 0;">Start a new discussion in jBPM at <a href="http://community.jboss.org/choose-container!input.jspa?contentType=1&containerType=14&container=2034">Community</a></p>
</div></td>
                        </tr>
                    </tbody>
                </table>


                </td>
            </tr>
        </tbody>
    </table>

</div>

</body>
</html>