DynamicTest
is a test case generated at runtime.
It is composed of a display name
and an Executable
.
Instances of DynamicTest
must be generated by factory methods
annotated with @TestFactory
.
Note that dynamic tests are quite different from standard @Test
cases since callbacks such as @BeforeEach
and
@AfterEach
methods are not executed for dynamic tests.
-
Method Summary
Modifier and TypeMethodDescriptionstatic DynamicTest
dynamicTest
(String displayName, URI testSourceUri, Executable executable) Factory for creating a newDynamicTest
for the supplied display name, custom test sourceURI
, and executable code block.static DynamicTest
dynamicTest
(String displayName, Executable executable) Factory for creating a newDynamicTest
for the supplied display name and executable code block.Get theexecutable
code block associated with thisDynamicTest
.static <T> Stream<DynamicTest>
stream
(Iterator<? extends Named<T>> inputGenerator, ThrowingConsumer<? super T> testExecutor) Generate a stream of dynamic tests based on the given generator and test executor.static <T> Stream<DynamicTest>
stream
(Iterator<T> inputGenerator, Function<? super T, String> displayNameGenerator, ThrowingConsumer<? super T> testExecutor) Generate a stream of dynamic tests based on the given generator and test executor.static <T> Stream<DynamicTest>
stream
(Stream<? extends Named<T>> inputStream, ThrowingConsumer<? super T> testExecutor) Generate a stream of dynamic tests based on the given input stream and test executor.static <T> Stream<DynamicTest>
stream
(Stream<T> inputStream, Function<? super T, String> displayNameGenerator, ThrowingConsumer<? super T> testExecutor) Generate a stream of dynamic tests based on the given input stream and test executor.Methods inherited from class org.junit.jupiter.api.DynamicNode
getDisplayName, getTestSourceUri, toString
-
Method Details
-
dynamicTest
Factory for creating a newDynamicTest
for the supplied display name and executable code block.- Parameters:
displayName
- the display name for the dynamic test; nevernull
or blankexecutable
- the executable code block for the dynamic test; nevernull
- See Also:
-
dynamicTest
Factory for creating a newDynamicTest
for the supplied display name, custom test sourceURI
, and executable code block.- Parameters:
displayName
- the display name for the dynamic test; nevernull
or blanktestSourceUri
- a custom test source URI for the dynamic test; may benull
if the framework should generate the test source based on the@TestFactory
methodexecutable
- the executable code block for the dynamic test; nevernull
- Since:
- 5.3
- See Also:
-
stream
public static <T> Stream<DynamicTest> stream(Iterator<T> inputGenerator, Function<? super T, String> displayNameGenerator, ThrowingConsumer<? super T> testExecutor) Generate a stream of dynamic tests based on the given generator and test executor.Use this method when the set of dynamic tests is nondeterministic in nature or when the input comes from an existing
Iterator
. Seestream(Stream, Function, ThrowingConsumer)
as an alternative.The given
inputGenerator
is responsible for generating input values. ADynamicTest
will be added to the resulting stream for each dynamically generated input value, using the givendisplayNameGenerator
andtestExecutor
.- Type Parameters:
T
- the type of input generated by theinputGenerator
and used by thedisplayNameGenerator
andtestExecutor
- Parameters:
inputGenerator
- anIterator
that serves as a dynamic input generator; nevernull
displayNameGenerator
- a function that generates a display name based on an input value; nevernull
testExecutor
- a consumer that executes a test based on an input value; nevernull
- Returns:
- a stream of dynamic tests based on the given generator and
executor; never
null
- See Also:
-
stream
@API(status=MAINTAINED, since="5.7") public static <T> Stream<DynamicTest> stream(Stream<T> inputStream, Function<? super T, String> displayNameGenerator, ThrowingConsumer<? super T> testExecutor) Generate a stream of dynamic tests based on the given input stream and test executor.Use this method when the set of dynamic tests is nondeterministic in nature or when the input comes from an existing
Stream
. Seestream(Iterator, Function, ThrowingConsumer)
as an alternative.The given
inputStream
is responsible for supplying input values. ADynamicTest
will be added to the resulting stream for each dynamically supplied input value, using the givendisplayNameGenerator
andtestExecutor
.- Type Parameters:
T
- the type of input supplied by theinputStream
and used by thedisplayNameGenerator
andtestExecutor
- Parameters:
inputStream
- aStream
that supplies dynamic input values; nevernull
displayNameGenerator
- a function that generates a display name based on an input value; nevernull
testExecutor
- a consumer that executes a test based on an input value; nevernull
- Returns:
- a stream of dynamic tests based on the given generator and
executor; never
null
- Since:
- 5.7
- See Also:
-
stream
@API(status=MAINTAINED, since="5.8") public static <T> Stream<DynamicTest> stream(Iterator<? extends Named<T>> inputGenerator, ThrowingConsumer<? super T> testExecutor) Generate a stream of dynamic tests based on the given generator and test executor.Use this method when the set of dynamic tests is nondeterministic in nature or when the input comes from an existing
Iterator
. Seestream(Stream, ThrowingConsumer)
as an alternative.The given
inputGenerator
is responsible for generating input values and display names. ADynamicTest
will be added to the resulting stream for each dynamically generated input value, using the giventestExecutor
.- Type Parameters:
T
- the type of input generated by theinputGenerator
and used by thetestExecutor
- Parameters:
inputGenerator
- anIterator
withNamed
values that serves as a dynamic input generator; nevernull
testExecutor
- a consumer that executes a test based on an input value; nevernull
- Returns:
- a stream of dynamic tests based on the given generator and
executor; never
null
- Since:
- 5.8
- See Also:
-
stream
@API(status=MAINTAINED, since="5.8") public static <T> Stream<DynamicTest> stream(Stream<? extends Named<T>> inputStream, ThrowingConsumer<? super T> testExecutor) Generate a stream of dynamic tests based on the given input stream and test executor.Use this method when the set of dynamic tests is nondeterministic in nature or when the input comes from an existing
Stream
. Seestream(Iterator, ThrowingConsumer)
as an alternative.The given
inputStream
is responsible for supplying input values and display names. ADynamicTest
will be added to the resulting stream for each dynamically supplied input value, using the giventestExecutor
.- Type Parameters:
T
- the type of input supplied by theinputStream
and used by thedisplayNameGenerator
andtestExecutor
- Parameters:
inputStream
- aStream
that supplies dynamicNamed
input values; nevernull
testExecutor
- a consumer that executes a test based on an input value; nevernull
- Returns:
- a stream of dynamic tests based on the given generator and
executor; never
null
- Since:
- 5.8
- See Also:
-
getExecutable
Get theexecutable
code block associated with thisDynamicTest
.
-