Diagram is not generated when using expression in CallActivity
Options
- Mark as New
- Bookmark
- Subscribe
- Mute
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
04-16-2015 12:14 PM
Hi,
I created a simple working process with a CallActivity at the end. See the workflow below :
[img][/img]
Depending of the router task (Businnes Rule task) return value, I execute a specific process. This process is defined at the runtime, so the CallActivity calledElement contains an expression like this :
When I deploy my process into Activiti, the diagram is not generated. See below :
[img]http://s3.kkloud.com.s3.amazonaws.com/gett/1YtSuZE2/process.png.client.x675.png?AWSAccessKeyId=AKIAI...[/img]
The associated stacktrace is :
By browsing the source code, I found that the diagam definition/generator (BaseProcessDefinitionDiagramLayoutResource) is looking for the subprocess called by CallActivity using the ProcessDefinitionKey :
But the ProcessDefinitionKey is not defined on the CallActivity when processDefinitionExpression is setted (An expression is passed into the calledElement field).
How can we generate a diagram :
I created a simple working process with a CallActivity at the end. See the workflow below :
[img][/img]
Depending of the router task (Businnes Rule task) return value, I execute a specific process. This process is defined at the runtime, so the CallActivity calledElement contains an expression like this :
<callActivity id="callActivity" name="Call Activity" calledElement="${execution.getVariable('result').get(0).get('processKey')}">
When I deploy my process into Activiti, the diagram is not generated. See below :
[img]http://s3.kkloud.com.s3.amazonaws.com/gett/1YtSuZE2/process.png.client.x675.png?AWSAccessKeyId=AKIAI...[/img]
The associated stacktrace is :
SEVERE: Servlet.service() for servlet [dispatcher] in context with path [/activiti-explorer] threw exception [Request processing failed; nested exception is org.activiti.engine.ActivitiIllegalArgumentException: key is null] with root causeorg.activiti.engine.ActivitiIllegalArgumentException: key is null at org.activiti.engine.impl.ProcessDefinitionQueryImpl.processDefinitionKey(ProcessDefinitionQueryImpl.java:129) at org.activiti.engine.impl.ProcessDefinitionQueryImpl.processDefinitionKey(ProcessDefinitionQueryImpl.java:36) at org.activiti.rest.diagram.services.BaseProcessDefinitionDiagramLayoutResource.getActivity(BaseProcessDefinitionDiagramLayoutResource.java:441) at org.activiti.rest.diagram.services.BaseProcessDefinitionDiagramLayoutResource.getDiagramNode(BaseProcessDefinitionDiagramLayoutResource.java:211) at org.activiti.rest.diagram.services.ProcessDefinitionDiagramLayoutResource.getDiagram(ProcessDefinitionDiagramLayoutResource.java:28) at sun.reflect.GeneratedMethodAccessor121.invoke(Unknown Source) at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) at java.lang.reflect.Method.invoke(Method.java:606) at org.springframework.web.method.support.InvocableHandlerMethod.invoke(InvocableHandlerMethod.java:215) at org.springframework.web.method.support.InvocableHandlerMethod.invokeForRequest(InvocableHandlerMethod.java:132) at org.springframework.web.servlet.mvc.method.annotation.ServletInvocableHandlerMethod.invokeAndHandle(ServletInvocableHandlerMethod.java:104) at org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter.invokeHandleMethod(RequestMappingHandlerAdapter.java:749) at org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter.handleInternal(RequestMappingHandlerAdapter.java:689) at org.springframework.web.servlet.mvc.method.AbstractHandlerMethodAdapter.handle(AbstractHandlerMethodAdapter.java:83) at org.springframework.web.servlet.DispatcherServlet.doDispatch(DispatcherServlet.java:938) at org.springframework.web.servlet.DispatcherServlet.doService(DispatcherServlet.java:870) at org.springframework.web.servlet.FrameworkServlet.processRequest(FrameworkServlet.java:961) at org.springframework.web.servlet.FrameworkServlet.doGet(FrameworkServlet.java:852) at javax.servlet.http.HttpServlet.service(HttpServlet.java:620) at org.springframework.web.servlet.FrameworkServlet.service(FrameworkServlet.java:837) at javax.servlet.http.HttpServlet.service(HttpServlet.java:727) at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:303) at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:208) at org.apache.tomcat.websocket.server.WsFilter.doFilter(WsFilter.java:52) at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:241) at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:208) at org.activiti.explorer.servlet.JsonpCallbackFilter.doFilter(JsonpCallbackFilter.java:40) at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:241) at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:208) at org.activiti.explorer.filter.ExplorerFilter.doFilter(ExplorerFilter.java:42) at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:241) at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:208) at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:220) at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:122) at org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:504) at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:170) at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:103) at org.apache.catalina.valves.AccessLogValve.invoke(AccessLogValve.java:950) at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:116) at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:421) at org.apache.coyote.http11.AbstractHttp11Processor.process(AbstractHttp11Processor.java:1074) at org.apache.coyote.AbstractProtocol$AbstractConnectionHandler.process(AbstractProtocol.java:611) at org.apache.tomcat.util.net.JIoEndpoint$SocketProcessor.run(JIoEndpoint.java:316) at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1145) at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:615) at org.apache.tomcat.util.threads.TaskThread$WrappingRunnable.run(TaskThread.java:61) at java.lang.Thread.run(Thread.java:745)
By browsing the source code, I found that the diagam definition/generator (BaseProcessDefinitionDiagramLayoutResource) is looking for the subprocess called by CallActivity using the ProcessDefinitionKey :
// Get last definition by key ProcessDefinition lastProcessDefinition = repositoryService .createProcessDefinitionQuery() .processDefinitionKey(callActivityBehavior.getProcessDefinitonKey()) .latestVersion().singleResult();
But the ProcessDefinitionKey is not defined on the CallActivity when processDefinitionExpression is setted (An expression is passed into the calledElement field).
How can we generate a diagram :
- For the "Deployed process definitions" view. When the process is not yet executed?
- For the "My instances" view. When a process has been started?
Labels:
- Labels:
-
Archive
2 REPLIES 2
Options
- Mark as New
- Bookmark
- Subscribe
- Mute
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
04-17-2015 02:33 AM
Hi Yohann,
I would say you have found
- an issue,
- the cause
(next step could be to create pull request. 🙂 )
Regards
Martin
I would say you have found
- an issue,
- the cause
(next step could be to create pull request. 🙂 )
Regards
Martin
Options
- Mark as New
- Bookmark
- Subscribe
- Mute
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
04-17-2015 08:54 AM
https://jira.codehaus.org/browse/ACT-2244 opened w/ a proposed fix solution