jacoco + gradle + testNG + jenkins 进行持续集成代码覆盖率的部署实现

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.配置完成执行构建,完成后即可看到覆盖率报告的结果

原文地址:https://www.cnblogs.com/fanshao2016/p/8000153.html