<!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="https://community.jboss.org/index.jspa" style="text-decoration: none; color: #E1E1E1">JBoss 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;">
Iusse of human task persistence - Transaction not active
</h3>
<span style="margin-bottom: 10px;">
created by <a href="https://community.jboss.org/people/patternman">Adam Peng</a> in <i>jBPM</i> - <a href="https://community.jboss.org/message/747072#747072">View the full discussion</a>
</span>
<hr style="margin: 20px 0; border: none; background-color: #dadada; height: 1px;">
<div class="jive-rendered-content"><p>Hi all,</p><p style="min-height: 8pt; height: 8pt; padding: 0px;"> </p><p>        I encoutnered issue when I was executing process including Human Tasks (on the other hand without human task the persistence was working fine!)</p><p style="min-height: 8pt; height: 8pt; padding: 0px;"> </p><p>        The error message is as below:</p><p>          </p><pre class="jive-pre"><code class="jive-code jive-java">Hibernate: insert into ProcessInstanceInfo (OPTLOCK, processId, startDate, lastReadDate, lastModificationDate, state, processInstanceByteArray) values (?, ?, ?, ?, ?, ?, ?)
Hibernate: insert into WorkItemInfo (creationDate, name, processInstanceId, state, OPTLOCK, workItemByteArray) values (?, ?, ?, ?, ?, ?)
Hibernate: insert into Task (archived, allowedToDelegate, taskInitiator_id, priority, activationTime, actualOwner_id, createdBy_id, createdOn, documentAccessType, documentContentId, documentType, expirationTime, faultAccessType, faultContentId, faultName, faultType, outputAccessType, outputContentId, outputType, parentId, previousStatus, processId, processInstanceId, processSessionId, skipable, status, workItemId, OPTLOCK) values (?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?)
Hibernate: insert into I18NText (language, text) values (?, ?)
Hibernate: insert into I18NText (language, text) values (?, ?)
Hibernate: update SessionInfo set lastModificationDate=?, rulesByteArray=?, startDate=?, OPTLOCK=? where id=? and OPTLOCK=?
Hibernate: insert into Content (content) values (?)
Hibernate: update ProcessInstanceInfo set OPTLOCK=?, processId=?, startDate=?, lastReadDate=?, lastModificationDate=?, state=?, processInstanceByteArray=? where InstanceId=? and OPTLOCK=?
Hibernate: update Task set archived=?, allowedToDelegate=?, taskInitiator_id=?, priority=?, activationTime=?, actualOwner_id=?, createdBy_id=?, createdOn=?, documentAccessType=?, documentContentId=?, documentType=?, expirationTime=?, faultAccessType=?, faultContentId=?, faultName=?, faultType=?, outputAccessType=?, outputContentId=?, outputType=?, parentId=?, previousStatus=?, processId=?, processInstanceId=?, processSessionId=?, skipable=?, status=?, workItemId=?, OPTLOCK=? where id=? and OPTLOCK=?
Hibernate: update I18NText set Task_Descriptions_Id=? where id=?
Hibernate: insert into PeopleAssignments_BAs (task_id, entity_id) values (?, ?)
Hibernate: update WorkItemInfo set creationDate=?, name=?, processInstanceId=?, state=?, OPTLOCK=?, workItemByteArray=? where workItemId=? and OPTLOCK=?
Hibernate: insert into PeopleAssignments_PotOwners (task_id, entity_id) values (?, ?)
java.lang.RuntimeException: Could not commit transaction
at org.jbpm.task.service.TaskServiceSession.doOperationInTransaction(TaskServiceSession.java:994)
at org.jbpm.task.service.TaskServiceSession.addTask(TaskServiceSession.java:186)
at org.jbpm.task.service.TaskServerHandler.messageReceived(TaskServerHandler.java:144)
at org.jbpm.task.service.mina.MinaTaskServerHandler.messageReceived(MinaTaskServerHandler.java:41)
at org.apache.mina.core.filterchain.DefaultIoFilterChain$TailFilter.messageReceived(DefaultIoFilterChain.java:716)
at org.apache.mina.core.filterchain.DefaultIoFilterChain.callNextMessageReceived(DefaultIoFilterChain.java:434)
at org.apache.mina.core.filterchain.DefaultIoFilterChain.access$1200(DefaultIoFilterChain.java:46)
at org.apache.mina.core.filterchain.DefaultIoFilterChain$EntryImpl$1.messageReceived(DefaultIoFilterChain.java:796)
at org.apache.mina.filter.codec.ProtocolCodecFilter$ProtocolDecoderOutputImpl.flush(ProtocolCodecFilter.java:427)
at org.apache.mina.filter.codec.ProtocolCodecFilter.messageReceived(ProtocolCodecFilter.java:245)
at org.apache.mina.core.filterchain.DefaultIoFilterChain.callNextMessageReceived(DefaultIoFilterChain.java:434)
at org.apache.mina.core.filterchain.DefaultIoFilterChain.access$1200(DefaultIoFilterChain.java:46)
at org.apache.mina.core.filterchain.DefaultIoFilterChain$EntryImpl$1.messageReceived(DefaultIoFilterChain.java:796)
at org.apache.mina.filter.logging.LoggingFilter.messageReceived(LoggingFilter.java:177)
at org.apache.mina.core.filterchain.DefaultIoFilterChain.callNextMessageReceived(DefaultIoFilterChain.java:434)
at org.apache.mina.core.filterchain.DefaultIoFilterChain.access$1200(DefaultIoFilterChain.java:46)
at org.apache.mina.core.filterchain.DefaultIoFilterChain$EntryImpl$1.messageReceived(DefaultIoFilterChain.java:796)
at org.apache.mina.core.filterchain.IoFilterAdapter.messageReceived(IoFilterAdapter.java:119)
at org.apache.mina.core.filterchain.DefaultIoFilterChain.callNextMessageReceived(DefaultIoFilterChain.java:434)
at org.apache.mina.core.filterchain.DefaultIoFilterChain.fireMessageReceived(DefaultIoFilterChain.java:426)
at org.apache.mina.core.polling.AbstractPollingIoProcessor.read(AbstractPollingIoProcessor.java:715)
at org.apache.mina.core.polling.AbstractPollingIoProcessor.process(AbstractPollingIoProcessor.java:668)
at org.apache.mina.core.polling.AbstractPollingIoProcessor.process(AbstractPollingIoProcessor.java:657)
at org.apache.mina.core.polling.AbstractPollingIoProcessor.access$600(AbstractPollingIoProcessor.java:68)
at org.apache.mina.core.polling.AbstractPollingIoProcessor$Processor.run(AbstractPollingIoProcessor.java:1141)
at org.apache.mina.util.NamePreservingRunnable.run(NamePreservingRunnable.java:64)
at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1110)
at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:603)
at java.lang.Thread.run(Thread.java:722)
Caused by: java.lang.RuntimeException: Unable to rollback transaction
at org.jbpm.task.service.persistence.TaskLocalTransactionManager.rollback(TaskLocalTransactionManager.java:77)
at org.jbpm.task.service.persistence.TaskPersistenceManager.endTransaction(TaskPersistenceManager.java:89)
at org.jbpm.task.service.TaskServiceSession.doOperationInTransaction(TaskServiceSession.java:982)
... 28 more
Caused by: java.lang.IllegalStateException: Transaction not active
at org.hibernate.ejb.TransactionImpl.rollback(TransactionImpl.java:104)
at org.jbpm.task.service.persistence.TaskLocalTransactionManager.rollback(TaskLocalTransactionManager.java:70)
... 30 more
 
