@ParameterizedTest与@EnumSource怎么在Junit 5中使用

这期内容当中小编将会给大家带来有关@ParameterizedTest与@EnumSource怎么在Junit 5中使用,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。

概述

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

publicenumActivityLimitEnum{
LIMIT(1,"封顶"),
UNLIMIT(0,"上不封顶");
}

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

@Test
@DisplayName("封顶")
voidtestLimit(){
}
@Test
@DisplayName("不封顶")
voidtestUnLimit(){
}

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

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

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

我们用Intellij IDEA执行上面的单元测试,效果如下:

@ParameterizedTest与@EnumSource怎么在Junit 5中使用

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

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

@ParameterizedTest
@EnumSource(value=ActivityLimitEnum.class,names={"LIMIT"})
@DisplayName("封顶和不封顶")
voidtest(ActivityLimitEnumactivityLimitEnum){
if(ActivityLimitEnum.LIMIT.equals(activityLimitEnum)){
assertFalse(false);
}
elseif(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>

上述就是小编为大家分享的@ParameterizedTest与@EnumSource怎么在Junit 5中使用了,如果刚好有类似的疑惑,不妨参照上述分析进行理解。如果想知道更多相关知识,欢迎关注恰卡编程网行业资讯频道。

发布于 2021-03-26 01:50:21
收藏
分享
海报
0 条评论
156
上一篇:如何在IDEA中使用JRebel热部署插件 下一篇:如何在django中使用LDAP验证
目录

    0 条评论

    本站已关闭游客评论,请登录或者注册后再评论吧~

    忘记密码?

    图形验证码