代码覆盖率之jacoco

代码覆盖率

在做单元测试时,代码覆盖率常常被拿来作为衡量测试好坏的指标,甚至,用代码覆盖率来考核测试任务完成情况,比如,代码覆盖率必须达到80%或 90%。

JaCoCo

Jacoco从多种角度对代码进行了分析,包括指令(Instructions,C0 Coverage),分支(Branches,C1 Coverage),圈复杂度(Cyclomatic Complexity),行(Lines),方法(Methods),类(Classes)。

1. Instructions

Jacoco计算的最小单位就是字节码指令。指令覆盖率表明了在所有的指令中,哪些被指令过以及哪些没有被执行。这项指数完全独立于源码格式并且在任何情况下有效,不需要类文件的调试信息。

2. Branches

Jacoco对所有的if和switch指令计算了分支覆盖率。这项指标会统计所有的分支数量,并同时支出哪些分支被执行,哪些分支没有被执行。这项指标也在任何情况都有效。异常处理不考虑在分支范围内。
在有调试信息的情况下,分支点可以被映射到源码中的每一行,并且被高亮表示。

红色钻石:无覆盖,没有分支被执行。
黄色钻石:部分覆盖,部分分支被执行。
绿色钻石:全覆盖,所有分支被执行。

3. Cyclomatic Complexity

Jacoco为每个非抽象方法计算圈复杂度,并也会计算每个类,包,组的复杂度。根据McCabe1996的定义,圈复杂度可以理解为覆盖所有的可能情况最少使用的测试用例数。这项参数也在任何情况下有效。

4. Lines

该项指数在有调试信息的情况下计算。因为每一行代码可能会产生若干条字节码指令,所以我们用三种不同状态表示行覆盖率

红色背景:无覆盖,该行的所有指令均无执行。
黄色背景:部分覆盖,该行部分指令被执行。
绿色背景:全覆盖,该行所有指令被执行。

5. Methods

每一个非抽象方法都至少有一条指令。若一个方法至少被执行了一条指令,就认为它被执行过。因为JaCoco直接对字节码进行操作,所以有些方法没有在源码显示(比如某些构造方法和由编译器自动生成的方法)也会被计入在内。

6. Classes

每个类中只要有一个方法被执行,这个类就被认定为被执行。同5一样,有些没有在源码声明的方法被执行,也认定该类被执行。

JaCoCo原理

参考网址:http://www.open-open.com/lib/view/open1472174544246.html
其中包含了注入探针以及修改字节码的相关原理。

与maven集成

<plugin>
        <groupId>org.jacoco</groupId>
        <artifactId>jacoco-maven-plugin</artifactId>
        <version>0.7.7.201606060606</version>
    <configuration>
        <destFile>target/coverage-reports/jacoco-unit.exec</destFile>
        <dataFile>target/coverage-reports/jacoco-unit.exec</dataFile>
    </configuration>
    <executions>
        <execution>
            <id>jacoco-initialize</id>
            <goals>
                <goal>prepare-agent</goal>
            </goals>
        </execution>
        <execution>
            <id>jacoco-site</id>
            <phase>package</phase>           
            <goals>
                <goal>report</goal>
            </goals>
        </execution>
    </executions>
</plugin>

实例解析

在经过与maven集成之后,生成的report文件在site/jacoco下,点开index.xml,即可查看生成报告。
包视图:


Package

类视图:


class

方法视图:
method

代码视图:


source code


以上三个表每个表都包含了五项指标数据。
代码视图中,背景色代表的含义上文已经提到。
宝石的颜色代表分支覆盖率,鼠标移动到黄色宝石上,将会提示如“1 of 2 branches missed”,对于“name==null”,有true和false两种分支,这说明程序只执行了一种分支。绿色宝石“All 2 branches covered”。红色宝石“All 2 branches missed”。

      </div>
  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Jacoco(Java Code Coverage)是一个用于衡量代码覆盖率的工具。它可以帮助开发人员分析代码的测试覆盖情况,从而提供关于测试质量和代码可靠性的指标。 要使用Jacoco来计算代码覆盖率,你需要在项目中集成Jacoco插件并进行配置。具体步骤如下: 1. 在项目的构建文件(如pom.xml或build.gradle)中添加Jacoco插件的依赖。 对于Maven项目,添加以下代码到pom.xml文件中: ```xml <build> <plugins> <plugin> <groupId>org.jacoco</groupId> <artifactId>jacoco-maven-plugin</artifactId> <version>0.8.7</version> <executions> <execution> <goals> <goal>prepare-agent</goal> </goals> </execution> <execution> <id>report</id> <phase>test</phase> <goals> <goal>report</goal> </goals> </execution> </executions> </plugin> </plugins> </build> ``` 对于Gradle项目,添加以下代码到build.gradle文件中: ```groovy plugins { id 'jacoco' } jacoco { toolVersion = "0.8.7" } test { jacoco { append = false destinationFile = file("$buildDir/jacoco/test.exec") } } ``` 2. 运行项目的测试套件,生成Jacoco的覆盖率数据。 使用命令行或者IDE工具运行项目的测试套件,Jacoco会在测试过程中收集代码覆盖率数据。默认情况下,Jacoco会将数据保存在项目的`target`目录下(Maven项目)或者`build`目录下(Gradle项目)。 3. 生成代码覆盖率报告。 运行以下命令来生成代码覆盖率报告: ```shell mvn jacoco:report ``` 或者 ```shell gradle jacocoTestReport ``` 生成的报告会显示代码的覆盖率情况,包括行覆盖率、分支覆盖率、类覆盖率等指标。你可以在报告中查看哪些代码被测试覆盖,哪些代码没有被覆盖到。 希望这能帮助到你!如果有更多关于Jacoco或其他开发工具的问题,请继续提问。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值