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

jacoco集成gradle

   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")
    }
}

 

jacoco在jenkins上的配置

 1.在jenkins系统管理-插件管理中,安装jacoco插件,安装好以后,增长的构建后任务中会出现生成jacoco测试报告的选项插件

2.增长任务后,出现覆盖率配置,这里的配置须要特别注意,若是配错没法找到对应文件时,执行的日志不会报错,但会致使覆盖率报告结果为0日志

 Path to exec files:代码覆盖率统计文件位置,即.exec生成的文件路径xml

Path to class directories:classes文件位置,统计的源代码编译后的路径

Path to source directories :源码文件位置,统计的源代码路径

下面是设置覆盖率百分比的提醒阈值。

太阳表示覆盖率高于设置阈值,覆盖率报告里会橙色提醒

乌云表示覆盖率低于设置阈值,覆盖率报告里会橙色提醒

  3.配置完成执行构建,完成后便可看到覆盖率报告的结果

相关文章
相关标签/搜索