代码测试覆盖率检查——jacoco

Jacoco是Java的代码测试覆盖率检查工具,提供了Maven插件。在Maven项目中,可在pom文件配置代码覆盖率、指定exec文件路径等。同时介绍了Jacoco报告表头含义,如指令、分支等覆盖率。此外,GitLab可配合Jacoco测试报告获取覆盖率数据,还能设置检查的正则表达式。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

jacoco是java的代码测试覆盖率检查工具,并且提供了maven插件,可以直接在maven中使用。并且gitlab中也提供了coverage图标可以通过设置拿到Jacoco测试覆盖率的报告。

maven项目中使用

maven的pom文件的配置:

<plugin>
    <groupId>org.jacoco</groupId>
    <artifactId>jacoco-maven-plugin</artifactId>
    <version>0.8.4</version>
    <configuration>
        <destFile>target/coverage-reports/jacoco-unit.exec</destFile>
        <dataFile>target/coverage-reports/jacoco-unit.exec</dataFile>
        <includes>
            <include>**/service/**</include>
            <include>**/controller/**</include>
            <!--<include>**/service/impl/*.class</include>-->
        </includes>
        <!-- rules里面指定覆盖规则 -->
        <rules>
            <rule implementation="org.jacoco.maven.RuleConfiguration">
                <element>BUNDLE</element>
                <limits>  
                    <!-- 方法覆盖到50% -->
                    <limit implementation="org.jacoco.report.check.Limit">
                        <counter>METHOD</counter>
                        <value>COVEREDRATIO</value>
                        <minimum>0.50</minimum>
                    </limit>
                    <!-- 分支覆盖到50% -->
                    <limit implementation="org.jacoco.report.check.Limit">
                        <counter>BRANCH</counter>
                        <value>COVEREDRATIO</value>
                        <minimum>0.50</minimum>
                    </limit>
                    <!-- 类覆盖到100%,不能遗失任何类 -->
                    <limit implementation="org.jacoco.report.check.Limit">
                    <counter>CLASS</counter>
                    <value>MISSEDCOUNT</value>
                    <maximum>0</maximum>
                    </limit>
                </limits>
            </rule>
        </rules>
    </configuration>
    <executions>
        <execution>
            <id>jacoco-initialize</id>
            <goals>
                <goal>prepare-agent</goal>
            </goals>
        </execution>
        <!--这个check:对代码进行检测,控制项目构建成功还是失败-->
        <execution>
            <id>check</id>
            <goals>
                <goal>check</goal>
            </goals>
        </execution>
        <!--这个report:对代码进行检测,然后生成index.html在 target/site/index.html中可以查看检测的详细结果-->
        <execution>
            <id>jacoco-site</id>
            <phase>package</phase>
            <goals>
                <goal>report</goal>
            </goals>
        </execution>
    </executions>
</plugin>

在maven的pom配置中,可以指定代码的覆盖率,分别从Instructions, Branches, Cyclomatic Complexity, Lines, Methods, Classes角度来指定覆盖率要求。
maven的pom文件中可以指定jacoco-unit.exec文件路径以及文件名。
还可以通过<includes>节点来指定哪些类需要进行单元测试。
注意: 这里的覆盖率要求在maven打包命令是不会生效的,只有在执行maven install的时候会按照覆盖率要求,如果不满足覆盖率则会报错。
另外maven的测试类需要遵循相应的规范命名,否则无法运行测试类,不能生成测试报告,以及覆盖率报告。jacoco使用的是maven-surefire-plugin插件,它的默认测试类名规范是:

Test*.java :以Test开头的Java类;
*Test.java :以Test结尾的Java类;
*TestCase.java:以TestCase结尾的Java类;

或者可以在pom中自定义测试类

<plugin>
	<groupId>org.apache.maven.plugins</groupId>
	<artifactId>maven-surefire-plugin</artifactId>
	<configuration>
		<includes>
			<include>**/*Tests.java</include>
			<include>**/*Test.java</include>
		</includes>
		<excludes>
			<exclude>**/Abstract*.java</exclude>
		</excludes>
	</configuration>
