Junit 5中@ParameterizedTest结合@EnumSource

概述


有时候业务代码里会根据一个枚举值来区分业务场景,比如说:

public enum ActivityLimitEnum {
    LIMIT(1,"封顶"),
    UNLIMIT(0,"上不封顶");
}

如果编写单元测试来验证业务代码,至少需要写两个测试方法,一个验收封顶逻辑,一个验收不封顶逻辑。

@Test
    @DisplayName("封顶")
    void testLimit() {
        
    }

    @Test
    @DisplayName("不封顶")
    void testUnLimit() {

    }

由于这两个场景只是区分封顶和不封顶,其他的都是一样的,如果写两个测试方法,testLimittestUnLimit方法里会有很多重复代码。这个时候Junit 5@ParameterizedTest@EnumSource就可以派上用场了。

    @ParameterizedTest
    @EnumSource(ActivityLimitEnum.class)
    @DisplayName("封顶和不封顶")
    void test(ActivityLimitEnum activityLimitEnum) {
        if (ActivityLimitEnum.LIMIT.equals(activityLimitEnum)) {
            assertFalse(false);
        } 
        else if (ActivityLimitEnum.UNLIMIT.equals(activityLimitEnum)) {
            assertTrue(true);
        }
    }

Junit 5在执行上面的test方法的时候,由于ActivityLimitEnum中有LIMITUNLIMIT两个枚举,先按照LIMIT类型执行一次test方法,再按照UNLIMIT类型再次执行test方法,共执行两次test方法,因此我们需要在test方法里,区分一下类型,按照实际情况编写assert代码进行验证即可。

我们用Intellij IDEA执行上面的单元测试,效果如下:
在这里插入图片描述

可以看到test方法确实执行了两次,LIMITUNLIMIT各执行一次。

如果枚举中的枚举值非常多,而单元测试里只是想验证其中部分枚举值,那可以用下面的方式:

    @ParameterizedTest
    @EnumSource(value = ActivityLimitEnum.class,names = {"LIMIT"})
    @DisplayName("封顶和不封顶")
    void test(ActivityLimitEnum activityLimitEnum) {
        if (ActivityLimitEnum.LIMIT.equals(activityLimitEnum)) {
            assertFalse(false);
        }
        else if (ActivityLimitEnum.UNLIMIT.equals(activityLimitEnum)) {
            assertTrue(true);
        }
    }

这样就只会执行LIMIT枚举值对应的场景。

如果要在Junit 5里使用@ParameterizedTest@EnumSource,需要添加如下依赖:

<dependency>
    <groupId>org.junit.jupiter</groupId>
    <artifactId>junit-jupiter-params</artifactId>
    <version>5.2.0</version>
    <scope>test</scope>
</dependency>
Sam哥哥 CSDN认证博客专家 项目管理 团队管理 总结和思考
喜欢研究和思考关于管理、领导力,流程、文化、人、效率,沟通、成本、执行的东西,因为这些因素跟【能否把事情真正做好】强相关。
已标记关键词 清除标记
©️2020 CSDN 皮肤主题: 大白 设计师:CSDN官方博客 返回首页