</code></pre><p style="min-height: 8pt; height: 8pt; padding: 0px;"> </p><p><p>Start task server</p><p style="min-height: 8pt; height: 8pt; padding: 0px;"> </p>:</p><p style="min-height: 8pt; height: 8pt; padding: 0px;"> </p><pre class="jive-pre"><code class="jive-code jive-java">  EntityManagerFactory emf = (EntityManagerFactory) applicationContext.getBean(<font color="red">"emf"</font>);
<font color="darkgreen">//  EntityManagerFactory emf = Persistence.createEntityManagerFactory("org.jbpm.persistence.jpa.task.local");</font>
  TaskService taskService = <font color="navy"><b>new</b></font> TaskService(emf,SystemEventListenerFactory.getSystemEventListener());
  TaskServiceSession taskSession = taskService.createSession();
  taskSession.addUser(<font color="navy"><b>new</b></font> User(<font color="red">"Administrator"</font>));
  MinaTaskServer server = <font color="navy"><b>new</b></font> MinaTaskServer(taskService);
  Thread thread = <font color="navy"><b>new</b></font> Thread(server);
  thread.start();
  log.info(<font color="red">"Mina Server has started."</font>);
  taskSession.dispose();
</code></pre><p style="min-height: 8pt; height: 8pt; padding: 0px;"> </p><p><p>p</p><p style="min-height: 8pt; height: 8pt; padding: 0px;"> </p>ersistence.xml</p><p style="min-height: 8pt; height: 8pt; padding: 0px;"> </p><pre class="jive-pre"><code class="jive-code jive-xml"><span class="jive-xml-tag"><persistence-unit name="org.jbpm.persistence.jpa.local" transaction-type="RESOURCE_LOCAL"></span>
    <span class="jive-xml-tag"><provider></span>org.hibernate.ejb.HibernatePersistence<span class="jive-xml-tag"></provider></span>
   
    <span class="jive-xml-tag"><mapping-file></span>META-INF/JBPMorm.xml<span class="jive-xml-tag"></mapping-file></span>
    <span class="jive-xml-tag"><mapping-file></span>META-INF/ProcessInstanceInfo.hbm.xml<span class="jive-xml-tag"></mapping-file></span>
