官方文档 - Parameterized Tests
    参数化测试是JUnit5很重要的一个新特性,它使得用不同的参数多次运行测试成为了可能,也为我们的单元测试带来许多便利。

    利用@ValueSource等注解,指定入参,我们将可以使用不同的参数进行多次单元测试,而不需要每新增一个参数就新增一个单元测试,省去了很多冗余代码。

    利用@ValueSource等注解,指定入参,我们将可以使用不同的参数进行多次单元测试,而不需要每新增一个参数就新增一个单元测试,省去了很多冗余代码。

    @ValueSource: 为参数化测试指定入参来源,支持八大基础类以及String类型,Class类型
    @NullSource: 表示为参数化测试提供一个null的入参
    @EnumSource: 表示为参数化测试提供一个枚举入参
    @CsvFileSource:表示读取指定CSV文件内容作为参数化测试入参
    @MethodSource:表示读取指定方法的返回值作为参数化测试入参(注意方法返回需要是一个流)
    当然如果参数化测试仅仅只能做到指定普通的入参还达不到让我觉得惊艳的地步。让我真正感到他的强大之处的地方在于他可以支持外部的各类入参。如:CSV,YML,JSON 文件甚至方法的返回值也可以作为入参。只需要去实现ArgumentsProvider接口,任何外部文件都可以作为它的入参。

    1. @ParameterizedTest
    2. @ValueSource(strings = {"one", "two", "three"})
    3. @DisplayName("参数化测试1")
    4. public void parameterizedTest1(String string) {
    5. System.out.println(string);
    6. Assertions.assertTrue(StringUtils.isNotBlank(string));
    7. }
    8. @ParameterizedTest
    9. @MethodSource("method") //指定方法名
    10. @DisplayName("方法来源参数")
    11. public void testWithExplicitLocalMethodSource(String name) {
    12. System.out.println(name);
    13. Assertions.assertNotNull(name);
    14. }
    15. static Stream<String> method() {
    16. return Stream.of("apple", "banana");
    17. }