jacoco做为代码覆盖率统计的工具,目前社区依旧很活跃,也在持续更新,支持的测试方式也相对丰富(支持独立测试工程和项目集成的测试模块),若是项目想作代码覆盖率统计,仍是首推jacoco。html
jacoco集成mvn的实现,网上介绍已经比较多了,这里再也不赘述,只记录一下jacoco集成gradle的过程,此处以项目集成的测试模块作例。app
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
特别关注,因为gradle在执行测试时对failcase是敏感的,只要存在一个case失败,都会使本次构建失败(直接抛出exception),致使在测试后没法执行jacoco,所以,须要跳过失败case,增长属性:ui
ignoreFailures = true
test { ignoreFailures = true useTestNG(); jacoco{ append = false destinationFile = file("$buildDir/jacoco/trade.exec") } }
4.在jenkis上作持续集成的话,基本上以上三点配置好以后就能够了,但若是本地想验证看下覆盖率报告的话,能够指定生成覆盖率报告格式,新增jacoco报告任务spa
jacocoTestReport { reports { xml.enabled false csv.enabled false html.destination file("${buildDir}/jacocoHtml") } }
1.在jenkins系统管理-插件管理中,安装jacoco插件,安装好以后,增长的构建后任务中会出现生成jacoco测试报告的选项插件
2.增长任务后,出现覆盖率配置,这里的配置须要特别注意,若是配错没法找到对应文件时,执行的日志不会报错,但会致使覆盖率报告结果为0日志
Path to exec files:代码覆盖率统计文件位置,即.exec生成的文件路径xml
Path to class directories:classes文件位置,统计的源代码编译后的路径
Path to source directories :源码文件位置,统计的源代码路径
下面是设置覆盖率百分比的提醒阈值。
太阳表示覆盖率高于设置阈值,覆盖率报告里会橙色提醒
乌云表示覆盖率低于设置阈值,覆盖率报告里会橙色提醒
3.配置完成执行构建,完成后便可看到覆盖率报告的结果