org.junit.platform.launcher.TestExecutionListener Maven / Gradle / Ivy
/*
* Copyright 2015-2019 the original author or authors.
*
* All rights reserved. This program and the accompanying materials are
* made available under the terms of the Eclipse Public License v2.0 which
* accompanies this distribution and is available at
*
* https://www.eclipse.org/legal/epl-v20.html
*/
package org.junit.platform.launcher;
import static org.apiguardian.api.API.Status.STABLE;
import org.apiguardian.api.API;
import org.junit.platform.engine.TestExecutionResult;
import org.junit.platform.engine.TestExecutionResult.Status;
import org.junit.platform.engine.reporting.ReportEntry;
/**
* Register a concrete implementation of this interface with a {@link Launcher}
* to be notified of events that occur during test execution.
*
* All methods in this interface have empty default implementations.
* Concrete implementations may therefore override one or more of these methods
* to be notified of the selected events.
*
*
JUnit provides two example implementations.
*
*
* - {@link org.junit.platform.launcher.listeners.LoggingListener}
* - {@link org.junit.platform.launcher.listeners.SummaryGeneratingListener}
*
*
* Contrary to JUnit 4, {@linkplain org.junit.platform.engine.TestEngine test engines}
* are supposed to report events not only for {@linkplain TestIdentifier identifiers}
* that represent executable leaves in the {@linkplain TestPlan test plan} but also
* for all intermediate containers. However, while both the JUnit Vintage and JUnit
* Jupiter engines comply with this contract, there is no way to guarantee this for
* third-party engines.
*
* @since 1.0
* @see Launcher
* @see TestPlan
* @see TestIdentifier
*/
@API(status = STABLE, since = "1.0")
public interface TestExecutionListener {
/**
* Called when the execution of the {@link TestPlan} has started,
* before any test has been executed.
*
* @param testPlan describes the tree of tests about to be executed
*/
default void testPlanExecutionStarted(TestPlan testPlan) {
}
/**
* Called when the execution of the {@link TestPlan} has finished,
* after all tests have been executed.
*
* @param testPlan describes the tree of tests that have been executed
*/
default void testPlanExecutionFinished(TestPlan testPlan) {
}
/**
* Called when a new, dynamic {@link TestIdentifier} has been registered.
*
*
A dynamic test is a test that is not known a-priori and
* therefore not contained in the original {@link TestPlan}.
*
* @param testIdentifier the identifier of the newly registered test
* or container
*/
default void dynamicTestRegistered(TestIdentifier testIdentifier) {
}
/**
* Called when the execution of a leaf or subtree of the {@link TestPlan}
* has been skipped.
*
*
The {@link TestIdentifier} may represent a test or a container. In
* the case of a container, no listener methods will be called for any of
* its descendants.
*
*
A skipped test or subtree of tests will never be reported as
* {@linkplain #executionStarted started} or
* {@linkplain #executionFinished finished}.
*
* @param testIdentifier the identifier of the skipped test or container
* @param reason a human-readable message describing why the execution
* has been skipped
*/
default void executionSkipped(TestIdentifier testIdentifier, String reason) {
}
/**
* Called when the execution of a leaf or subtree of the {@link TestPlan}
* is about to be started.
*
*
The {@link TestIdentifier} may represent a test or a container.
*
*
This method will only be called if the test or container has not
* been {@linkplain #executionSkipped skipped}.
*
*
This method will be called for a container {@code TestIdentifier}
* before {@linkplain #executionStarted starting} or
* {@linkplain #executionSkipped skipping} any of its children.
*
* @param testIdentifier the identifier of the started test or container
*/
default void executionStarted(TestIdentifier testIdentifier) {
}
/**
* Called when the execution of a leaf or subtree of the {@link TestPlan}
* has finished, regardless of the outcome.
*
*
The {@link TestIdentifier} may represent a test or a container.
*
*
This method will only be called if the test or container has not
* been {@linkplain #executionSkipped skipped}.
*
*
This method will be called for a container {@code TestIdentifier}
* after all of its children have been
* {@linkplain #executionSkipped skipped} or have
* {@linkplain #executionFinished finished}.
*
*
The {@link TestExecutionResult} describes the result of the execution
* for the supplied {@code TestIdentifier}. The result does not include or
* aggregate the results of its children. For example, a container with a
* failing test will be reported as {@link Status#SUCCESSFUL SUCCESSFUL} even
* if one or more of its children are reported as {@link Status#FAILED FAILED}.
*
* @param testIdentifier the identifier of the finished test or container
* @param testExecutionResult the (unaggregated) result of the execution for
* the supplied {@code TestIdentifier}
*
* @see TestExecutionResult
*/
default void executionFinished(TestIdentifier testIdentifier, TestExecutionResult testExecutionResult) {
}
/**
* Called when additional test reporting data has been published for
* the supplied {@link TestIdentifier}.
*
*
Can be called at any time during the execution of a test plan.
*
* @param testIdentifier describes the test or container to which the entry pertains
* @param entry the published {@code ReportEntry}
*/
default void reportingEntryPublished(TestIdentifier testIdentifier, ReportEntry entry) {
}
}