测试员进阶技能:如何有效地利用单元测试报告?
为什么需要单元测试?
从产品角度而言,常规的功能测试、系统测试都是站在产品局部或全局功能进行测试,能够很好地与用户的需要相结合,但是缺乏了对产品研发细节(特别是代码细节的理解)。
从测试人员角度而言,功能测试和系统测试以及其他性能测试等等对测试人员的全局特性理解能力要求较高,只要测试人员能够掌握一两种自动化测试框架基本能够开展功能、性能自动化测试,但是借助于测试框架进行研发降低了测试人员对代码的掌握、理解要求。
从开发人员角度而言,用户需求往往并不是具体的、全面的,因此基于用户需求转换成开发文档或着针对某个功能编写开发代码往往也存在着局限性(也即我们常说的bug)。
因此,编写单元测试可以帮助测试人员更好地理解代码细节、提高代码开发能力,也能帮助开发人员提前辨识代码中可能存在的bug,提高代码的容错能力。
如何制定单元测试报告
良好的单元测试报告能够帮助测试人员更好地分析、挖掘潜藏的问题。那么,如何制定单元测试报告呢,从哪些维度出发呢?在这里我们主要从测试人员角度出发来思考这个问题。
- 首先,我们需要报告中能够呈现我们的测试用例数量和测试结果(pass或者fail),以及错误细节。
- 其次,从单元测试本身特点出发,我们需要报告中能够呈现出针对单元代码分支、单元方法等的覆盖率,更好地帮助我们梳理和测试用例设计的优良。
在此,我们使用surefire-report统计测试用例数量和测试结果,使用jacoco统计单元测覆盖率(注:本文默认测试用例的执行方式是mvn test)。
如何配置 surefire-report 和 jacoco ·surefire-report 配置
配置方法:配置 maven-surefire-plugin 插件,maven-surefire-plugin 是 maven 默认的 test
执行器,配置方法如下图所示:
上图中 testFailureIgnore 表示忽略单元测试中的错误继续构建,<include>**/*Test.java</include> :表示任何子目录下所有命名以 Test 结尾的 Java 类,<exclude> **/Test*.java </exclude> :表示不执行任何子目录下所有命名以 Test 开头的Java 类。
执行方法:使用 mvn test surefire-report:report 即可,会生成在/target/site/surefire-report.html 测试报告文档。如下图所示:Tests 显示总用例数;Errors 指的是程序没有考虑到的情况,例如异常未能捕捉;Failure 指的是预期的结果与实际运行单元的结果不同所导致,常出现在断言处;Skipped 表示跳过的测试用例数;Success Rate表示用例成功率(=成功用例数/总用例数);Time 显示总耗时。Package List 显示详细的package 下用例执行结果。
·jacoco 配置
配置方法:配置 jacoco-maven-plugin 插件,配置方法如下图所示,phase 表示插件运行的生命周期阶段。
执行方法:mvn test 执行即可。会在/target/site/jacoco/目录下生成总的覆盖率报告index.html 和不同 package 的单元测试覆盖率报告../xxx/index.html。此外还有 csv 和 xml格式的单元测试覆盖率报告。
如上图所示为某个 package 的单元测试覆盖率报告。红色进度条表未覆盖,绿色进度条表示已覆盖,Cov 为总体覆盖率。missed Instructions 表示代码覆盖率,Missed Branches表示逻辑分支覆盖率,Missed Cxty 表示判断执行数,missed Lines 表示代码行数,Methods表示方法个数。
- 推荐12个开源的跨平台桌面项目
- 为什么kafka性能下降这么快,我用RocketMQ的时候不会这样子
- iOS16新功能被曝耗电严重,暂时别用了!
- 我所知道的webpack5那些不太一样的改变
- 谈谈你对Kafka副本Leader选举原理的理解?
- 这样Debug,排查问题效率大大提升
- 将你的 Python 脚本转换为命令行程序
- MyBatis批量插入几千条数据慎用foreach
- 低代码平台能提升开发效率吗?
- 自定义的配置文件,如何注入到SpringBoot?
- 一个能干掉90%候选人的Kafka面试连环炮
- ThreadLocal 你真的用不上吗?
- Java中容器设计的进化史:从白盒到黑盒,再到跻身为设计模式之一的迭代器
- 浅谈自旋锁和JVM对锁的优化
- 手把手教你实现一个常用的 antd form 组件
- .NET开发框架优缺点剖析
- Python中的Deque: 实现高效的队列和堆栈
- 信息架构如何设计?5000字干货帮你快速掌握!
- C 进阶教程:C 标准模板库初学者指南
- 导致Spring事务失效的原因有哪些?