配置文件
要想使用 Junit 进行单元测试需要引入以下第三方库:
引入后可以使用 @Test,@BeforeEach等注解
<!-- https://mvnrepository.com/artifact/org.junit.jupiter/junit-jupiter-api -->
<dependency>
<groupId>org.junit.jupiter</groupId>
<artifactId>junit-jupiter-api</artifactId>
<version>5.9.1</version>
<scope>test</scope>
</dependency>
引入后可以进行”参数化“
<!-- https://mvnrepository.com/artifact/org.junit.jupiter/junit-jupiter-params -->
<dependency>
<groupId>org.junit.jupiter</groupId>
<artifactId>junit-jupiter-params</artifactId>
<version>5.9.1</version>
<scope>test</scope>
</dependency>
引入后可管理测试用例,如 @Suite
<!-- https://mvnrepository.com/artifact/org.junit.platform/junit-platform-suite -->
<dependency>
<groupId>org.junit.platform</groupId>
<artifactId>junit-platform-suite</artifactId>
<version>1.9.1</version>
<scope>test</scope>
</dependency>
<!-- https://mvnrepository.com/artifact/org.junit.jupiter/junit-jupiter-engine -->
<dependency>
<groupId>org.junit.jupiter</groupId>
<artifactId>junit-jupiter-engine</artifactId>
<version>5.9.1</version>
<scope>test</scope>
</dependency>
注解
@Test 标注测试方法
public class JunitTest {
@Test //标注下面的方法是测试方法
public void test01(){
System.out.println("==========这是第一个测试用例==========");
}
@Test
public void test02(){
System.out.println("==========这是第二个测试用例==========");
}
}
@BeforeAll 和 @AfterAll 标注在测试之前和之后执行的方法
@BeforeAll
static void Start(){
System.out.println("********** 测试开始 **********");
}
@AfterAll
static void End(){
System.out.println("********** 测试结束 **********");
}
@BeforeEach 和 @AfterEach 标注在每条测试之前和之后执行的方法
@BeforeEach
public void startEach(){
System.out.println("********** 测试开始 **********");
}
@AfterEach
public void endEach(){
System.out.println("********** 测试结束 **********");
}
@TestMethodOrder 和 @Order(优先级) 标注测试方法的执行顺序
如下代码设置 test01 的执行优先级为 2 小于 test02 的执行优先级 1,所以 test02 测试方法先执行,其次才是 test01 方法
// @TestMethodOrder 指定用哪个方法来进行测试方法排序
//MethodOrderer.OrderAnnotation.class 表示用注解排序测试方法
@TestMethodOrder(MethodOrderer.OrderAnnotation.class)
public class JunitTest {
//设置测试方法执行的优先级,2 的优先级小于 1
@Order(2)
//标注下面的方法是测试方法
@Test
public void test01(){
System.out.println("==========这是第一个测试用例==========");
}
@Order(1)
@Test
public void test02(){
System.out.println("==========这是第二个测试用例==========");
}
}
@ParameterizedTest 将测试方法参数化
注意:使用 @ParameterizedTest 注解就已经代表该方法是一个测试方法,不需要再使用 @Test 方法,否则会报错
@ValueSource 单参数
如下代码,会依次将 @ValueSource 注解中定义的整数作为参数依次传入 test03 方法中
//将测试方法参数化
@ParameterizedTest
//设置参数的数据源,只支持一个参数
@ValueSource(ints = {1,2,3,4})
public void test03(int x){
System.out.println(x);
}
@CsvSource 多参数
如下代码,会依次将 @CsvSource 注解中定义的多组数据作为参数依次传入 test04 方法中
@ParameterizedTest
//设置参数的数据源,支持多个参数
@CsvSource({"雨林, 20","小菊,22"})
void test04(String name,int age){
System.out.println("name:"+name+" age:"+age);
}
@CsvFileSource 通过文件传递多参数
test05.txt 文件内容
张三,28
李四,19
王五,20
如下代码,以 test05.txt 文件中的数据作为参数,传入 test05 测试方法中
@ParameterizedTest
//通过文件传递多参数
@CsvFileSource(resources = "test05.txt")
void test05(String name,int age){
System.out.println("name:"+name+" age:"+age);
}
注意,如果该测试方法在包中,那么 test05.txt 文件也要放到相同名称的包中
如下图,测试方法在 example 包中
将 test05.txt 文件放到 resources 的 example 包中
@MethodSource 通过方法传递多参数
如下代码,以 Generate 方法中定义的数据作为参数,传入 test06 测试方法中
@ParameterizedTest
//通过方法传递参数
@MethodSource("Generate")
void test06(String name,int age){
System.out.println("name:"+name+" age:"+age);
}
Generate 方法
public static Stream<Arguments> Generate() {
return Stream.of(Arguments.arguments("张三",18),
Arguments.arguments("李四",20));
}
@Suite 测试套件(管理测试顺序)
测试套件,用于管理测试顺序(有许多类和包都用于测试,要管理它们的执行顺序)
@SelectClasses 管理测试类的执行顺序
//测试套件,用于管理测试顺序(有许多类和包都用于测试,要管理它们的执行顺序)
@Suite
//管理测试类的执行顺序
@SelectClasses({JunitTest.class,JunitTest1.class})
public class RunTest {
}
如下图,先执行 JunitTest,再执行 JunitTest1
@SelectPackages 管理包的执行顺序
//测试套件,用于管理测试顺序(有许多类和包都用于测试,要管理它们的执行顺序)
@Suite
//管理测试包的执行顺序
@SelectPackages(value = {"example"})
public class RunTest {
}
如下图,执行了 example 包下的 JunitTest