</plugin>
jacoco报告表头解释
  1. Instructions
    Jacoco计算的最小单位就是字节码指令。指令覆盖率表明了在所有的指令中,哪些被指令过以及哪些没有被执行。这项指数完全独立于源码格式并且在任何情况下有效,不需要类文件的调试信息。
  2. Branches
    Jacoco对所有的if和switch指令计算了分支覆盖率。这项指标会统计所有的分支数量,并同时支出哪些分支被执行,哪些分支没有被执行。这项指标也在任何情况都有效。异常处理不考虑在分支范围内。
  3. Cyclomatic Complexity
    Jacoco为每个非抽象方法计算圈复杂度,并也会计算每个类,包,组的复杂度。根据McCabe1996的定义,圈复杂度可以理解为覆盖所有的可能情况最少使用的测试用例数。这项参数也在任何情况下有效。
  4. Lines
    该项指数在有调试信息的情况下计算。因为每一行代码可能会产生若干条字节码指令,所以我们用三种不同状态表示行覆盖率
  5. Methods
    每一个非抽象方法都至少有一条指令。若一个方法至少被执行了一条指令,就认为它被执行过。因为JaCoco直接对字节码进行操作,所以有些方法没有在源码显示(比如某些构造方法和由编译器自动生成的方法)也会被计入在内。
  6. Classes
    每个类中只要有一个方法被执行,这个类就被认定为被执行。同5一样,有些没有在源码声明的方法被执行,也认定该类被执行。
gitlab上项目代码测试覆盖率检测

gitlab可以配合jacoco的测试报告,来获取到检测到的覆盖率数据。
在项目的.gitlab-ci.yml文件中配置mvn clean test && cat target/site/jacoco/index.html根据自己的实际情况来配置如果是打包前面一段则配置mvn clean package,如果报告路径有修改,则改为对应文件目录。
在gitlab中的Setting-CI/DI中的pipelines展开可以设置覆盖率检查的正则表达式,而JaCoCo则是根据检测报告html来生成覆盖率。对应的覆盖率获取gitlab已经提供了相应的正则表达式,可以直接使用。
在gitlab中修改这里的配置
这里覆盖率有提示JaCoCo使用的正则表达式

### 使用 JaCoCo 检查和提高 Java 测试覆盖率的最佳实践 #### 配置 Maven 项目以集成 JaCoCo 为了在 Maven 项目中使用 JaCoCo,需要先配置 `pom.xml` 文件。通过引入 `jacoco-maven-plugin` 插件,可以在构建过程中自动计算并展示测试覆盖率。 ```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> <!-- report goal --> <execution> <id>report</id> <phase>prepare-package</phase> <goals> <goal>report</goal> </goals> </execution> <!-- check goal with thresholds --> <execution> <id>check-coverage</id> <goals> <goal>check</goal> </goals> <configuration> <rules> <rule> <element>BUNDLE</element> <limits> <limit> <counter>LINE</counter> <value>COVEREDRATIO</value> <minimum>0.80</minimum> </limit> <limit> <counter>BRANCH</counter> <value>COVEREDRATIO</value> <minimum>0.75</minimum> </limit> </limits> </rule> </rules> </configuration> </execution> </executions> </plugin> </plugins> </build> ``` 上述配置不仅设置了行覆盖率至少达到80%,还规定了分支覆盖率达到75%以上[^2]。 #### 编写高质量的单元测试案例 编写全面且有效的单元测试是提高测试覆盖率的关键: 1. **确保边界条件得到充分验证** 对于每一个函数输入参数的不同情况都要有对应的测试用例,特别是边缘值处理部分。 2. **模拟外部依赖** 利用像 Mockito 这样的框架来隔离待测组件与其他系统的交互,从而专注于核心业务逻辑的功能性验证[^4]. 3. **关注异常路径** 不仅要测试正常流程下的行为表现,还需要特别注意各种可能发生的错误场景及其恢复机制。 #### 解读 JaCoCo 报告优化代码结构 运行完带有 JaCoCo测试之后,将会生成一份详细的 HTML 格式的报告文件夹,默认位于项目的 target/site/jacoco/index.html 下。这份文档提供了直观的颜色编码指示哪些区域已经被成功访问过以及未被触及的地方。针对红色标记出来的空白区段进行针对性改进——重构冗余复杂的算法表达;补充缺失的重要功能检验环节等措施均有助于逐步提升整体的质量水平[^1]。
评论 5
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值