<span class="jive-xml-tag"><mapping-file></span>META-INF/Taskorm.xml<span class="jive-xml-tag"></mapping-file></span>
  <span class="jive-xml-tag"><class></span>org.jbpm.task.Attachment<span class="jive-xml-tag"></class></span>
  <span class="jive-xml-tag"><class></span>org.jbpm.task.Content<span class="jive-xml-tag"></class></span>
  <span class="jive-xml-tag"><class></span>org.jbpm.task.BooleanExpression<span class="jive-xml-tag"></class></span>
  <span class="jive-xml-tag"><class></span>org.jbpm.task.Comment<span class="jive-xml-tag"></class></span>
  <span class="jive-xml-tag"><class></span>org.jbpm.task.Deadline<span class="jive-xml-tag"></class></span>
  <span class="jive-xml-tag"><class></span>org.jbpm.task.Comment<span class="jive-xml-tag"></class></span>
  <span class="jive-xml-tag"><class></span>org.jbpm.task.Deadline<span class="jive-xml-tag"></class></span>
  <span class="jive-xml-tag"><class></span>org.jbpm.task.Delegation<span class="jive-xml-tag"></class></span>
  <span class="jive-xml-tag"><class></span>org.jbpm.task.Escalation<span class="jive-xml-tag"></class></span>
  <span class="jive-xml-tag"><class></span>org.jbpm.task.Group<span class="jive-xml-tag"></class></span>
  <span class="jive-xml-tag"><class></span>org.jbpm.task.I18NText<span class="jive-xml-tag"></class></span>
  <span class="jive-xml-tag"><class></span>org.jbpm.task.Notification<span class="jive-xml-tag"></class></span>
  <span class="jive-xml-tag"><class></span>org.jbpm.task.EmailNotification<span class="jive-xml-tag"></class></span>
  <span class="jive-xml-tag"><class></span>org.jbpm.task.EmailNotificationHeader<span class="jive-xml-tag"></class></span>
  <span class="jive-xml-tag"><class></span>org.jbpm.task.PeopleAssignments<span class="jive-xml-tag"></class></span>
  <span class="jive-xml-tag"><class></span>org.jbpm.task.Reassignment<span class="jive-xml-tag"></class></span>
  <span class="jive-xml-tag"><class></span>org.jbpm.task.Status<span class="jive-xml-tag"></class></span>
  <span class="jive-xml-tag"><class></span>org.jbpm.task.Task<span class="jive-xml-tag"></class></span>
  <span class="jive-xml-tag"><class></span>org.jbpm.task.TaskData<span class="jive-xml-tag"></class></span>
  <span class="jive-xml-tag"><class></span>org.jbpm.task.SubTasksStrategy<span class="jive-xml-tag"></class></span>
  <span class="jive-xml-tag"><class></span>org.jbpm.task.OnParentAbortAllSubTasksEndStrategy<span class="jive-xml-tag"></class></span>
  <span class="jive-xml-tag"><class></span>org.jbpm.task.OnAllSubTasksEndParentEndStrategy<span class="jive-xml-tag"></class></span>
  <span class="jive-xml-tag"><class></span>org.jbpm.task.User<span class="jive-xml-tag"></class></span>
    <span class="jive-xml-tag"><class></span>org.jbpm.persistence.processinstance.ProcessInstanceInfo<span class="jive-xml-tag"></class></span>
    <span class="jive-xml-tag"><class></span>org.drools.persistence.info.SessionInfo<span class="jive-xml-tag"></class></span>
    <span class="jive-xml-tag"><class></span>org.drools.persistence.info.WorkItemInfo<span class="jive-xml-tag"></class></span>
    <span class="jive-xml-tag"><class></span>org.jbpm.process.audit.ProcessInstanceLog<span class="jive-xml-tag"></class></span>
    <span class="jive-xml-tag"><class></span>org.jbpm.process.audit.NodeInstanceLog<span class="jive-xml-tag"></class></span>
    <span class="jive-xml-tag"><class></span>org.jbpm.process.audit.VariableInstanceLog<span class="jive-xml-tag"></class></span>
    <span class="jive-xml-tag"><properties></span>
      <span class="jive-xml-tag"><property name="hibernate.dialect" value="org.hibernate.dialect.SQLServerDialect"/></span>
      <span class="jive-xml-tag"><property name="hibernate.connection.autocommit" value="false" /></span>
      <span class="jive-xml-tag"><property name="hibernate.max_fetch_depth" value="3"/></span>
      <span class="jive-xml-tag"><property name="hibernate.archive.autodetection" value="false"/></span>
      <span class="jive-xml-tag"><property name="hibernate.hbm2ddl.auto" value="update" /></span>
      <span class="jive-xml-tag"><property name="hibernate.show_sql" value="true" /></span>
        <span class="jive-xml-tag"><property name="hibernate.transaction.manager_lookup_class" value="org.hibernate.transaction.BTMTransactionManagerLookup" /></span>
    <span class="jive-xml-tag"></properties></span>       
  <span class="jive-xml-tag"></persistence-unit></span>
