IDEMPIERE-4319 Cascade workflow activities (completing chained documents) exception problem (#122)
Implemented a better approach: save the first workflow savepoint and rollback to that one in case of cascade activities
This commit is contained in:
parent
36d6644879
commit
2a3224ea46
|
@ -514,6 +514,16 @@ public class Trx
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private Savepoint m_lastWFSavepoint = null;
|
||||||
|
|
||||||
|
public synchronized void setLastWFSavepoint(Savepoint savepoint) {
|
||||||
|
m_lastWFSavepoint = savepoint;
|
||||||
|
}
|
||||||
|
|
||||||
|
public synchronized Savepoint getLastWFSavepoint() {
|
||||||
|
return m_lastWFSavepoint;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Release Savepoint
|
* Release Savepoint
|
||||||
* @param savepoint
|
* @param savepoint
|
||||||
|
|
|
@ -286,7 +286,13 @@ public class MWFActivity extends X_AD_WF_Activity implements Runnable
|
||||||
if (log.isLoggable(Level.FINE)) log.fine(oldState + "->"+ WFState + ", Msg=" + getTextMsg());
|
if (log.isLoggable(Level.FINE)) log.fine(oldState + "->"+ WFState + ", Msg=" + getTextMsg());
|
||||||
super.setWFState (WFState);
|
super.setWFState (WFState);
|
||||||
m_state = new StateEngine (getWFState());
|
m_state = new StateEngine (getWFState());
|
||||||
saveEx(); // closed in MWFProcess.checkActivities()
|
boolean valid = save();
|
||||||
|
if (! valid) {
|
||||||
|
// the activity could not be updated, probably it was deleted by the rollback to savepoint
|
||||||
|
// so, set the ID to zero and save it again (insert)
|
||||||
|
setAD_WF_Activity_ID(0);
|
||||||
|
saveEx();
|
||||||
|
}
|
||||||
updateEventAudit();
|
updateEventAudit();
|
||||||
|
|
||||||
// Inform Process
|
// Inform Process
|
||||||
|
@ -336,7 +342,13 @@ public class MWFActivity extends X_AD_WF_Activity implements Runnable
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
m_audit.setEventType(MWFEventAudit.EVENTTYPE_StateChanged);
|
m_audit.setEventType(MWFEventAudit.EVENTTYPE_StateChanged);
|
||||||
m_audit.saveEx();
|
boolean valid = m_audit.save();
|
||||||
|
if (! valid) {
|
||||||
|
// the event audit could not be updated, probably it was deleted by the rollback to savepoint
|
||||||
|
// so, set the ID to zero and save it again (insert)
|
||||||
|
m_audit.setAD_WF_EventAudit_ID(0);
|
||||||
|
m_audit.saveEx();
|
||||||
|
}
|
||||||
} // updateEventAudit
|
} // updateEventAudit
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -871,8 +883,15 @@ public class MWFActivity extends X_AD_WF_Activity implements Runnable
|
||||||
//
|
//
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
if (!localTrx)
|
if (!localTrx) {
|
||||||
savepoint = trx.setSavepoint(null);
|
// when cascade workflows, avoid setting a savepoint for each workflow
|
||||||
|
// use the same first savepoint from the transaction
|
||||||
|
savepoint = trx.getLastWFSavepoint();
|
||||||
|
if (savepoint == null) {
|
||||||
|
savepoint = trx.setSavepoint(null);
|
||||||
|
trx.setLastWFSavepoint(savepoint);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
if (!m_state.isValidAction(StateEngine.ACTION_Start))
|
if (!m_state.isValidAction(StateEngine.ACTION_Start))
|
||||||
{
|
{
|
||||||
|
@ -925,6 +944,7 @@ public class MWFActivity extends X_AD_WF_Activity implements Runnable
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
trx.rollback(savepoint);
|
trx.rollback(savepoint);
|
||||||
|
trx.setLastWFSavepoint(null);
|
||||||
} catch (SQLException e1) {}
|
} catch (SQLException e1) {}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -973,7 +993,6 @@ public class MWFActivity extends X_AD_WF_Activity implements Runnable
|
||||||
if (contextLost)
|
if (contextLost)
|
||||||
Env.getCtx().remove("#AD_Client_ID");
|
Env.getCtx().remove("#AD_Client_ID");
|
||||||
}
|
}
|
||||||
throw new AdempiereException(e);
|
|
||||||
}
|
}
|
||||||
finally
|
finally
|
||||||
{
|
{
|
||||||
|
|
Loading…
Reference in New Issue