下面列出了怎么用org.junit.platform.launcher.listeners.SummaryGeneratingListener的API类实例代码及写法,或者点击链接到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();
}
@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);
}
public void updatePassFailCount(SummaryGeneratingListener summaryListener) {
TestExecutionSummary summary = summaryListener.getSummary();
if (summary.getTotalFailureCount() > 0) {
getFailedCounter().incrementAndGet();
summary.getFailures().forEach(thisFailure -> {
TestIdentifier testIdentifier = thisFailure.getTestIdentifier();
String exceptionMessage = thisFailure.getException().getMessage();
LOGGER.info("\n----------------------------------------------------------------------\n");
LOGGER.info("\n###JUnit5: Test Failed Due To --> {}, \ntestIdentifier={}", exceptionMessage, testIdentifier);
LOGGER.info("\n----------------------------------------------------------------------\n");
});
} else {
getPassedCounter().incrementAndGet();
}
}
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);
}
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));
}
private static int launchJUnitPlatform(TestConf testConf) {
var moduleName = testConf.moduleName();
var moduleNameAndVersion = testConf.moduleNameAndVersion();
var parallel = testConf.parallel();
var includeTags = testConf.includeTags();
var excludeTags = testConf.excludeTags();
// Create Launcher API entry point
// https://junit.org/junit5/docs/current/user-guide/#launcher-api
var builder = LauncherDiscoveryRequestBuilder.request();
// Select from...
var packages = testConf.packages();
if (packages.isEmpty()) {
builder.selectors(selectModule(moduleName));
} else {
builder.selectors(packages.stream().map(DiscoverySelectors::selectPackage).collect(toUnmodifiableList()));
}
// Apply filters...
if (!includeTags.isEmpty()) {
builder.filters(TagFilter.includeTags(includeTags));
}
if (!excludeTags.isEmpty()) {
builder.filters(TagFilter.excludeTags(excludeTags));
}
// Fine-tune configuration...
builder.configurationParameter("junit.jupiter.execution.parallel.enabled", Boolean.toString(parallel));
var launcher = LauncherFactory.create();
var launcherDiscoveryRequest = builder.build();
var summaryGeneratingListener = new SummaryGeneratingListener();
var xmlReportsWritingListener = new LegacyXmlReportGeneratingListener(testConf.reportPath().resolve(moduleName), new PrintWriter(System.out));
launcher.registerTestExecutionListeners(summaryGeneratingListener);
launcher.registerTestExecutionListeners(xmlReportsWritingListener);
var startTimeMillis = System.currentTimeMillis();
launcher.execute(launcherDiscoveryRequest);
var duration = System.currentTimeMillis() - startTimeMillis;
var summary = summaryGeneratingListener.getSummary();
// DEBUG
//summary.printTo(new PrintWriter(System.out));
var success = summary.getTestsFailedCount() == 0 && summary.getTestsAbortedCount() == 0 &&
summary.getContainersFailedCount() == 0 && summary.getContainersAbortedCount() == 0;
if (success) {
var succeeded = summary.getTestsSucceededCount();
System.out.printf("[tester] Successfully tested %s: %d tests in %d ms%n", moduleNameAndVersion, succeeded, duration);
} else {
var writer = new PrintWriter(System.err);
summary.printTo(writer);
summary.printFailuresTo(writer);
}
return success? 0: 1;
}