下面列出了org.junit.platform.engine.discovery.DiscoverySelectors#org.junit.platform.launcher.LauncherDiscoveryRequest 实例代码,或者点击链接到github查看源代码,也可以在右侧发表评论。
@RepeatedTest(10)
void runTestsInParallel() {
Launcher launcher = LauncherFactory.create();
SummaryGeneratingListener listener = new SummaryGeneratingListener();
launcher.registerTestExecutionListeners(listener);
LauncherDiscoveryRequest request = request()//
.configurationParameter("junit.jupiter.execution.parallel.enabled", "true")//
.configurationParameter("junit.jupiter.execution.parallel.config.dynamic.factor", "10")//
.selectors(selectClass(TestCase.class))//
.build();
launcher.execute(request);
assertEquals(NUM_TESTS, listener.getSummary().getTestsSucceededCount(),
"number of tests executed successfully");
}
public static void main(String[] args) {
LauncherDiscoveryRequest request = LauncherDiscoveryRequestBuilder.request()
.selectors(
selectPackage("btdex.sellContract.dispute"),
selectClass(TestTakeRetake.class),
selectClass(TestInvalidTakeTake.class),
selectClass(TestInvalidTakeReopenWithdraw.class)
)
.build();
Launcher launcher = LauncherFactory.create();
// Register a listener
SummaryGeneratingListener listener = new SummaryGeneratingListener();
launcher.registerTestExecutionListeners(listener);
//TestPlan testPlan = launcher.discover(request);
launcher.execute(request);
TestExecutionSummary summary = listener.getSummary();
printReport(summary);
}
@RepeatedTest(10)
void runTestsInParallel() {
Launcher launcher = LauncherFactory.create();
SummaryGeneratingListener listener = new SummaryGeneratingListener();
launcher.registerTestExecutionListeners(listener);
LauncherDiscoveryRequest request = request()//
.configurationParameter("junit.jupiter.execution.parallel.enabled", "true")//
.configurationParameter("junit.jupiter.execution.parallel.config.dynamic.factor", "10")//
.selectors(selectClass(TestCase.class))//
.build();
launcher.execute(request);
assertEquals(NUM_TESTS, listener.getSummary().getTestsSucceededCount(),
"number of tests executed successfully");
}
@SuppressWarnings("unused")
public static void main(String[] args) {
// Discover and filter tests
LauncherDiscoveryRequest request = LauncherDiscoveryRequestBuilder
.request()
.selectors(selectPackage("io.github.bonigarcia"),
selectClass(DummyTest.class))
.filters(includeClassNamePatterns(".*Test")).build();
Launcher launcher = LauncherFactory.create();
TestPlan plan = launcher.discover(request);
// Executing tests
TestExecutionListener listener = new SummaryGeneratingListener();
launcher.registerTestExecutionListeners(listener);
launcher.execute(request, listener);
}
@SuppressWarnings("unused")
public static void main(String[] args) {
// Discover and filter tests
LauncherDiscoveryRequest request = LauncherDiscoveryRequestBuilder
.request()
.selectors(selectPackage("io.github.bonigarcia"),
selectClass(DummyTest.class))
.filters(includeClassNamePatterns(".*Test")).build();
Launcher launcher = LauncherFactory.create();
TestPlan plan = launcher.discover(request);
// Executing tests
TestExecutionListener listener = new SummaryGeneratingListener();
launcher.registerTestExecutionListeners(listener);
launcher.execute(request, listener);
}
@Test
@DisplayName("⚙️ Check a timeout diagnosis")
void checkTimeoutFailureTestWithIntermediateAsyncVerifier() {
LauncherDiscoveryRequest request = LauncherDiscoveryRequestBuilder.request()
.selectors(selectClass(EmbeddedWithARunner.TimingOut.class))
.build();
Launcher launcher = LauncherFactory.create();
SummaryGeneratingListener listener = new SummaryGeneratingListener();
launcher.registerTestExecutionListeners(listener);
launcher.execute(request);
TestExecutionSummary summary = listener.getSummary();
assertThat(summary.getTestsStartedCount()).isEqualTo(1);
assertThat(summary.getTestsFailedCount()).isEqualTo(1);
Throwable exception = summary.getFailures().get(0).getException();
assertThat(exception)
.isInstanceOf(TimeoutException.class)
.hasMessageContaining("checkpoint in file VertxExtensionTest.java");
}
public static void main(String[] args) {
//@formatter:off
LauncherDiscoveryRequest request = LauncherDiscoveryRequestBuilder.request()
.selectors(selectClass("com.baeldung.EmployeesUnitTest"))
.configurationParameter("junit.conditions.deactivate", "com.baeldung.extensions.*")
.configurationParameter("junit.jupiter.extensions.autodetection.enabled", "true")
.build();
//@formatter:on
TestPlan plan = LauncherFactory.create()
.discover(request);
Launcher launcher = LauncherFactory.create();
SummaryGeneratingListener summaryGeneratingListener = new SummaryGeneratingListener();
launcher.execute(request, new TestExecutionListener[] { summaryGeneratingListener });
launcher.execute(request);
summaryGeneratingListener.getSummary()
.printTo(new PrintWriter(System.out));
}
private JUnit5Tests(Launcher launcher
, LauncherDiscoveryRequest request
, SummaryGeneratingListener listener) {
this.launcher = launcher;
this.request = request;
this.listener = listener;
}
public static JUnit5Tests createInstance(Class<?> testClass) {
SummaryGeneratingListener listener = new SummaryGeneratingListener();
LauncherDiscoveryRequest request =
LauncherDiscoveryRequestBuilder.request()
.selectors(selectClass(testClass))
.build();
Launcher launcher = LauncherFactory.create();
launcher.registerTestExecutionListeners(listener);
return new JUnit5Tests(launcher, request, listener);
}
private static TestExecutionSummary runTestMethod(Class<?> testClass, String methodName) {
MethodSelector testMethodSelector = selectMethod(testClass, methodName);
LauncherDiscoveryRequest request = request().selectors(testMethodSelector)
.build();
SummaryGeneratingListener listener = new SummaryGeneratingListener();
Launcher launcher = LauncherFactory.create();
launcher.execute(request, listener);
return listener.getSummary();
}
@Step("Run classes {classes}")
private AllureResults runClasses(final Class<?>... classes) {
final AllureResultsWriterStub writerStub = new AllureResultsWriterStub();
final AllureLifecycle lifecycle = new AllureLifecycle(writerStub);
final ClassSelector[] classSelectors = Stream.of(classes)
.map(DiscoverySelectors::selectClass)
.toArray(ClassSelector[]::new);
final LauncherDiscoveryRequest request = LauncherDiscoveryRequestBuilder.request()
.configurationParameter("junit.jupiter.extensions.autodetection.enabled", "true")
.selectors(classSelectors)
.build();
final LauncherConfig config = LauncherConfig.builder()
.enableTestExecutionListenerAutoRegistration(false)
.addTestExecutionListeners(new AllureJunitPlatform(lifecycle))
.build();
final Launcher launcher = LauncherFactory.create(config);
final AllureLifecycle defaultLifecycle = Allure.getLifecycle();
try {
Allure.setLifecycle(lifecycle);
StepsAspects.setLifecycle(lifecycle);
AttachmentsAspects.setLifecycle(lifecycle);
launcher.execute(request);
return writerStub;
} finally {
Allure.setLifecycle(defaultLifecycle);
StepsAspects.setLifecycle(defaultLifecycle);
AttachmentsAspects.setLifecycle(defaultLifecycle);
}
}
@Step("Run classes {classes}")
private AllureResults runClasses(final Class<?>... classes) {
final AllureResultsWriterStub writerStub = new AllureResultsWriterStub();
final AllureLifecycle lifecycle = new AllureLifecycle(writerStub);
final ClassSelector[] classSelectors = Stream.of(classes)
.map(DiscoverySelectors::selectClass)
.toArray(ClassSelector[]::new);
final LauncherDiscoveryRequest request = LauncherDiscoveryRequestBuilder.request()
.selectors(classSelectors)
.build();
final LauncherConfig config = LauncherConfig.builder()
.enableTestExecutionListenerAutoRegistration(false)
.addTestExecutionListeners(new AllureJunitPlatform(lifecycle))
.build();
final Launcher launcher = LauncherFactory.create(config);
final AllureLifecycle defaultLifecycle = Allure.getLifecycle();
try {
Allure.setLifecycle(lifecycle);
StepsAspects.setLifecycle(lifecycle);
AttachmentsAspects.setLifecycle(lifecycle);
launcher.execute(request);
return writerStub;
} finally {
Allure.setLifecycle(defaultLifecycle);
StepsAspects.setLifecycle(defaultLifecycle);
AttachmentsAspects.setLifecycle(defaultLifecycle);
}
}
public static TestPlanExecutionReport runTests(Class<?> clazz) {
Launcher launcher = LauncherFactory.create();
LauncherDiscoveryRequest request = LauncherDiscoveryRequestBuilder.request()
.selectors(selectClass(clazz))
.build();
ExecutionReportListener listener = new ExecutionReportListener().addClassToSkip(clazz);
launcher.execute(request, listener);
return listener.getReport();
}
/**
* Executes a JUnit Jupiter test discovery and collects the result.
*
* @return The result of discovered tests.
*/
private Result collectTests0() {
Set<Path> classPathRoots = new HashSet<>();
classPathRoots.add(Paths.get(classDirectory.getAbsolutePath()));
LauncherDiscoveryRequest request = LauncherDiscoveryRequestBuilder.request()
.selectors(selectClasspathRoots(classPathRoots))
.selectors(selectDirectory(classDirectory))
.build();
TestPlan testPlan = LauncherFactory.create().discover(request);
Result result = new Result();
for (TestIdentifier rootIdentifier : testPlan.getRoots()) {
for (TestIdentifier identifier : testPlan.getChildren(rootIdentifier)) {
String fqn = fullyQualifiedName(identifier);
Selector selector = new SuiteSelector();
Item item = new Item();
item.fullyQualifiedClassName = fqn;
item.selectors.add(selector);
item.explicit = false;
result.discoveredTests.add(item);
}
}
return result;
}
/**
* Creates a new test plan helper for a specific test class.
*
* @param testClass The name of the test class.
* @return A new test helper instance.
*/
public static TestHelper of(String testClass) {
LauncherDiscoveryRequest request = LauncherDiscoveryRequestBuilder.request()
.selectors(selectClass(testClass))
.build();
final TestPlan testPlan = LauncherFactory.create().discover(request);
return new TestHelper(testPlan);
}
@Test
@DisplayName("⚙️ Check a test failure")
void checkFailureTest() {
LauncherDiscoveryRequest request = LauncherDiscoveryRequestBuilder.request()
.selectors(selectClass(FailureTest.class))
.build();
Launcher launcher = LauncherFactory.create();
SummaryGeneratingListener listener = new SummaryGeneratingListener();
launcher.registerTestExecutionListeners(listener);
launcher.execute(request);
TestExecutionSummary summary = listener.getSummary();
assertThat(summary.getTestsStartedCount()).isEqualTo(1);
assertThat(summary.getTestsFailedCount()).isEqualTo(1);
assertThat(summary.getFailures().get(0).getException()).isInstanceOf(AssertionError.class);
}
@Test
@DisplayName("⚙️ Check a failure in the test method body rather than in a callback")
void checkDirectFailure() {
LauncherDiscoveryRequest request = LauncherDiscoveryRequestBuilder.request()
.selectors(selectClass(DirectFailureTest.class))
.build();
Launcher launcher = LauncherFactory.create();
SummaryGeneratingListener listener = new SummaryGeneratingListener();
launcher.registerTestExecutionListeners(listener);
launcher.execute(request);
TestExecutionSummary summary = listener.getSummary();
assertThat(summary.getTestsStartedCount()).isEqualTo(1);
assertThat(summary.getTestsFailedCount()).isEqualTo(1);
assertThat(summary.getFailures().get(0).getException()).isInstanceOf(RuntimeException.class);
}
@Test
@DisplayName("⚙️ Check a test failure with an intermediate async result verifier")
void checkFailureTestWithIntermediateAsyncVerifier() {
LauncherDiscoveryRequest request = LauncherDiscoveryRequestBuilder.request()
.selectors(selectClass(FailureWithIntermediateAsyncVerifierTest.class))
.build();
Launcher launcher = LauncherFactory.create();
SummaryGeneratingListener listener = new SummaryGeneratingListener();
launcher.registerTestExecutionListeners(listener);
launcher.execute(request);
TestExecutionSummary summary = listener.getSummary();
assertThat(summary.getTestsStartedCount()).isEqualTo(1);
assertThat(summary.getTestsFailedCount()).isEqualTo(1);
assertThat(summary.getFailures().get(0).getException()).isInstanceOf(AssertionError.class);
}
private JupiterExecutionListener executeTests(LauncherDiscoveryRequest request) throws Exception {
TestDescriptor testDescriptor = createTestDescriptorForCucumber(
engine.discover(request, forEngine(engine.getId())), containers);
eventRecorder.reset();
engine.execute(new ExecutionRequest(testDescriptor, eventRecorder, request.getConfigurationParameters()));
return eventRecorder;
}
private void runTests(String... args) throws ClassNotFoundException {
for (String arg : args) {
List<LauncherDiscoveryRequest> requests = collectTests(arg);
if (requests.isEmpty()) {
log.warn("test not found {}", (Object[]) args);
}
for (LauncherDiscoveryRequest request : requests) {
this.runJUnit(arg, request);
}
}
System.exit(0);
}
private Runnable createJupiterRunnable(Class<?> testClass, String testMethod) {
return () -> {
LOGGER.info(Thread.currentThread().getName() + "\n - Parallel Junit5 test- *Start-Time = " + now());
final LauncherDiscoveryRequest request = LauncherDiscoveryRequestBuilder.request()
.selectors(selectMethod(testClass, testMethod))
.build();
final Launcher launcher = LauncherFactory.create();
// -------------------------
// Register Report listener
// -------------------------
registerReportListener(testClass, testMethod, launcher);
// ------------------------------
// Register Test-Summary listener
// ------------------------------
final SummaryGeneratingListener summaryListener = new SummaryGeneratingListener();
launcher.registerTestExecutionListeners(summaryListener);
launcher.execute(request);
LOGGER.info(Thread.currentThread().getName() + "\n - Parallel Junit5 test- *End-Time = " + now());
updatePassFailCount(summaryListener);
};
}
public String executeTests(List<Class<?>> testClasses) {
LauncherDiscoveryRequest discoveryRequest = LauncherDiscoveryRequestBuilder.request()
.selectors(
testClasses.stream().map(DiscoverySelectors::selectClass).collect(Collectors.toList())
)
.build();
var launcherConfig = LauncherConfig.builder()
.addTestEngines(new JupiterTestEngine())
.build();
Launcher launcher = LauncherFactory.create(launcherConfig);
// Create log listener:
var logLines = new ArrayList<String>();
var logListener = LoggingListener.forBiConsumer((t, m) -> log(logLines, m.get(), t));
// Create a summary listener:
var summaryListener = new SummaryGeneratingListener();
launcher.registerTestExecutionListeners(logListener, summaryListener);
// Execute request
launcher.execute(discoveryRequest);
var report = summaryListener.getSummary();
return createJsonTestReport(report, logLines);
}
public void runOne() {
LauncherDiscoveryRequest request = LauncherDiscoveryRequestBuilder
.request()
.selectors(selectClass(FirstUnitTest.class))
.build();
Launcher launcher = LauncherFactory.create();
TestPlan testPlan = launcher.discover(request);
launcher.registerTestExecutionListeners(listener);
launcher.execute(request);
}
public void runAll() {
LauncherDiscoveryRequest request = LauncherDiscoveryRequestBuilder
.request()
.selectors(selectPackage("com.baeldung.runfromjava"))
.filters(includeClassNamePatterns(".*Test"))
.build();
Launcher launcher = LauncherFactory.create();
TestPlan testPlan = launcher.discover(request);
launcher.registerTestExecutionListeners(listener);
launcher.execute(request);
}
private void runJUnit(String arg, LauncherDiscoveryRequest request) {
Stopwatch stopwatch = Stopwatch.createStarted();
System.out.println(String.format("Running %s", arg));
System.out.println();
Launcher launcher = LauncherFactory.create();
SummaryGeneratingListener listener = new SummaryGeneratingListener();
launcher.execute(request, listener);
TestExecutionSummary summary = listener.getSummary();
this.runCnt += summary.getTestsFoundCount();
this.failureCnt += summary.getTestsFailedCount();
this.ignoreCnt += summary.getTestsSkippedCount();
this.ignoreCnt += summary.getTestsSkippedCount();
System.out.println();
if (summary.getTestsFailedCount() > 0) {
System.out.println(
String.format(
"FAIL Tests run: %d, Failures: %d, Ignore: %d, Time elapsed: %s",
summary.getTestsFoundCount(),
summary.getTestsFailedCount(),
summary.getTestsSkippedCount(),
stopwatch.stop()));
System.out.println("Failures:");
for (TestExecutionSummary.Failure failure : summary.getFailures()) {
System.out.println(failure.getTestIdentifier().getDisplayName());
failure.getException().printStackTrace();
System.out.println();
}
} else {
System.out.println(
String.format(
"Tests run: %d, Failures: %d, Ignore: %d, Time elapsed: %s",
summary.getTestsFoundCount(),
summary.getTestsFailedCount(),
summary.getTestsSkippedCount(),
stopwatch.stop()));
System.out.println("Success");
}
System.out.println(Strings.repeat("-", 80));
}