jacoco集成gradle
jacoco作为代码覆盖率统计的工具,目前社区依旧很活跃,也在持续更新,支持的测试方式也相对丰富(支持独立测试工程和项目集成的测试模块),如果项目想做代码覆盖率统计,还是首推jacoco。
jacoco集成mvn的实现,网上介绍已经比较多了,这里不再赘述,只记录一下jacoco集成gradle的过程,此处以项目集成的测试模块做例。
1.在测试模块的build.gradle中引入jacoco插件。
apply plugin: "jacoco"
2.指定jacoco的版本和报告路径,这里只有两个属性,toolVersion指定版本号,reportsDir指定报告生成的路径也就是 .exec文件的路径,路径为空时,默认 $buildDir/reports/jacoco
jacoco { toolVersion = "0.7.9" reportsDir = file("$buildDir/customJacocoReportDir")}
3.同样在测试模块的build.gradle文件中,test任务下,增加jacoco的任务,这样在每次执行测试脚本后会自动执行jacoco,我这边是与testng配套的,因此与useTestng()顺序放一起就行了.
特别关注,由于gradle在执行测试时对failcase是敏感的,只要存在一个case失败,都会使本次构建失败(直接抛出exception),导致在测试后无法执行jacoco,因此,需要跳过失败case,增加属性:
ignoreFailures = true
test { ignoreFailures = true useTestNG(); jacoco{ append = false destinationFile = file("$buildDir/jacoco/trade.exec") } }
4.在jenkis上做持续集成的话,基本上以上三点配置好之后就可以了,但如果本地想验证看下覆盖率报告的话,可以指定生成覆盖率报告格式,新增jacoco报告任务
jacocoTestReport { reports { xml.enabled false csv.enabled false html.destination file("${buildDir}/jacocoHtml") }}
jacoco在jenkins上的配置
1.在jenkins系统管理-插件管理中,安装jacoco插件,安装好之后,增加的构建后任务中会出现生成jacoco测试报告的选项
2.增加任务后,出现覆盖率配置,这里的配置需要特别注意,如果配错无法找到对应文件时,执行的日志不会报错,但会导致覆盖率报告结果为0
Path to exec files:代码覆盖率统计文件位置,即.exec生成的文件路径
Path to class directories:classes文件位置,统计的源代码编译后的路径
Path to source directories :源码文件位置,统计的源代码路径
下面是设置覆盖率百分比的提醒阈值。
太阳表示覆盖率高于设置阈值,覆盖率报告里会橙色提醒
乌云表示覆盖率低于设置阈值,覆盖率报告里会橙色提醒
3.配置完成执行构建,完成后即可看到覆盖率报告的结果