X-Git-Url: http://git.argeo.org/?a=blobdiff_plain;ds=sidebyside;f=runtime%2Forg.argeo.slc.core%2Fsrc%2Fmain%2Fjava%2Forg%2Fargeo%2Fslc%2Fcore%2Fexecution%2FProcessThreadGroup.java;h=2f264bed46ea59c441a4031e895cc1d70e3e5d3a;hb=af9457b0628ba4cc625192762d0c0fe7564b9846;hp=969c9b93fba5737c75ea723c601402f991b7d7d9;hpb=57aa5d64fb38af2d98076eeaaa11573b3147cc26;p=gpl%2Fargeo-slc.git diff --git a/runtime/org.argeo.slc.core/src/main/java/org/argeo/slc/core/execution/ProcessThreadGroup.java b/runtime/org.argeo.slc.core/src/main/java/org/argeo/slc/core/execution/ProcessThreadGroup.java index 969c9b93f..2f264bed4 100644 --- a/runtime/org.argeo.slc.core/src/main/java/org/argeo/slc/core/execution/ProcessThreadGroup.java +++ b/runtime/org.argeo.slc.core/src/main/java/org/argeo/slc/core/execution/ProcessThreadGroup.java @@ -15,12 +15,9 @@ */ package org.argeo.slc.core.execution; -import java.util.ArrayList; -import java.util.List; import java.util.concurrent.ArrayBlockingQueue; import java.util.concurrent.BlockingQueue; -import org.argeo.slc.execution.ExecutionModulesManager; import org.argeo.slc.execution.ExecutionProcess; import org.argeo.slc.execution.ExecutionStep; import org.springframework.security.Authentication; @@ -28,20 +25,20 @@ import org.springframework.security.context.SecurityContextHolder; /** The thread group attached to a given {@link SlcExecution}. */ public class ProcessThreadGroup extends ThreadGroup { - private final ExecutionModulesManager executionModulesManager; - private final ProcessThread processThread; + // private final ExecutionModulesManager executionModulesManager; + // private final ProcessThread processThread; private final Authentication authentication; private final static Integer STEPS_BUFFER_CAPACITY = 5000; private BlockingQueue steps = new ArrayBlockingQueue( STEPS_BUFFER_CAPACITY); - public ProcessThreadGroup(ExecutionModulesManager executionModulesManager, - ProcessThread processThread) { - super("SLC Process #" + processThread.getProcess().getUuid() - + " thread group"); - this.executionModulesManager = executionModulesManager; - this.processThread = processThread; + private Boolean hadAnError = false; + + public ProcessThreadGroup(ExecutionProcess executionProcess) { + super("SLC Process #" + executionProcess.getUuid() + " thread group"); + // this.executionModulesManager = executionModulesManager; + // this.processThread = processThread; this.authentication = SecurityContextHolder.getContext() .getAuthentication(); } @@ -51,22 +48,27 @@ public class ProcessThreadGroup extends ThreadGroup { } public void dispatchAddStep(ExecutionStep step) { - ExecutionProcess slcProcess = processThread.getProcess(); - List steps = new ArrayList(); - steps.add(step); + // ExecutionProcess slcProcess = processThread.getProcess(); + // List steps = new ArrayList(); + // steps.add(step); // TODO clarify why we don't dispatch steps, must be a reason // dispatchAddSteps(steps); - slcProcess.addSteps(steps); + // slcProcess.addSteps(steps); + if (step.getType().equals(ExecutionStep.ERROR)) + hadAnError = true; this.steps.add(step); } - public void dispatchAddSteps(List steps) { - ExecutionProcess slcProcess = processThread.getProcess(); - executionModulesManager.dispatchAddSteps(slcProcess, steps); - } + // public void dispatchAddSteps(List steps) { + // ExecutionProcess slcProcess = processThread.getProcess(); + // executionModulesManager.dispatchAddSteps(slcProcess, steps); + // } public BlockingQueue getSteps() { return steps; } + public Boolean hadAnError() { + return hadAnError; + } }