@API(status=STABLE, since="5.0") public interface TestInfo
TestInfo
is used to inject information about the current test or
container into to @Test
, @BeforeEach
, @AfterEach
,
@BeforeAll
, and @AfterAll
methods.
If a method parameter is of type TestInfo
, JUnit will supply
an instance of TestInfo
corresponding to the current test as the
value for the parameter.
Test
,
DisplayName
Modifier and Type | Method and Description |
---|---|
String |
getDisplayName()
Get the display name of the current test or container.
|
Set<String> |
getTags()
Get the set of all tags for the current test or container.
|
Optional<Class<?>> |
getTestClass()
Get the
Class associated with the current test or container, if available. |
Optional<Method> |
getTestMethod()
Get the
Method associated with the current test, if available. |
String getDisplayName()
The display name is either a default name or a custom name configured
via @DisplayName
.
If the context in which TestInfo
is used is at the container
level, the default display name is generated based on the name of the
test class. For top-level and @Nested
test classes, the
default display name is the simple name
of the class. For static
nested test classes, the default display
name is the default display name for the enclosing class concatenated with
the simple name of the static
nested class, separated by a dollar sign ($
). For example, the
default display names for the following test classes are
TopLevelTests
, NestedTests
, and TopLevelTests$StaticTests
.
class TopLevelTests { @Nested class NestedTests {} static class StaticTests {} }
If the context in which TestInfo
is used is at the test level,
the default display name is the name of the test method concatenated with
a comma-separated list of simple names
of the parameter types in parentheses. For example, the default display
name for the following test method is testUser(TestInfo, User)
.
@Test void testUser(TestInfo testInfo, @Mock User user) {}
Note that display names are typically used for test reporting in IDEs and build tools and may contain spaces, special characters, and even emoji.
null
or blankSet<String> getTags()
Tags may be declared directly on the test element or inherited from an outer context.
Optional<Class<?>> getTestClass()
Class
associated with the current test or container, if available.