一:前言
分析未覆盖部分的代码,从而反推在前期测试设计是否充分?
没有覆盖到的代码是否是测试设计的盲点?为什么没有考虑到?
需求/设计不够清晰?测试设计的理解有误?
以上的相关问题相信身为测试人员大家都遇到过这种窘境.......往往造成系统某些功能的策略性放弃或之后进行补充测试用例设计。
作为一个合格的测试人员,保证产品的软件质量是其工作首要目标,为了这个目标,测试人员常常会通过很多手段或工具来加以保证,覆盖率就是其中一环比较重要的环节。
通常我们会将测试覆盖率分为两个部分,需求覆盖率、代码覆盖率。
需求覆盖:
指的是测试人员对需求的了解程度,根据需求的可测试性来拆分成各个子需求点,来编写相应的测试用例,最终建立一个需求和用例的映射关系,以用例的测试结果来验证需求的实现,可以理解为黑盒覆盖。
代码覆盖:
为了更加全面的覆盖,我们可能还需要理解被测程序的逻辑,需要考虑到每个函数的输入与输出,逻辑分支代码的执行情况,这个时候我们的测试执行情况就以代码覆盖率来衡量,可以理解为白盒覆盖。
以上两者完全可以相辅相成,用代码覆盖结果反向的检查需求覆盖(用例)的测试是否充分完整。
代码覆盖率不仅检测出程序中的废代码,还可以逆向反推在代码设计中思维混乱点,提醒设计/开发人员理清代码逻辑关系,提升代码质量。
代码覆盖率高不能说明代码质量高,但是反过来看,代码覆盖率低,代码质量不会高到哪里去,可以作为测试自我审视的重要工具之一。
二:Jacoco简介
Jacoco全称JavaCodeCoverage,是一个开源的,统计JAVA代码覆盖率的工具。
那什么是代码覆盖?为了更加全面的覆盖,我们可能还需要理解被测程序的逻辑,需要考虑到每个函数的输入与输出,逻辑分支代码的执行情况,这个时候我们的测试执行情况就以代码覆盖率来衡量,可以理解为白盒覆盖。
市场上java主要代码覆盖率工具:EMMA、JaCoCo。
JaCoCo优势:
(1)JaCoCo支持分支覆盖、引入了Agent模式。
(2)EMMA官网已经不维护了,JaCoCo是其团队开发的,可以理解为一个升级版。
(3)JaCoCo社区比较活跃,官网也在不断的维护更新。
Jacoco官网地址:EclEmma - JaCoCo Java Code Coverage Library。
Jacoco官方文档:https://www.jacoco.org/jacoco/trunk/doc/flow.html。
Jacoco是一个开源的覆盖率工具。Jacoco可以嵌入到Ant 、Maven中,并提供了EclEmma Eclipse插件,也可以使用JavaAgent技术监控Java程序。很多第三方的工具提供了对Jacoco的集成,如sonar、Jenkins等。
三:Jacoco覆盖指标基本概念
Jacoco包含了多种尺度的覆盖率计数器,包含指令级覆盖(Instructions,C0coverage),分支(Branches,C1coverage)、圈复杂度(CyclomaticComplexity)、行覆盖(Lines)、方法覆盖(non-abstract methods)、类覆盖(classes)。