赞
踩
本文为在霍格沃兹测试开发学社中学习到的一些技术,写出来分享给大家,希望有志同道合的小伙伴可以一起交流技术,一起进步~
Spring Boot 2.2.0 版本开始引入 JUnit 5 作为单元测试默认库;在 Spring Boot 2.2.0 版本之前,spring-boot-starter-test 包含了 JUnit 4 的依赖;
如何查看SpringBoot的版本:
public static void main(String[] args) {
String springVersion = SpringVersion.getVersion();
String springBootVersion = SpringBootVersion.getVersion();
}
运行结果:
Spring版本:5.3.18
SpringBoot版本:2.6.6
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>
<scope>test</scope>
</dependency>
但是但是, 在用junit5进行套件测试的时候发现报错无法识别 @RunWith(JUnitPlatform.class) ,我就意识到默认的依赖不全,所以直接果断引入依赖,如下:
<dependency>
<groupId>org.junit.jupiter</groupId>
<artifactId>junit-jupiter-engine</artifactId>
<version>5.6.2</version>
</dependency>
<dependency>
<groupId>org.junit.platform</groupId>
<artifactId>junit-platform-runner</artifactId>
<version>1.6.2</version>
</dependency>
表明一个测试方法
表明在所有测试方法执行之前执行的方法,且只执行一次
表明在所有测试方法执行之后执行的方法,且只执行一次
表明在每个测试方法执行之前都会执行的方法
表明在每个测试方法执行之后都会执行的风发
牢记junit5生命周期的洋葱模型
嵌套测试
测试类或者方法的显示名称
禁用测试类或者方法
额外重复执行
注解 | 作用 |
---|---|
@RunWith(JUnitPlatform.class) | 执行套件 |
@SelectPackage({“com.packageA”,“com.packageB”}) | 根据包-创建套件 |
@IncludePackage(“包名”) | 在套件中,过滤需要执行的测试包 |
@ExcludePackages(“包名”) | 在套件中,过滤剔除不需要执行的测试包 |
@SelectClasses( {a.class,b.class,c.class} ) | 根据类-创建套件 |
@IncludeClassNamePatterns(“类名”) | 在套件中,过滤需要执行的测试类 |
@ExcludeClassNamePatterns(“类名”) | 在套件中,过滤剔除不需要执行的测试类 |
@IncludeTags(“tag”) | 在套件中,过滤需要执行的测试方法 |
@ExcludeTags(“tag”) | 在套件中,过滤剔除不需要执行的测试方法 |
通过select来创建套件,通过包、类、和方法三个维度来选择需要执行的测试用例。所有条件是且的关系,求的是交集。
若交集为空,如下图效果:
若交集不为空,则执行匹配的用例:
使用classname进行匹配时,需要加上所在的包名(唉~ 好麻烦)
文末说明
推荐博文:接口测试经典面试题:Session、cookie、token有什么区别?
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。