</code></pre><p style="min-height: 8pt; height: 8pt; padding: 0px;"> </p><p style="min-height: 8pt; height: 8pt; padding: 0px;"> </p><p>applicationContext-jbpm.xml</p><p style="min-height: 8pt; height: 8pt; padding: 0px;"> </p><pre class="jive-pre"><code class="jive-code jive-xml"><span class="jive-xml-tag"><?xml version="1.0" encoding="UTF-8"?></span>
<span class="jive-xml-tag"><span><beans xmlns="</span><a class="jive-link-external-small" href="http://www.springframework.org/schema/beans" target="_blank">http://www.springframework.org/schema/beans</a><span>" xmlns:xsi="</span><a class="jive-link-external-small" href="http://www.w3.org/2001/XMLSchema-instance" target="_blank">http://www.w3.org/2001/XMLSchema-instance</a><span>" xmlns:drools="</span><a class="jive-link-external-small" href="http://drools.org/schema/drools-spring" target="_blank">http://drools.org/schema/drools-spring</a><span>" xsi:schemaLocation="</span><a class="jive-link-external-small" href="http://www.springframework.org/schema/beans" target="_blank">http://www.springframework.org/schema/beans</a><span> </span><a class="jive-link-external-small" href="http://www.springframework.org/schema/beans/spring-beans-2.0.xsd" target="_blank">http://www.springframework.org/schema/beans/spring-beans-2.0.xsd</a><span> </span><a class="jive-link-external-small" href="http://drools.org/schema/drools-spring" target="_blank">http://drools.org/schema/drools-spring</a><span> </span><a class="jive-link-external-small" href="http://drools.org/schema/drools-spring-1.3.0.xsd" target="_blank">http://drools.org/schema/drools-spring-1.3.0.xsd</a><span>"></span></span>
<span class="jive-xml-tag"><bean id="jbpmDS" class="org.springframework.jdbc.datasource.DriverManagerDataSource"></span>
  <span class="jive-xml-tag"><property name="driverClassName" value="com.microsoft.sqlserver.jdbc.SQLServerDriver"/></span>
  <span class="jive-xml-tag"><property name="url" value="${productDB.jbpm.url}"/></span>
  <span class="jive-xml-tag"><property name="username" value="${productDB.username}"/></span>
  <span class="jive-xml-tag"><property name="password" value="${productDB.password}"/></span>
