开启掘金成长之旅!这是我参与「掘金日新计划 · 12 月更文挑战」的第三十天,点击查看活动详情
一、代码覆盖率
通常我们在做单元测试的时候会接触到代码覆盖率的概念,通过在单元测试的过程中收集代码覆盖率去判断测试用 例是否充分,去更精准的定位问题。而对于功能测试或者接口测试比较少的去关注覆盖率数据,功能测试时覆盖率 的收集也是比较困难的。然后对于功能测试而言进行代码覆盖率的收集有利于测试工程师去判断哪些分支没有被覆 盖,判断是否是设计用例的时候没有做到覆盖,又或者是由于存在bug使得无法覆盖到,从而更精准的去定位bug的 位置,去分析问题,节省时间。
二、工具简介
对于java的代码覆盖率的收集,比较常用的工具有emma、jacoco,它们都是免费的代码覆盖率工具。emma目前已 经不维护,EclEmma团队推出了jacoco,jacoco可以理解为emma的升级版本。Jacoco可以跟ant、maven、gradle 等集成,降低了使用成本,使用更灵活;同时它还引入了监控机制,通过JJavaAgent技术监控Java程序。Jacoco 还可以更第三方平台进行集成,比如sonar、jenkins,通过第三方平台更友好的将覆盖率数据在web端展示。
二、Java Counters
Jacoco提供了多维度的覆盖率统计方法,包含指令级(Instructions,COcoverage)覆盖,分支(Branches,C1coverag e)覆盖、类(classes)覆盖、方法(non-abstract methods)覆盖、行(Lines)覆盖。同时还提供圈复杂度(CyclomaticC omplexity)的统计,它会去计算每个类,方法的圈复杂度,根据McCabe1996的定义,圈复杂度可以理解为覆盖所 有的可能情况最少使用的测试用例数,同时圈复杂度越高意味着程序越复杂,发生bug的概率越大。
2.1 Instructions
Jacoco在统计覆盖率时最小的统计单位就是字节码指令。通过指令覆盖率统计的是所有的指令哪些被执行了哪些没 有被执行,从而得出统计数据。这项规则完全独立于源码格式并且且在任何情况下有效,不需要类文件的调试信息。
2.2 Branches
Jacoco对所有的if...else...和switch...case...指令计算了分支覆盖率。分支覆盖会去统计程序中所有的分支数量,并 统计哪些被执行哪些没有被执行,从而得出有效的覆盖率数据
2.3 Classes
类覆盖是收集类的统计数据,计算中每个类中只要有一个方法被执行,这个类就被认定为被执行,那么它的覆盖率 就是100%。
2.4 Methods
方法覆盖是收集类中的方法的覆盖率,通常一个非抽象方法都至少有一条指令,只要改方法中有一行被执行,该统다. 计规则就认为他被执行了,该方法的覆盖率就是100%。
2.5 Lines
行覆盖,统计每行代码的覆盖率,只有当每一行代码都被执行到了才会是100%,理论上保证100%的覆盖率就能保 证程序不会有bug。