2

何が起こっているのか、なぜループが継続しないのか理解できません。開いているすべてのアクティビティ タスクのダッシュボードを作成しています。今私が抱えている問題は、ダッシュボードの作成中に誰かがタスクを閉じたときです。

コードは次のようになります。

List<Task> approvalTasks = taskQueryApproval.list();
for (Task task : approvalTasks) {
    try {
        ActivitiApplicationRequest activitiRequest = (ActivitiApplicationRequest) taskService
                .getVariable(task.getId(), ACTIVITIREQUEST);
        if (!dashboardValues.containsKey(activitiRequest.getGlobalRequestId())) {
            GlobalRequest globalRequest = globalRequestDao
                .findMinimalGlobalRequestForDashboardBySyscode(activitiRequest.getGlobalRequestId());
            if (globalRequest != null) {
                DashboardValueObject vo = new DashboardValueObject(globalRequest);
                vo.setHasApproval(true);
                dashboardValues.put(activitiRequest.getGlobalRequestId(), vo);
            }
        }
        } catch (ActivitiException ex) {
            LOGGER.debug("Approval already done, skipping activititask");
        }
}

私が抱えている問題は、タスクが存在しないときに Activiti が例外をスローすることを知っていることです。そのため、for ループ内に try-catch を配置しました。

私が期待しているのは、エラーがキャッチされると、リストの残りの部分が続くことです。デバッグ中に、キャッチが行われていることさえ見ました。しかし、ループは依然として中断され、アプリケーションは停止します。これらの例外を除いて:

SEVERE: Error while closing command context org.activiti.engine.ActivitiException: task 203039 doesn't exist
at org.activiti.engine.impl.cmd.GetTaskVariableCmd.execute(GetTaskVariableCmd.java:55)
at org.activiti.engine.impl.interceptor.CommandExecutorImpl.execute(CommandExecutorImpl.java:24)
at org.activiti.engine.impl.interceptor.CommandContextInterceptor.execute(CommandContextInterceptor.java:42)

9-nov-2012 14:45:42 org.activiti.engine.impl.interceptor.CommandContext close
SEVERE: Error while closing command context
org.apache.ibatis.exceptions.PersistenceException: 
### Error querying database.  Cause: com.atomikos.jdbc.AtomikosSQLException: The transaction has timed out - try increasing the timeout if needed
### The error may exist in org/activiti/db/mapping/entity/Task.xml
### The error may involve org.activiti.engine.impl.persistence.entity.TaskEntity.selectTask
### The error occurred while executing a query
### SQL: select * from ACT_RU_TASK where ID_ = ?
### Cause: com.atomikos.jdbc.AtomikosSQLException: The transaction has timed out - try increasing the timeout if needed
at org.apache.ibatis.exceptions.ExceptionFactory.wrapException(ExceptionFactory.java:8)
at org.apache.ibatis.session.defaults.DefaultSqlSession.selectList(DefaultSqlSession.java:81)

私は何を間違っていますか?

4

0 に答える 0