data:image/s3,"s3://crabby-images/02ace/02ace956f9868cf2a1a780bd2c0a517cd3a46077" alt="JAR search and dependency download from the Maven repository"
org.testng.SuiteTaskExecutor Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of testng Show documentation
Show all versions of testng Show documentation
Testing framework for Java
package org.testng;
import java.util.concurrent.BlockingQueue;
import java.util.concurrent.ExecutorService;
import java.util.concurrent.TimeUnit;
import org.testng.internal.IConfiguration;
import org.testng.internal.Utils;
import org.testng.internal.thread.TestNGThreadFactory;
import org.testng.internal.thread.graph.GraphOrchestrator;
import org.testng.log4testng.Logger;
import org.testng.thread.IThreadWorkerFactory;
class SuiteTaskExecutor {
private final BlockingQueue queue;
private final IDynamicGraph graph;
private final IThreadWorkerFactory factory;
private final IConfiguration configuration;
private final int threadPoolSize;
private ExecutorService service;
private static final Logger LOGGER = Logger.getLogger(SuiteTaskExecutor.class);
public SuiteTaskExecutor(
IConfiguration configuration,
IThreadWorkerFactory factory,
BlockingQueue queue,
IDynamicGraph graph,
int threadPoolSize) {
this.configuration = configuration;
this.factory = factory;
this.queue = queue;
this.graph = graph;
this.threadPoolSize = threadPoolSize;
}
public void execute() {
String name = "suites-";
service =
this.configuration
.getExecutorServiceFactory()
.create(
threadPoolSize,
threadPoolSize,
Integer.MAX_VALUE,
TimeUnit.MILLISECONDS,
queue,
new TestNGThreadFactory(name));
GraphOrchestrator executor = new GraphOrchestrator<>(service, factory, graph, null);
executor.run();
}
public void awaitCompletion() {
Utils.log("TestNG", 2, "Starting executor for all suites");
try {
boolean ignored = service.awaitTermination(Long.MAX_VALUE, TimeUnit.MILLISECONDS);
service.shutdownNow();
} catch (InterruptedException handled) {
Thread.currentThread().interrupt();
LOGGER.error(handled.getMessage(), handled);
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy