本篇我们学习junit5的基础知识和常用方法/注解
文章目录
什么是Junit
前篇我们学习了Selenium,Selenium是一个自动化的测试框架,而本篇学的Junit是一个单元测试框架
有什么区别呢?
拿着一个技术写自动化测试用例(Selenium3)
拿着一个技术管理编写好的测试用例(Junit5)
Junit是针对java的单元测试框架
Junit的依赖添加
在使用前先进行依赖注入,在maven中央搜素junit,maven仓库地址进行复制,添加依赖到pom.xml中。
junit 5.9.1的代码示例:
<!-- 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>
Junit常用注解
@Test
通过这个表示当前这个方法是一个测试用例
@Disabled
对测试用例进行忽略
@BefoerAll,@AfterAll,@BeforeEach,@AfterEach
@BefoerAll最开始执行:初始化,创建驱动,打开
@AfterAl最后执行:关闭程序,浏览器
@BefoerAll在所有测试用例运行前执行对应的方法
@BeforeEach是在每一个测试用例执行前执行对应的方法
@AfterAl在所有测试用例运行后执行对应的方法
@AfterEach是在每一个测试用例执行后执行对应的方法
断言
在测试中,断言用于验证测试结果是否符合预期。
断言分为:断言相等、断言不相等、断言为空、断言不为空
使用assertArrayEquals进行判断
代码示例:
前面是预期,后面是执行结果
@ParameterizedTest
@ValueSource(ints = {1})
void Test4(int num){
System.out.println(num);
Assertions.assertArrayEquals(new int[]{1}, new int[]{num});断言相等
Assertions.assertNotEquals(1,num);//断言不相等
String str = "null";
Assertions.assertNotNull(str);//断言不为空
Assertions.assertNull(str);//断言为空
}
测试用例的执行顺序
添加一个注释,同时设置执行顺序
如果不添加测试顺序,就会按照自己的算法进行运行
按照顺序执行
使用@TestMethodOrder(MethodOrderer.OrderAnnotation.class)+ @Order(1)
@TestMethodOrder(MethodOrderer.OrderAnnotation.class)
public class junitTest {
@Order(1)
@Test
public void Test1(){
System.out.println("这是一个Junit的测试1");
}
```## 随机执行
添加注解,随机执行测试用例
```java
@TestMethodOrder(MethodOrderer.Random.class)
测试套件
测试套件通过添加注解@Suite实现
通过class运行测试用例
使用注解@SelectClasses实现
代码示例:
@Suite
@SelectClasses({junTest.class,junitTest.class})//会按照写的文件顺序进行测试,一个测试完一个测试
通过包运行测试用例
使用注解@SelectPackages实现
代码示例:
@Suite
@SelectPackages(value = {"Test001","Test002"})//会按照包的顺序进行执行
参数化
参数化设置同样需要添加依赖,maven仓库,搜索Parameterized,复制,粘贴(需要与junit版本一致),至pom.xml文件。
以下为示例:
<!-- 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>
参数化使用注解@ParameterizedTest进行实现
单参数
单参数实现使用注解@ValueSource()进行实现
代码示例:
@ParameterizedTest
@ValueSource(ints = {1,2,3,})
public void Test4(int num){
System.out.println(num);
}
多参数
多参数的实现方式有两种
@CsvSource(value=)
这种实现使用注解@CsvSource()实现
代码示例
@ParameterizedTest
@CsvSource({"1,2,3"})
void Test55 (String x,String y,int z){
System.out.println(x);
System.out.println(y);
System.out.println(z);
}
@CsvFileSource(files/resources = “”)
使用CSV获取参数,但是需要创建响应的文件
使用注解@CsvFileSource()实现
代码示例:
@ParameterizedTest
@CsvFileSource(resources = "test11.csv")
void test6(String name){
System.out.println(name);
}
动态参数
使用方法获取参数,需要创建方法进行引入
使用注解@MethodSource()实现
代码示例:
public static Stream<Arguments> Generator() {
return Stream.of(Arguments.arguments(1,"张三"),
Arguments.arguments(2,"李四"),
Arguments.arguments(3,"王五"));
}
@ParameterizedTest
@MethodSource("Generator")
void Test7(int num , String name){
System.out.println(num + ":" + name);
}