<span class="jive-xml-tag"></bean></span>
<span class="jive-xml-tag"><bean id="emf" class="org.springframework.orm.jpa.LocalContainerEntityManagerFactoryBean"></span>
  <span class="jive-xml-tag"><property name="dataSource" ref="jbpmDS" /></span>
  <span class="jive-xml-tag"><property name="persistenceUnitName" value="org.jbpm.persistence.jpa.local" /></span>
<span class="jive-xml-tag"></bean></span>
<span class="jive-xml-tag"><bean id="txManager" class="org.springframework.orm.jpa.JpaTransactionManager"></span>
  <span class="jive-xml-tag"><property name="entityManagerFactory" ref="emf" /></span>
<span class="jive-xml-tag"></bean></span>
<span class="jive-xml-tag"><drools:grid-node id="node1" /></span>
<span class="jive-xml-tag"><drools:kbase id="kbase1" node="node1"></span>
  <span class="jive-xml-tag"><drools:resources></span>
   <span class="jive-xml-tag"><drools:resource type="BPMN2" source="classpath:processes/test.bpmn" /></span>
   <span class="jive-xml-tag"></drools:resources></span>
<span class="jive-xml-tag"></drools:kbase></span>
<span class="jive-xml-tag"><drools:ksession id="ksession1" type="stateful" kbase="kbase1" node="node1"></span>
  <span class="jive-xml-tag"><drools:configuration></span>
   <span class="jive-xml-tag"><drools:jpa-persistence></span>
    <span class="jive-xml-tag"><drools:transaction-manager ref="txManager" /></span>
    <span class="jive-xml-tag"><drools:entity-manager-factory ref="emf" /></span>
   <span class="jive-xml-tag"></drools:jpa-persistence></span>
  <span class="jive-xml-tag"></drools:configuration></span>
<span class="jive-xml-tag"></drools:ksession></span>
<span class="jive-xml-tag"><bean id="testService" class="testServiceImpl"></span>
  <span class="jive-xml-tag"><property name="ksession" ref="ksession1" /></span>
  <span class="jive-xml-tag"><property name="processId" value="test" /></span>
<span class="jive-xml-tag"></bean></span>
<span class="jive-xml-tag"></beans></span>
</code></pre><p style="min-height: 8pt; height: 8pt; padding: 0px;"> </p><p style="min-height: 8pt; height: 8pt; padding: 0px;"> </p><p>And then when I use ksession1 to startProcess, I got above error message. And it's ok to start a process without human task.</p><p style="min-height: 8pt; height: 8pt; padding: 0px;"> </p><p>Any hints/suggestion would be appreciated !!</p><p style="min-height: 8pt; height: 8pt; padding: 0px;"> </p><p>BTW I'm using jBPM 5.3.</p></div>
<div style="background-color: #f4f4f4; padding: 10px; margin-top: 20px;">
<p style="margin: 0;">Reply to this message by <a href="https://community.jboss.org/message/747072#747072">going to Community</a></p>
        <p style="margin: 0;">Start a new discussion in jBPM at <a href="https://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>