[jboss-user] [JBoss jBPM] - NullPointerException after signal token in Process State wit

kirq4e do-not-reply at jboss.com
Sat Jan 10 09:54:19 EST 2009


Hi guys,

Recently me and my colleague started learning jBPM for our new project. I have started creating some processes to learn its capabilities.
We have developed a simple Parent-Children scenario.

The parent process is:
<?xml version="1.0" encoding="UTF-8"?>
  | <process-definition  xmlns=""  name="ParentProcess">
  | 	<start-state name="start">
  | 		<transition to="SetInputVariable" name="toSetInputVariable"></transition>
  | 	</start-state>
  | 
  | 	<process-state name="InvokeChildProcess">
  | 		<sub-process name="ChildProcess" binding="late"></sub-process>
  | 		<variable access="read" name="parentKey"></variable>
  | 		<variable access="read,write" name="lastVisitedProcess"></variable>
  | 		<transition to="PrintVariables" name="toPrintVariables"></transition>
  | 	</process-state>
  | 
  | 	<node name="SetInputVariable">
  | 		<action class="com.sirma.ecs2.test.subprocess.actions.SetInputVariables"></action>
  | 		<transition to="InvokeChildProcess" name="toInvokeChildProcess"></transition>
  | 	</node>
  | 
  | 	<node name="PrintVariables">
  | 		<action class="com.sirma.ecs2.test.subprocess.actions.PrintVariables"></action>
  | 		<transition to="end" name="toEnd"></transition>
  | 	</node>
  | 	<end-state name="end"></end-state>
  | </process-definition>

The child process is:
<?xml version="1.0" encoding="UTF-8"?>
  | <process-definition  xmlns=""  name="ChildProcess">
  | 	<start-state name="start">
  | 		<transition to="Reset Variables" name="toResetVariables"></transition>
  | 	</start-state>
  | 
  | 	<node name="Reset Variables">
  | 		<action name="Reset Variables" class="com.sirma.ecs2.test.subprocess.actions.ResetVariables"></action>
  | 		<transition to="WaitSignal" name="toWaitSignal"></transition>
  | 	</node>
  | 
  | 	<state name="WaitSignal">
  | 		<transition to="end" name="toEnd">
  | 			<action class="com.sirma.ecs2.test.subprocess.actions.ExitWait"></action>
  | 		</transition>
  | 	</state>
  | 	<end-state name="end"></end-state>
  | </process-definition>

I start a Parent process and signal it the Token stops at the child`s State node: WaitSignal. 
The Root token of the parent node is in InvokeChildProcess. The ActionHandlers are very simple just print a message and work with some variables.

If i try to signal the Parent process`s root node i got a NullPointerException:
Caused by: java.lang.NullPointerException
  | 	at org.jbpm.graph.node.ProcessState.leave(ProcessState.java:186)
  | 	at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
  | 	at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39)
  | 	at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)
  | 	at java.lang.reflect.Method.invoke(Method.java:585)
  | 	at org.hibernate.proxy.pojo.javassist.JavassistLazyInitializer.invoke(JavassistLazyInitializer.java:173)
  | 	at org.jbpm.graph.def.Node_$$_javassist_49.leave(Node_$$_javassist_49.java)
  | 	at org.jbpm.graph.exe.Token.signal(Token.java:192)
  | 	at org.jbpm.graph.exe.Token.signal(Token.java:140)
  | 	at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
  | 	at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39)
  | 	at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)
  | 	at java.lang.reflect.Method.invoke(Method.java:585)
  | 	at org.hibernate.proxy.pojo.javassist.JavassistLazyInitializer.invoke(JavassistLazyInitializer.java:173)
  | 	at org.jbpm.graph.exe.Token_$$_javassist_64.signal(Token_$$_javassist_64.java)
  | 	at com.kpenev.test.TestBean.signalToken(Unknown Source)
  | 

Probably the right token that i have to signal is the token of the subprocess, but i don`t think that such an exception should occur. 

The code that i execute is:
JbpmContext jbpmContext = JbpmConfiguration.getInstance()
  | 				.createJbpmContext();
  | 		try {
  | 			ProcessInstance instance = jbpmContext.getGraphSession()
  | 					.loadProcessInstance(instanceID);
  | 			instance.getRootToken().signal();
  | 		} finally {
  | 			jbpmContext.close();
  | 		}

The code that really works is:
JbpmContext jbpmContext = JbpmConfiguration.getInstance()
  | 				.createJbpmContext();
  | 		try {
  | 			ProcessInstance instance = jbpmContext.getGraphSession()
  | 					.loadProcessInstance(instanceID);
  | 			instance.getRootToken().getSubProcessInstance().getRootToken()
  | 					.signal();
  | 		} finally {
  | 			jbpmContext.close();
  | 		}

I`m using jbpm-3.3.0.GA version and jboss-4.2.3.GA.

I debuged it and the subProcessInstance variable at ExecutionContext isn`t set.

Hope there is a solution for this, because in the near future i have to develop a very complex processes including subprocesses.

View the original post : http://www.jboss.com/index.html?module=bb&op=viewtopic&p=4200781#4200781

Reply to the post : http://www.jboss.com/index.html?module=bb&op=posting&mode=reply&p=4200781



More information about the jboss-user mailing list