一.了解junit
junit是一个开源的java单元测试框架,java方向使用最广泛的单元测试框架.
所需要的依赖
<dependencies>
<!-- https://mvnrepository.com/artifact/org.seleniumhq.selenium/selenium-java -->
<dependency>
<groupId>org.seleniumhq.selenium</groupId>
<artifactId>selenium-java</artifactId>
<version>4.0.0-alpha-7</version>
</dependency>
<dependency>
<groupId>commons-io</groupId>
<artifactId>commons-io</artifactId>
<version>2.6</version>
</dependency>
<dependency>
<groupId>org.junit.jupiter</groupId>
<artifactId>junit-jupiter</artifactId>
<version>5.8.2</version>
<scope>test</scope>
</dependency>
<dependency>
<groupId>org.junit.platform</groupId>
<artifactId>junit-platform-suite</artifactId>
<version>1.8.2</version>
<scope>test</scope>
</dependency>
<dependency>
<groupId>org.junit.platform</groupId>
<artifactId>junit-platform-reporting</artifactId>
<version>1.8.2</version>
<scope>test</scope>
</dependency>
</dependencies>
二,注解
1.@Test表示
这是一个方法/一个用例
data:image/s3,"s3://crabby-images/c107f/c107f14dc0b9b0899b6814a82efe76f6f5d1f9fc" alt=""
但是他的顺序是不固定的.我们需要指定顺序
2.@BeforeEach/@BeforeAll
@BeforeEach表示被注解的方法执行前都要执行一遍
data:image/s3,"s3://crabby-images/19758/19758800c448c8564f7644a58cbc55360af4d7b3" alt=""
注意只要@BeforeEach就行
否则就会先执行aaa然后因为需要先执行一遍aaa然后再执行一遍aaa再往下执行bbb
data:image/s3,"s3://crabby-images/75879/75879bd855c7f0fecb48bfa5b0133304ef327cf9" alt=""
@BeforeAll:所有方法之前执行一次
注意:被BeforeAll需要用static方法
data:image/s3,"s3://crabby-images/60119/60119e1ab0e6623d23bf1d7bb61e7ac8b2566f87" alt=""
3.@AfterEach/@AfterAll
@AfterEach 其他方法执行后都要执行一遍
data:image/s3,"s3://crabby-images/b4d72/b4d720ea8361254bfd7134a01f3f993422d38719" alt=""
注意只有被ALL修饰的才要static 其他的都不能用static
data:image/s3,"s3://crabby-images/6a993/6a993de6b2b7b8f5fc32f4837cd5d4e1d337cc73" alt=""
@AfterALL同理
三.断言
写自动化测试要么是正确的要么是错误的,不能因为错误就停止所有程序,所以需要断言
junit提供了一组Assertions类来编写
data:image/s3,"s3://crabby-images/77a24/77a245e11884abfdf9a3e26458b66784740ec127" alt=""
1. Assertions.assertEquals(expect,actual)
校验期望值和实际值是否匹配
data:image/s3,"s3://crabby-images/2aa10/2aa105d862ffbd0101703819bbbca5f935c9ca5d" alt=""
data:image/s3,"s3://crabby-images/13adb/13adb4dbd96b3924dc0a82a1d30349d8e3aec300" alt=""
2.Assertions.assertNotEquals(Expect,actual)
检验是否不匹配
data:image/s3,"s3://crabby-images/66b48/66b482af22bd3f48846d2efa43ebaf70776ed639" alt=""
3.Assertions.assertTrue()/Assertions.assertFalse()
参数是表达式,结果是boolean类型
data:image/s3,"s3://crabby-images/a1620/a162032bd269c173004645f2e80c9b81a6287709" alt=""
4.assertNull()/assertNotNull()
检验是否为空
data:image/s3,"s3://crabby-images/c6464/c646495a54bc5f6b4fdafe42625d3be51900ad79" alt=""
data:image/s3,"s3://crabby-images/d2ad4/d2ad4feb289624e42d3a88259d28d87df31bdfe2" alt=""
data:image/s3,"s3://crabby-images/4e110/4e110531053daeec5484dc726964eb169ba527a9" alt=""
四.用例执行顺序
juit的默认执行顺序是不确定的.官方文档没有明确指出
我们仍然可以使用junit里提供的方法来手动设置用例的方法
通过方法排序---通过-@order注解来排序
第一步.在类外标注当前类使用方法来进行排序
data:image/s3,"s3://crabby-images/033e9/033e976854a5e80be2375aa94aaf857a0150bede" alt=""
第二步在每个注解下标注顺序
data:image/s3,"s3://crabby-images/749b1/749b1ff95201b348ca6f59477c6ba97bff3c4ea6" alt=""
data:image/s3,"s3://crabby-images/f46cd/f46cd76239d10675206854994b2100bb81a0025e" alt=""
如果被static修饰,就直接无视,没有排序了
data:image/s3,"s3://crabby-images/fff00/fff00aa02fa52eac7fb517d57bd7e660f9e636f8" alt=""
无视原有的After Before
面试问题:为什么需要用到junit里的排序方法
junit里的方法有方法顺序排序,标签排序
首先会把方法的类定义在类外声明当前类类用方法进行排序
然后类里明确标注具体的执行顺序
如果用例之间存在关联关系,那么就需要手动指定用例的执行顺序
但是我们再编写测试用例的时候进行保持用例的独立性
五.测试套件suite
1.指定对应的的类 添加到套件执行
先创建一个专门的类来进行运行.把同一个包里要运行的类放在一起
data:image/s3,"s3://crabby-images/8fcc2/8fcc2a141d51ab9fc9967edec5b891977aa8c59f" alt=""
注意:
包下必须有命名包含Test\tests的文件 并且有对应的执行注解,否则则会提示找不到对应的用例
data:image/s3,"s3://crabby-images/cdc61/cdc61f1a7f3295bbb7dd17983cd256b8e142be83" alt=""
2)指定包.添加到套件中执行
data:image/s3,"s3://crabby-images/1b6be/1b6be29a3c6b8e60a4214d66eb33c694d2172a4e" alt=""
注定必须在同一个包下进行测试
六. 参数化
@Parameterizedtest 标注方法类型为参数化
不需要再添加@Test注解,如果添加了,则用例则会多执行一遍
1.单参数
@ValueSource(类型={参数1,参数2...})
其中的类型 对应原生类型,int->ints float->floats
data:image/s3,"s3://crabby-images/35795/35795711b800db0b5aedd9756cfd3dec7a8ea4d2" alt=""
data:image/s3,"s3://crabby-images/95c56/95c56767b92fe9264cf6076d5c36fd74ef1c69f8" alt=""
2.多参数
@CsvSource
data:image/s3,"s3://crabby-images/f5268/f52683bb9c9b997e306d54e49c608646cb80c6bc" alt=""
data:image/s3,"s3://crabby-images/9859d/9859dcbe10664d1a34d60ca2452973e31d72dae5" alt=""
注意就算多个方法指定来源,都要同时用参数注解(@ParameterizedTest)注明
data:image/s3,"s3://crabby-images/9aaca/9aacab977eabde4e58442a451519dc8073b90677" alt=""
手动指定分隔符
用delimiterString
data:image/s3,"s3://crabby-images/b5942/b5942a850221992775999c1381c3f471dab1074b" alt=""
如果参数中含逗号,要么指定分隔符,要么就用单引号' ' 作为转义字符
data:image/s3,"s3://crabby-images/7208a/7208aa7278524a1a3b89f7616cda3a107497a691" alt=""
3.指定文件路径.csv
如果参数非常多,在代码中编写不太好看.可以借助文件注入的方式来添加
@CsvSource(指定文件路径)
data:image/s3,"s3://crabby-images/a6e01/a6e016260ec3753f35a3c949c27edb443512d6f9" alt=""
相对路径下 一定要在前加上 /
data:image/s3,"s3://crabby-images/491b1/491b17d2764251820924789a992d615f9cb76d8d" alt=""
绝对路径不用加
4.动态参数
4.1单参数
@MathodSource("")参数为数据来源的方法名,如果不指定数据来源.则默认找用例同名的静态方法
提供数据的方法,返回值是Stream流
data:image/s3,"s3://crabby-images/9fae6/9fae6a86e0b9697ee348d9d34c5869e2c4f97260" alt=""
4.2多参数
返回多参树用Argurment类
data:image/s3,"s3://crabby-images/39e63/39e63595ba0572877c2673a3b27b4a4d33b48224" alt=""
七.执行屏幕截图
data:image/s3,"s3://crabby-images/d22e9/d22e98d1fec1b152fe4b871a7c8c59cf636092cc" alt=""
加路径的时候要加上要保存的名字
data:image/s3,"s3://crabby-images/543e9/543e9705d62ecd95e7d9f84d06bff04e64913f5a" alt=""
data:image/s3,"s3://crabby-images/70a93/70a9343432950a3d17289cecf287d354a5715765" alt=""