/*
* Copyright 2015 the original author or authors.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package org.springframework.statemachine.recipes;
import static org.hamcrest.Matchers.contains;
import static org.hamcrest.Matchers.is;
import static org.junit.Assert.assertThat;
import java.util.ArrayList;
import java.util.List;
import java.util.Map;
import java.util.concurrent.CountDownLatch;
import java.util.concurrent.TimeUnit;
import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;
import org.junit.Test;
import org.springframework.statemachine.StateContext;
import org.springframework.statemachine.StateMachine;
import org.springframework.statemachine.StateMachineContext;
import org.springframework.statemachine.listener.StateMachineListenerAdapter;
import org.springframework.statemachine.recipes.tasks.TasksHandler;
import org.springframework.statemachine.recipes.tasks.TasksHandler.TasksListenerAdapter;
import org.springframework.statemachine.state.State;
import org.springframework.statemachine.support.DefaultStateMachineContext;
import org.springframework.statemachine.transition.Transition;
public class TasksHandlerTests {
private final static Log log = LogFactory.getLog(TasksHandlerTests.class);
@Test
public void testRunOnceSimpleNoFailures() throws InterruptedException {
TasksHandler handler = TasksHandler.builder()
.task("1", sleepRunnable())
.task("2", sleepRunnable())
.task("3", sleepRunnable())
.build();
TestListener listener = new TestListener();
listener.reset(9, 0, 0);
StateMachine<String, String> machine = handler.getStateMachine();
machine.addStateListener(listener);
machine.start();
assertThat(listener.stateMachineStartedLatch.await(1, TimeUnit.SECONDS), is(true));
handler.runTasks();
assertThat(listener.stateChangedLatch.await(8, TimeUnit.SECONDS), is(true));
assertThat(listener.stateChangedCount, is(9));
assertThat(machine.getState().getIds(), contains(TasksHandler.STATE_READY));
Map<Object, Object> variables = machine.getExtendedState().getVariables();
assertThat(variables.size(), is(3));
}
@Test
public void testRunFail() throws InterruptedException {
TasksHandler handler = TasksHandler.builder()
.task("1", sleepRunnable())
.task("2", sleepRunnable())
.task("3", failRunnable())
.build();
TestListener listener = new TestListener();
listener.reset(11, 0, 0);
StateMachine<String, String> machine = handler.getStateMachine();
machine.addStateListener(listener);
machine.start();
assertThat(listener.stateMachineStartedLatch.await(1, TimeUnit.SECONDS), is(true));
handler.runTasks();
assertThat(listener.stateChangedLatch.await(8, TimeUnit.SECONDS), is(true));
assertThat(listener.stateChangedCount, is(11));
assertThat(machine.getState().getIds(), contains(TasksHandler.STATE_ERROR, TasksHandler.STATE_MANUAL));
Map<Object, Object> variables = machine.getExtendedState().getVariables();
assertThat(variables.size(), is(3));
}
@Test
public void testRunFailAndFixAndContinue() throws InterruptedException {
TasksHandler handler = TasksHandler.builder()
.task("1", sleepRunnable())
.task("2", sleepRunnable())
.task("3", failRunnable())
.build();
TestListener listener = new TestListener();
listener.reset(11, 0, 0);
StateMachine<String, String> machine = handler.getStateMachine();
machine.addStateListener(listener);
machine.start();
assertThat(listener.stateMachineStartedLatch.await(1, TimeUnit.SECONDS), is(true));
handler.runTasks();
assertThat(listener.stateChangedLatch.await(8, TimeUnit.SECONDS), is(true));
assertThat(listener.stateChangedCount, is(11));
assertThat(machine.getState().getIds(), contains(TasksHandler.STATE_ERROR, TasksHandler.STATE_MANUAL));
listener.reset(0, 0, 0, 0, 1);
handler.fixCurrentProblems();
assertThat(listener.extendedStateChangedLatch.await(1, TimeUnit.SECONDS), is(true));
listener.reset(1, 0, 0);
handler.continueFromError();
assertThat(listener.stateChangedLatch.await(1, TimeUnit.SECONDS), is(true));
assertThat(listener.stateChangedCount, is(1));
assertThat(machine.getState().getIds(), contains(TasksHandler.STATE_READY));
}
@Test
public void testRunFailAndAutomaticFix() throws InterruptedException {
TasksHandler handler = TasksHandler.builder()
.task("1", sleepRunnable())
.task("2", sleepRunnable())
.task("3", failRunnable())
.build();
TestTasksListener tasksListener = new TestTasksListener();
tasksListener.fix = true;
handler.addTasksListener(tasksListener);
TestListener listener = new TestListener();
listener.reset(1, 0, 0);
StateMachine<String, String> machine = handler.getStateMachine();
machine.addStateListener(listener);
machine.start();
assertThat(listener.stateMachineStartedLatch.await(1, TimeUnit.SECONDS), is(true));
assertThat(listener.stateChangedLatch.await(2, TimeUnit.SECONDS), is(true));
assertThat(listener.stateChangedCount, is(1));
listener.reset(10, 0, 0);
handler.runTasks();
assertThat(listener.stateChangedLatch.await(4, TimeUnit.SECONDS), is(true));
assertThat(listener.stateChangedCount, is(10));
assertThat(machine.getState().getIds(), contains(TasksHandler.STATE_READY));
}
@Test
public void testDagSingleRoot() throws InterruptedException {
TasksHandler handler = TasksHandler.builder()
.task("1", sleepRunnable())
.task("1", "12", sleepRunnable())
.task("1", "13", sleepRunnable())
.build();
TestListener listener = new TestListener();
listener.reset(9, 0, 0);
StateMachine<String, String> machine = handler.getStateMachine();
machine.addStateListener(listener);
machine.start();
assertThat(listener.stateMachineStartedLatch.await(1, TimeUnit.SECONDS), is(true));
handler.runTasks();
assertThat(listener.stateChangedLatch.await(12, TimeUnit.SECONDS), is(true));
assertThat(listener.stateChangedCount, is(9));
assertThat(machine.getState().getIds(), contains(TasksHandler.STATE_READY));
Map<Object, Object> variables = machine.getExtendedState().getVariables();
assertThat(variables.size(), is(3));
}
@Test
public void testDagMultiRoot() throws InterruptedException {
TasksHandler handler = TasksHandler.builder()
.task("1", sleepRunnable())
.task("1", "12", sleepRunnable())
.task("1", "13", sleepRunnable())
.task("2", sleepRunnable())
.task("2", "22", sleepRunnable())
.task("2", "23", sleepRunnable())
.task("3", sleepRunnable())
.task("3", "32", sleepRunnable())
.task("3", "33", sleepRunnable())
.build();
TestListener listener = new TestListener();
StateMachine<String, String> machine = handler.getStateMachine();
machine.addStateListener(listener);
listener.reset(1, 0, 0);
machine.start();
assertThat(listener.stateMachineStartedLatch.await(1, TimeUnit.SECONDS), is(true));
assertThat(listener.stateChangedLatch.await(2, TimeUnit.SECONDS), is(true));
assertThat(listener.stateChangedCount, is(1));
listener.reset(20, 0, 0);
handler.runTasks();
assertThat(listener.stateChangedLatch.await(10, TimeUnit.SECONDS), is(true));
assertThat(listener.stateChangedCount, is(20));
assertThat(machine.getState().getIds(), contains(TasksHandler.STATE_READY));
Map<Object, Object> variables = machine.getExtendedState().getVariables();
assertThat(variables.size(), is(9));
}
@Test
public void testEvents1() throws InterruptedException {
TestTasksListener tasksListener = new TestTasksListener();
TasksHandler handler = TasksHandler.builder()
.task("1", sleepRunnable())
.task("2", sleepRunnable())
.task("3", sleepRunnable())
.listener(tasksListener)
.build();
TestListener listener = new TestListener();
listener.reset(9, 0, 0);
StateMachine<String, String> machine = handler.getStateMachine();
machine.addStateListener(listener);
machine.start();
assertThat(listener.stateMachineStartedLatch.await(1, TimeUnit.SECONDS), is(true));
tasksListener.reset(1, 0, 3, 3, 0, 3, 1, 0);
handler.runTasks();
assertThat(listener.stateChangedLatch.await(8, TimeUnit.SECONDS), is(true));
assertThat(listener.stateChangedCount, is(9));
assertThat(machine.getState().getIds(), contains(TasksHandler.STATE_READY));
assertThat(tasksListener.onTasksStartedLatch.await(1, TimeUnit.SECONDS), is(true));
assertThat(tasksListener.onTasksStarted, is(1));
assertThat(tasksListener.onTaskPreExecuteLatch.await(3, TimeUnit.SECONDS), is(true));
assertThat(tasksListener.onTaskPreExecute, is(3));
assertThat(tasksListener.onTaskPostExecuteLatch.await(3, TimeUnit.SECONDS), is(true));
assertThat(tasksListener.onTaskPostExecute, is(3));
assertThat(tasksListener.onTaskFailed, is(0));
assertThat(tasksListener.onTaskSuccessLatch.await(3, TimeUnit.SECONDS), is(true));
assertThat(tasksListener.onTaskSuccess, is(3));
assertThat(tasksListener.onTasksSuccessLatch.await(1, TimeUnit.SECONDS), is(true));
assertThat(tasksListener.onTasksSuccess, is(1));
}
@Test
public void testEvents2() throws InterruptedException {
TestTasksListener tasksListener = new TestTasksListener();
TasksHandler handler = TasksHandler.builder()
.task("1", sleepRunnable())
.task("2", sleepRunnable())
.task("3", failRunnable())
.listener(tasksListener)
.build();
TestListener listener = new TestListener();
listener.reset(11, 0, 0);
StateMachine<String, String> machine = handler.getStateMachine();
machine.addStateListener(listener);
machine.start();
assertThat(listener.stateMachineStartedLatch.await(1, TimeUnit.SECONDS), is(true));
tasksListener.reset(1, 0, 0, 0, 1, 0, 0, 1);
handler.runTasks();
assertThat(listener.stateChangedLatch.await(8, TimeUnit.SECONDS), is(true));
assertThat(listener.stateChangedCount, is(11));
assertThat(tasksListener.onTasksStartedLatch.await(1, TimeUnit.SECONDS), is(true));
assertThat(tasksListener.onTasksStarted, is(1));
assertThat(tasksListener.onTaskSuccessLatch.await(2, TimeUnit.SECONDS), is(true));
assertThat(tasksListener.onTaskSuccess, is(2));
assertThat(tasksListener.onTaskFailedLatch.await(1, TimeUnit.SECONDS), is(true));
assertThat(tasksListener.onTaskFailed, is(1));
assertThat(tasksListener.onTasksErrorLatch.await(1, TimeUnit.SECONDS), is(true));
assertThat(tasksListener.onTasksError, is(1));
assertThat(tasksListener.onTasksSuccess, is(0));
}
@Test
public void testEvents3() throws InterruptedException {
TestTasksListener tasksListener = new TestTasksListener();
TasksHandler handler = TasksHandler.builder()
.task("1", sleepRunnable())
.task("2", sleepRunnable())
.task("3", failRunnable())
.listener(tasksListener)
.build();
TestListener listener = new TestListener();
listener.reset(11, 0, 0);
StateMachine<String, String> machine = handler.getStateMachine();
machine.addStateListener(listener);
machine.start();
assertThat(listener.stateMachineStartedLatch.await(1, TimeUnit.SECONDS), is(true));
tasksListener.reset(0, 1, 0, 0, 0, 0, 0, 0);
handler.runTasks();
assertThat(listener.stateChangedLatch.await(8, TimeUnit.SECONDS), is(true));
assertThat(listener.stateChangedCount, is(11));
assertThat(machine.getState().getIds(), contains(TasksHandler.STATE_ERROR, TasksHandler.STATE_MANUAL));
listener.reset(1, 0, 0);
handler.fixCurrentProblems();
handler.continueFromError();
assertThat(listener.stateChangedLatch.await(1, TimeUnit.SECONDS), is(true));
assertThat(listener.stateChangedCount, is(1));
assertThat(machine.getState().getIds(), contains(TasksHandler.STATE_READY));
assertThat(tasksListener.onTasksContinueLatch.await(1, TimeUnit.SECONDS), is(true));
assertThat(tasksListener.onTasksContinue, is(1));
}
@Test
public void testPersist1() throws InterruptedException {
TestStateMachinePersist persist = new TestStateMachinePersist();
TasksHandler handler = TasksHandler.builder()
.task("1", sleepRunnable())
.task("2", sleepRunnable())
.task("3", sleepRunnable())
.persist(persist)
.build();
TestListener listener = new TestListener();
listener.reset(9, 0, 0);
StateMachine<String, String> machine = handler.getStateMachine();
machine.addStateListener(listener);
machine.start();
assertThat(listener.stateMachineStartedLatch.await(1, TimeUnit.SECONDS), is(true));
persist.reset(5);
handler.runTasks();
assertThat(listener.stateChangedLatch.await(8, TimeUnit.SECONDS), is(true));
assertThat(listener.stateChangedCount, is(9));
assertThat(machine.getState().getIds(), contains(TasksHandler.STATE_READY));
Map<Object, Object> variables = machine.getExtendedState().getVariables();
assertThat(variables.size(), is(3));
assertThat(persist.writeLatch.await(4, TimeUnit.SECONDS), is(true));
assertThat(persist.contexts.size(), is(5));
for (StateMachineContext<String, String> context : persist.getContexts()) {
if (context.getState() == "TASKS") {
assertThat(context.getChilds().size(), is(3));
} else {
assertThat(context.getChilds().size(), is(0));
}
}
}
@Test
public void testPersist2() throws InterruptedException {
TestStateMachinePersist persist = new TestStateMachinePersist();
TasksHandler handler = TasksHandler.builder()
.task("1", sleepRunnable())
.task("2", sleepRunnable())
.task("3", failRunnable())
.persist(persist)
.build();
TestListener listener = new TestListener();
listener.reset(11, 0, 0);
StateMachine<String, String> machine = handler.getStateMachine();
machine.addStateListener(listener);
machine.start();
assertThat(listener.stateMachineStartedLatch.await(1, TimeUnit.SECONDS), is(true));
persist.reset(6);
handler.runTasks();
assertThat(listener.stateChangedLatch.await(8, TimeUnit.SECONDS), is(true));
assertThat(listener.stateChangedCount, is(11));
assertThat(machine.getState().getIds(), contains(TasksHandler.STATE_ERROR, TasksHandler.STATE_MANUAL));
Map<Object, Object> variables = machine.getExtendedState().getVariables();
assertThat(variables.size(), is(3));
assertThat(persist.writeLatch.await(4, TimeUnit.SECONDS), is(true));
assertThat(persist.contexts.size(), is(6));
for (StateMachineContext<String, String> context : persist.getContexts()) {
if (context.getState() == "TASKS") {
assertThat(context.getChilds().size(), is(3));
} else if (context.getState() == "ERROR") {
assertThat(context.getChilds().size(), is(1));
} else {
assertThat(context.getChilds().size(), is(0));
}
}
}
@Test
public void testReset1() throws InterruptedException {
TestStateMachinePersist persist = new TestStateMachinePersist();
TasksHandler handler = TasksHandler.builder()
.task("1", sleepRunnable())
.task("2", sleepRunnable())
.task("3", sleepRunnable())
.persist(persist)
.build();
TestListener listener = new TestListener();
StateMachine<String, String> machine = handler.getStateMachine();
machine.addStateListener(listener);
handler.resetFromPersistStore();
assertThat(listener.stateMachineStartedLatch.await(1, TimeUnit.SECONDS), is(true));
}
@Test
public void testReset2() throws InterruptedException {
DefaultStateMachineContext<String, String> child = new DefaultStateMachineContext<String, String>("MANUAL", null, null, null);
List<StateMachineContext<String, String>> childs = new ArrayList<StateMachineContext<String, String>>();
childs.add(child);
DefaultStateMachineContext<String, String> context = new DefaultStateMachineContext<String, String>(childs, "ERROR", null, null, null);
TestStateMachinePersist persist = new TestStateMachinePersist(context);
TasksHandler handler = TasksHandler.builder()
.task("1", sleepRunnable())
.task("2", sleepRunnable())
.task("3", sleepRunnable())
.persist(persist)
.build();
TestListener listener = new TestListener();
StateMachine<String, String> machine = handler.getStateMachine();
machine.addStateListener(listener);
handler.resetFromPersistStore();
assertThat(listener.stateMachineStartedLatch.await(1, TimeUnit.SECONDS), is(true));
assertThat(machine.getState().getIds(), contains(TasksHandler.STATE_ERROR, TasksHandler.STATE_MANUAL));
}
@Test
public void testReset3() throws InterruptedException {
log.info("testReset3 start");
List<StateMachineContext<String, String>> childs = new ArrayList<StateMachineContext<String, String>>();
DefaultStateMachineContext<String, String> context = new DefaultStateMachineContext<String, String>(childs, "ERROR", null, null, null);
TestStateMachinePersist persist = new TestStateMachinePersist(context);
TasksHandler handler = TasksHandler.builder()
.task("1", sleepRunnable())
.task("2", sleepRunnable())
.task("3", sleepRunnable())
.persist(persist)
.build();
TestListener listener = new TestListener();
listener.reset(2, 0, 0);
StateMachine<String, String> machine = handler.getStateMachine();
machine.addStateListener(listener);
handler.resetFromPersistStore();
log.info("testReset3 wait stateMachineStartedLatch");
assertThat(listener.stateMachineStartedLatch.await(1, TimeUnit.SECONDS), is(true));
log.info("testReset3 wait stateChangedLatch");
assertThat(listener.stateChangedLatch.await(4, TimeUnit.SECONDS), is(true));
assertThat(listener.stateChangedCount, is(2));
assertThat(machine.getState().getIds(), contains(TasksHandler.STATE_READY));
}
//@Test
public void testReset4() throws InterruptedException {
// TODO: automaticAction() is not executed when state is reset
DefaultStateMachineContext<String, String> child = new DefaultStateMachineContext<String, String>("AUTOMATIC", null, null, null);
List<StateMachineContext<String, String>> childs = new ArrayList<StateMachineContext<String, String>>();
childs.add(child);
DefaultStateMachineContext<String, String> context = new DefaultStateMachineContext<String, String>(childs, "ERROR", null, null, null);
TestStateMachinePersist persist = new TestStateMachinePersist(context);
TasksHandler handler = TasksHandler.builder()
.task("1", sleepRunnable())
.task("2", sleepRunnable())
.task("3", sleepRunnable())
.persist(persist)
.build();
TestListener listener = new TestListener();
listener.reset(2, 0, 0);
StateMachine<String, String> machine = handler.getStateMachine();
machine.addStateListener(listener);
handler.resetFromPersistStore();
assertThat(listener.stateMachineStartedLatch.await(1, TimeUnit.SECONDS), is(true));
assertThat(listener.stateChangedLatch.await(4, TimeUnit.SECONDS), is(true));
assertThat(listener.stateChangedCount, is(2));
assertThat(machine.getState().getIds(), contains(TasksHandler.STATE_READY));
}
private static Runnable sleepRunnable() {
return new Runnable() {
@Override
public void run() {
try {
Thread.sleep(2000);
} catch (InterruptedException e) {
}
}
};
}
private static Runnable failRunnable() {
return new Runnable() {
@Override
public void run() {
throw new RuntimeException();
}
};
}
static class TestListener extends StateMachineListenerAdapter<String, String> {
private final Object lock = new Object();
volatile CountDownLatch stateMachineStartedLatch = new CountDownLatch(1);
volatile CountDownLatch stateChangedLatch = new CountDownLatch(1);
volatile CountDownLatch stateEnteredLatch = new CountDownLatch(2);
volatile CountDownLatch stateExitedLatch = new CountDownLatch(0);
volatile CountDownLatch transitionLatch = new CountDownLatch(0);
volatile CountDownLatch extendedStateChangedLatch = new CountDownLatch(0);
volatile int stateChangedCount = 0;
volatile int transitionCount = 0;
volatile int extendedStateChangedCount = 0;
List<State<String, String>> statesEntered = new ArrayList<State<String, String>>();
List<State<String, String>> statesExited = new ArrayList<State<String, String>>();
@Override
public void stateMachineStarted(StateMachine<String, String> stateMachine) {
synchronized (lock) {
stateMachineStartedLatch.countDown();
}
}
@Override
public void stateChanged(State<String, String> from, State<String, String> to) {
synchronized (lock) {
TasksHandlerTests.log.info("stateChanged " + from + "::" + to);
stateChangedCount++;
stateChangedLatch.countDown();
}
}
@Override
public void stateEntered(State<String, String> state) {
synchronized (lock) {
statesEntered.add(state);
stateEnteredLatch.countDown();
}
}
@Override
public void stateExited(State<String, String> state) {
synchronized (lock) {
statesExited.add(state);
stateExitedLatch.countDown();
}
}
@Override
public void transitionEnded(Transition<String, String> transition) {
synchronized (lock) {
transitionCount++;
transitionLatch.countDown();
}
}
@Override
public void extendedStateChanged(Object key, Object value) {
synchronized (lock) {
extendedStateChangedCount++;
extendedStateChangedLatch.countDown();
}
}
public void reset(int c1, int c2, int c3) {
reset(c1, c2, c3, 0);
}
public void reset(int c1, int c2, int c3, int c4) {
reset(c1, c2, c3, c4, 0);
}
public void reset(int c1, int c2, int c3, int c4, int c5) {
synchronized (lock) {
stateChangedLatch = new CountDownLatch(c1);
stateEnteredLatch = new CountDownLatch(c2);
stateExitedLatch = new CountDownLatch(c3);
transitionLatch = new CountDownLatch(c4);
extendedStateChangedLatch = new CountDownLatch(c5);
stateChangedCount = 0;
transitionCount = 0;
extendedStateChangedCount = 0;
statesEntered.clear();
statesExited.clear();
}
}
}
private static class TestTasksListener extends TasksListenerAdapter {
final Object lock = new Object();
volatile CountDownLatch onTasksStartedLatch = new CountDownLatch(1);
volatile CountDownLatch onTasksContinueLatch = new CountDownLatch(1);
volatile CountDownLatch onTaskPreExecuteLatch = new CountDownLatch(1);
volatile CountDownLatch onTaskPostExecuteLatch = new CountDownLatch(1);
volatile CountDownLatch onTaskFailedLatch = new CountDownLatch(1);
volatile CountDownLatch onTaskSuccessLatch = new CountDownLatch(1);
volatile CountDownLatch onTasksSuccessLatch = new CountDownLatch(1);
volatile CountDownLatch onTasksErrorLatch = new CountDownLatch(1);
volatile int onTasksStarted;
volatile int onTasksContinue;
volatile int onTaskPreExecute;
volatile int onTaskPostExecute;
volatile int onTaskFailed;
volatile int onTaskSuccess;
volatile int onTasksSuccess;
volatile int onTasksError;
volatile boolean fix = false;
@Override
public void onTasksStarted() {
synchronized (lock) {
onTasksStarted++;
onTasksStartedLatch.countDown();
}
}
@Override
public void onTasksContinue() {
synchronized (lock) {
onTasksContinue++;
onTasksContinueLatch.countDown();
}
}
@Override
public void onTaskPreExecute(Object id) {
synchronized (lock) {
onTaskPreExecute++;
onTaskPreExecuteLatch.countDown();
}
}
@Override
public void onTaskPostExecute(Object id) {
synchronized (lock) {
onTaskPostExecute++;
onTaskPostExecuteLatch.countDown();
}
}
@Override
public void onTaskFailed(Object id, Exception exception) {
synchronized (lock) {
onTaskFailed++;
onTaskFailedLatch.countDown();
}
}
@Override
public void onTaskSuccess(Object id) {
synchronized (lock) {
onTaskSuccess++;
onTaskSuccessLatch.countDown();
}
}
@Override
public void onTasksSuccess() {
synchronized (lock) {
onTasksSuccess++;
onTasksSuccessLatch.countDown();
}
}
@Override
public void onTasksError() {
synchronized (lock) {
onTasksError++;
onTasksErrorLatch.countDown();
}
}
@Override
public void onTasksAutomaticFix(TasksHandler handler, StateContext<String, String> context) {
if (!fix) {
return;
}
handler.markAllTasksFixed();
}
public void reset(int c1, int c2, int c3, int c4, int c5, int c6, int c7, int c8) {
synchronized (lock) {
onTasksStartedLatch = new CountDownLatch(c1);
onTasksContinueLatch = new CountDownLatch(c2);
onTaskPreExecuteLatch = new CountDownLatch(c3);
onTaskPostExecuteLatch = new CountDownLatch(c4);
onTaskFailedLatch = new CountDownLatch(c5);
onTaskSuccessLatch = new CountDownLatch(c6);
onTasksSuccessLatch = new CountDownLatch(c7);
onTasksErrorLatch = new CountDownLatch(c8);
onTasksStarted = 0;
onTasksContinue = 0;
onTaskPreExecute = 0;
onTaskPostExecute = 0;
onTaskFailed = 0;
onTaskSuccess = 0;
onTasksSuccess = 0;
onTasksError = 0;
}
}
}
}