首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

在没有ParameterResolver的JUnit5中实现BeforeEach、AfterEach的参数化

,可以通过编写自定义的扩展来实现。

首先,需要创建一个实现BeforeEachCallbackAfterEachCallback接口的类,该类将负责在每个测试方法之前和之后执行相应的操作。在这个类中,可以定义一个成员变量来存储参数化的值。

接下来,需要创建一个实现TestTemplateInvocationContextProvider接口的类,该类将负责提供参数化的值。在这个类中,可以定义一个方法来返回参数化的值列表。

然后,需要创建一个实现TestTemplateInvocationContext接口的类,该类将负责在每个参数化的测试方法中执行相应的操作。在这个类中,可以使用之前定义的成员变量来获取参数化的值。

最后,在测试类中使用@ExtendWith注解来注册自定义的扩展,并使用@TestTemplate注解来标记参数化的测试方法。

下面是一个示例代码:

代码语言:txt
复制
import org.junit.jupiter.api.extension.*;
import org.junit.jupiter.api.*;

public class ParameterizedTest implements BeforeEachCallback, AfterEachCallback {

    private String parameter;

    @Override
    public void beforeEach(ExtensionContext context) throws Exception {
        // 在每个测试方法之前执行的操作
        parameter = context.getDisplayName(); // 这里示例使用测试方法的名称作为参数化的值
        System.out.println("BeforeEach: " + parameter);
    }

    @Override
    public void afterEach(ExtensionContext context) throws Exception {
        // 在每个测试方法之后执行的操作
        System.out.println("AfterEach: " + parameter);
    }

    @RegisterExtension
    static Extension extension = new Extension() {
        @Override
        public void beforeEach(ExtensionContext context) throws Exception {
            ParameterizedTest instance = (ParameterizedTest) context.getRequiredTestInstance();
            instance.beforeEach(context);
        }

        @Override
        public void afterEach(ExtensionContext context) throws Exception {
            ParameterizedTest instance = (ParameterizedTest) context.getRequiredTestInstance();
            instance.afterEach(context);
        }
    };

    @TestTemplate
    @ExtendWith(ParameterProvider.class)
    void parameterizedTest(String parameter) {
        // 参数化的测试方法
        System.out.println("Parameterized Test: " + parameter);
    }

    static class ParameterProvider implements TestTemplateInvocationContextProvider {
        @Override
        public boolean supportsTestTemplate(ExtensionContext context) {
            return true;
        }

        @Override
        public Stream<TestTemplateInvocationContext> provideTestTemplateInvocationContexts(ExtensionContext context) {
            List<String> parameters = Arrays.asList("param1", "param2", "param3"); // 这里示例使用固定的参数化值列表
            return parameters.stream().map(parameter ->
                    new TestTemplateInvocationContext() {
                        @Override
                        public String getDisplayName(int invocationIndex) {
                            return parameter;
                        }

                        @Override
                        public List<Extension> getAdditionalExtensions() {
                            return Collections.singletonList(extension);
                        }
                    });
        }
    }
}

在上面的示例代码中,我们创建了一个ParameterizedTest类,实现了BeforeEachCallbackAfterEachCallback接口,并定义了一个成员变量parameter来存储参数化的值。然后,我们创建了一个ParameterProvider类,实现了TestTemplateInvocationContextProvider接口,用于提供参数化的值。在ParameterProvider类中,我们定义了一个方法provideTestTemplateInvocationContexts来返回参数化的值列表,并在每个参数化的测试方法中执行相应的操作。最后,在测试类中使用@ExtendWith注解注册自定义的扩展,并使用@TestTemplate注解标记参数化的测试方法。

这样,我们就实现了在没有ParameterResolver的JUnit5中实现BeforeEach、AfterEach的参数化。

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

Spring学习笔记(二十八)——springboot单元测试&JUnit5

Spring Boot 2.2.0 版本开始引入 JUnit 5 作为单元测试默认库 作为最新版本的JUnit框架,JUnit5与之前版本的Junit框架有很大的不同。由三个不同子项目的几个不同模块组成。 JUnit 5 = JUnit Platform + JUnit Jupiter + JUnit Vintage * JUnit Platform: Junit Platform是在JVM上启动测试框架的基础,不仅支持Junit自制的测试引擎,其他测试引擎也都可以接入。 * JUnit Jupiter: JUnit Jupiter提供了JUnit5的新的编程模型,是JUnit5新特性的核心。内部 包含了一个测试引擎,用于在Junit Platform上运行。 * JUnit Vintage: 由于JUint已经发展多年,为了照顾老的项目,JUnit Vintage提供了兼容JUnit4.x,Junit3.x的测试引擎。

01
  • JUnit5基础教程

    JUnit5是Java的单元测试框架,用于测试Java程序代码。作为一名软件测试工程师,掌握JUnit是非常重要的。我们将从头开始,一步步学习JUnit5的用法。 一、准备工作 1. 在Maven项目中添加JUnit5依赖: <dependency> <groupId>org.junit.jupiter</groupId> <artifactId>junit-jupiter</artifactId> <version>5.7.0</version> <scope>test</scope> </dependency> 2. 创建测试类:使用@Test注解标注测试方法,测试类名通常以Test结尾,如:MathTests。 public class MathTests { @Test void addition() { } } 二、第一条测试用例 我们在addition()方法中使用assertEquals()断言两个值相等: @Test void addition() { assertEquals(2, 1 + 1); } 三、运行测试 右键测试类名,选择“Run 'MathTests'”运行测试类。JUnit将检测@Test注解方法,执行它们,并报告测试结果。 四、JUnit注解 JUnit提供了许多测试相关注解: - @Test:标注测试方法 - @BeforeEach:每个测试方法前执行 - @AfterEach:每个测试方法后执行 - @RepeatedTest:重复测试多次 - @Timeout:测试方法超时时间 - @Disabled:忽略测试方法 - 等等 五、断言 我们可以在测试方法中使用各种断言来验证预期结果: - assertEquals(expected, actual) 两个值相等 - assertTrue(condition) 条件为真 - assertNull(object) 对象为空 - assertThrows(exceptionType, executable) 执行代码抛出异常 - 等等 六、测试套件与测试分组 JUnit支持把多个相关测试组织在一起: - @Suite用于注解测试套件类 - @RunWith(Suite.class)用于启动测试套件 - @Categories用于给测试类或方法添加分类 - 然后可以在套件中包含指定分类的测试 七、参数化测试 使用@ValueSource等注解,可以运行同一测试逻辑针对不同输入。 希望此详细教程能够帮助初级工程师彻底掌握JUnit5的使用。请在学习或使用中遇到任何问题,随时与我讨论。

    02

    开发必备之单元测试

    ​ 计算机世界里的软件产品通常是由模块组合而成的 模块又可以分成诸多子模块。 比如淘宝系统由搜索模块、商品模块、交易模块等组成,而交易模块又分成下单模块、 支付模块、发货模块等子模块,如此细分下去,最终的子模块是由不可再分的程序单 元组成的。对这些程序单元的测试,即称为单元测试(Unit Testing ,简称单测)。单元的粒度要根据实际情况判定,可能是类、方法等,在面向对象编程中,通常认为最小单元就是方法。单元测试的目的是在集成测试和功能测试之前对软件中的可测试单 元进 逐一检查和验证。单元测试是程序功能的基本保障,是软件产品上线非常重要的环。

    01
    领券