本文由CSDN博客万一博主翻译,其他章节的翻译请参见:

http://blog.csdn.net/column/details/gradle-translation.html

翻译项目请关注Github上的地址:

https://github.com/msdx/gradledoc/tree/1.12。

直接浏览双语版的文档请访问:

http://gradledoc.qiniudn.com/1.12/userguide/userguide.html。

另外,Android 手机用户可通过我写的一个程序浏览文档,带缓存功能的,目前0.2.1版本兼容 android 2.2以上系统,地址如下:

http://www.wandoujia.com/apps/com.githang.gradledoc

翻译不易,转载请注明本文在CSDN博客上的出处:

http://blog.csdn.net/maosidiaoxian/article/details/46646311

关于我对Gradle的翻译,以Github上的项目及http://gradledoc.qiniudn.com 上的文档为准。如有发现翻译有误的地方,将首先在以上两个地方更新。因时间精力问题,博客中发表的译文基本不会同步修改。

第三十四章. JaCoCo 插件

JaCoCo 插件目前还是孵化中状态。请务必注意,在以后的
Gradle 版本中,DSL 和其他配置可能会有所改变。

JaCoCo 插件通过集成JaCoCo
Java 代码提供了代码覆盖率指标。

34.1.
入门

要想开始,请将 JaCoCo 插件应用于你想要计算代码覆盖率的项目中。

示例 34.1. 应用 JaCoCo 插件

build.gradle

apply plugin: "jacoco"

如果 Java 插件也被应用于你的项目,那么会创建一个名为jacocoTestReport的新任务,该新任务依赖于test任务。该报告可以在$buildDir/reports/jacoco/test 中看到。默认情况下,会生成一个
HTML 报告。

34.2.
配置 JaCoCo 插件

JaCoCo 插件添加一个名为jacoco类型为JacocoPluginExtension的project
扩展,这个扩展允许在你的构建中配置 JaCoCo 所使用的默认值。

示例 34.2. 配置 JaCoCo 插件设置

build.gradle

jacoco
    toolVersion = "0.6.2.201302030002"
    reportsDir = file("$buildDir/customJacocoReportDir")
}

表 34.1. JaCoCo 属性的 Gradle 默认值

Property Gradle 默认值
reportsDir "$buildDir/reports/jacoco"

34.3.
JaCoCo 报告配置

JacocoReport任务可以用于生成不同格式的代码覆盖率报告。它实现了标准的
Gradle 类型Reporting,并呈现了一个JacocoReportsContainer类型的报告容器。

示例 34.3. 配置测试任务

build.gradle

jacocoTestReport {
    reports
        xml.enabled false
        csv.enabled false
        html.destination "${buildDir}/jacocoHtml"
    }
}


34.4.
JaCoCo 的特定任务配置

JaCoCo 插件添加了一个JacocoTaskExtension扩展到Test类型的所有任务中。该扩展允许配置
JaCoCo 中的测试任务的一些特定属性。

示例 34.4. 配置测试任务

build.gradle

test {
    jacoco
        append = false
        destinationFile = file("$buildDir/jacoco/jacocoTest.exec")
        classDumpFile = file("$buildDir/jacoco/classpathdumps")
    }
}

表 34.2. JaCoCo 任务扩展的默认值

Property Gradle 默认值
enabled true
destPath $buildDir/jacoco
append true
includes []
excludes []
excludeClassLoaders []
sessionId auto-generated
dumpOnExit true
output Output.FILE
address -
port -
classDumpPath -
jmx false

虽然Test的所有任务会在java插件被配置使用时会自动增强以提供覆盖率信息,但是任何实现了JavaForkOptions的任务都可以通过
JaCoCo 插件得到增强。也就意味着,任何fork Java 进程的任务都可以用于生成覆盖率信息。

例如,你可以配置您的构建使用application插件来生成代码覆盖率。

示例 34.5. 使用 application 插件来生成代码覆盖率数据

build.gradle

apply plugin: "application"
apply plugin: "jacoco"

mainClassName = "org.gradle.MyMain"

jacoco {
    applyTo run
}

task applicationCodeCoverageReport(type:JacocoReport){
    executionData run
    sourceSets sourceSets.main
}

注: 此示例中的代码可以在Gradle
的二进制分发包及源代码分发包中的samples/testing/jacoco/application中找到。

示例 34.6. 由 applicationCodeCoverageReport 生成的覆盖率报告

构建布局

application
  build
    jacoco
      run.exec
    reports/jacoco/applicationCodeCoverageReport/html/
      index.html

34.5.
任务

对于同时也配置使用了 Java 插件的项目,JaCoCo 插件会自动添加以下任务:

表 34.3. JaCoCo 插件 - 任务

任务名称 依赖于 类型 描述
jacocoTestReport - JacocoReport 为测试任务生成代码覆盖率报告。

34.6.
依赖管理

JaCoCo 插件添加了下列的依赖配置:

表34.4. JaCoCo 插件 ​​- 依赖配置

名称 意义
jacocoAnt 用于运行JacocoReportJacocoMerge任务的
JaCoCo Ant 库。
jacocoAgent 用于测试位于test下的代码的 JaCoCo 客户端库。

最新文章

  1. AVR/Arduino定时/计数器、中断入门
  2. IE6/IE7下绝对定位position:absolute和margin的冲突问题解决
  3. 网页打包安卓APP流程
  4. c# 轻量级ORM框架 之 WhereHelper (二)
  5. 借鉴网上的winform模仿QQ窗口停靠功能稍作改动
  6. RealThinClient学习(一)
  7. AngularJS中实现服务端分页
  8. JavaScript—offset、client、scroll
  9. Java8从对象列表中取出某个属性的列表
  10. Lyk Love painting/convex hull/mumsic
  11. Android添加百分比布局库时显示Failed to resolve: com.android.support.percent:问题
  12. 【魔改】hdu6325 多校赛3G xy排序凸包+llvector模板
  13. pychram 2018-01 安装pyQT5报错
  14. AxonFramework
  15. 其原因可能是堆被损坏,这也说明 xxx.exe 中或它所加载的任何 DLL 中有 bug
  16. python学习之----用虚拟环境保存库文件
  17. WordPress导航菜单函数
  18. Oracle 数据库执行慢SQL
  19. Collections工具类的使用
  20. 洛谷P1709 [USACO5.5]隐藏口令Hidden Password(最小表示法)

热门文章

  1. Java 资源本地化与国际化
  2. 如何通过网络连接进行ADB调试
  3. 7.0、Android Studio命令行工具
  4. Spark技术内幕:Master的故障恢复
  5. 09 ListView监听 ExpandableListView的使用总结
  6. SSH深度历险(三) EJB Session Bean有状态和无状态的区别与联系
  7. UNIX网络编程——客户/服务器程序设计示范(三)
  8. JEECG&Dubbo Demo
  9. 【一天一道LeetCode】#260. Single Number III
  10. Devstack: A copy of worked local.conf I'm sharing with you.