Interface TestInfo


  • @API(status=STABLE,
         since="5.0")
    public interface TestInfo
    TestInfo is used to inject information about the current test or container into to @Test, @RepeatedTest, @ParameterizedTest, @TestFactory, @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 or container as the value for the parameter.

    Since:
    5.0
    See Also:
    Test, RepeatedTest, TestFactory, BeforeEach, AfterEach, BeforeAll, AfterAll, DisplayName, Tag
    • Method Detail

      • getDisplayName

        String getDisplayName()
        Get the display name of the current test or container.

        The display name is either a default name or a custom name configured via @DisplayName.

        Default Display Names

        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.

        Returns:
        the display name of the test or container; never null or blank
      • getTags

        Set<String> getTags()
        Get the set of all tags for the current test or container.

        Tags may be declared directly on the test element or inherited from an outer context.

      • getTestClass

        Optional<Class<?>> getTestClass()
        Get the Class associated with the current test or container, if available.
      • getTestMethod

        Optional<Method> getTestMethod()
        Get the Method associated with the current test or container, if available.