net.serenitybdd.junit.runners.ParameterizedRunnerScheduler Maven / Gradle / Ivy
package net.serenitybdd.junit.runners;
import com.google.common.collect.ImmutableList;
import org.junit.runners.model.RunnerScheduler;
import java.util.LinkedList;
import java.util.Queue;
import java.util.concurrent.*;
import java.util.concurrent.atomic.AtomicInteger;
/**
* JUnit scheduler for parallel parameterized tests.
*/
class ParameterizedRunnerScheduler implements RunnerScheduler {
private ExecutorService executorService;
private CompletionService completionService;
private Queue> tasks;
public ParameterizedRunnerScheduler(final Class> klass, final int threadCount) {
executorService = Executors.newFixedThreadPool(threadCount, new NamedThreadFactory(klass.getSimpleName()));
completionService = new ExecutorCompletionService<>(executorService);
tasks = new LinkedList<>();
}
protected Queue> getTaskQueue() {
return new LinkedList<>(ImmutableList.copyOf(tasks));
}
public void schedule(final Runnable childStatement) {
tasks.offer(completionService.submit(childStatement, null));
}
public void finished() {
try {
while (!tasks.isEmpty()) {
tasks.remove(completionService.take());
}
} catch (InterruptedException e) {
Thread.currentThread().interrupt();
} finally {
executorService.shutdownNow();
}
}
static final class NamedThreadFactory implements ThreadFactory {
private static final AtomicInteger POOL_NUMBER = new AtomicInteger(1);
private final AtomicInteger threadNumber = new AtomicInteger(1);
private final ThreadGroup group;
NamedThreadFactory(final String poolName) {
group = new ThreadGroup(poolName + "-" + POOL_NUMBER.getAndIncrement());
}
public Thread newThread(final Runnable r) {
return new Thread(group, r, group.getName() + "-thread-" + threadNumber.getAndIncrement(), 0);
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy