查看代码覆盖率报告

Android Gradle 插件可以创建代码覆盖率报告,用于跟踪测试覆盖的代码百分比。本页介绍了如何启用覆盖率报告和生成报告。

您可以为每个变体的每种测试类型(单元测试和插桩测试)生成覆盖率报告。您还可以跨不同的测试类型、模块和 build 变体生成统一的覆盖率报告。

启用代码覆盖率

必须通过在模块级 build 文件中将 enableAndroidTestCoverageenableUnitTestCoverage 设置为 true,为要获取覆盖率报告的每个变体启用代码覆盖率:

Kotlin

android {
    // ...
    buildTypes {
        debug {
            // Enable coverage for unit tests
            enableUnitTestCoverage = true
            // Enable coverage for instrumentation tests
            enableAndroidTestCoverage = true
        }
    }
}

Groovy

android {
    // ...
    buildTypes {
        debug {
            // Enable coverage for unit tests
            enableUnitTestCoverage true
            // Enable coverage for instrumentation tests
            enableAndroidTestCoverage true
        }
    }
}

更改 Jacoco 版本(可选)

当您在模块上启用覆盖率时,AGP 会自动应用 Jacoco。 不过,如果您需要使用特定版本的 Jacoco,可以在模块级 build 文件中指定该版本:

Kotlin

android {
    jacoco {
        version = "JACOCO_VERSION"
    }
}

Groovy

android {
    jacoco {
        version = 'JACOCO_VERSION'
    }
}

生成特定于变体的覆盖率报告

如需仅针对特定变体生成单元测试或插桩测试的覆盖率报告,请运行相应的任务。

测试类型 命令 报告位置
单元测试 ./gradlew :module-name:createVariantNameUnitTestCoverageReport path-to-your-project/module-name/build/reports/coverage/test/variant/index.html
插桩测试 ./gradlew :module-name:createVariantNameAndroidTestCoverageReport path-to-your-project/module-name/build/reports/coverage/androidTest/variant/connected/index.html

生成统一的代码覆盖率报告

您可以使用 createCoverageReportcreateAggregatedCoverageReport Gradle 任务生成统一的代码覆盖率报告。您可以使用这些任务生成一个 HTML 报告,其中整合了来自不同测试类型(单元测试和插桩测试)、模块和 build 变体的覆盖率数据。 这样,您就可以在一个信息中心内全面了解项目的代码覆盖率。

前提条件

  • Android Gradle 插件 9.2.0-alpha07 或更高版本

如需生成统一的报告,请从命令行运行以下任务之一:

覆盖率范围 命令 说明 报告位置
当前模块 ./gradlew :module-name:createCoverageReport 为当前模块生成统一的覆盖率报告,合并来自所有测试类型的数据。 path-to-your-project/module-name/build/reports/code_coverage_html_report/
当前模块和依赖项 ./gradlew :module-name:createAggregatedCoverageReport 为当前模块及其所有依赖项生成统一的覆盖率报告。此任务适用于已启用发布的应用模块和 库模块 path-to-your-project/module-name/build/reports/aggregated_code_coverage_html_report/

生成的 HTML 报告着陆页会显示所有模块的概览摘要。您可以从模块到软件包、从软件包到类,以及从类到源文件逐层深入。 点击任何文件,即可查看代码,其中突出显示了行覆盖率和分支覆盖率:

  • 绿色:已覆盖的行。
  • 红色:未覆盖的行。
  • 黄色:部分覆盖(缺少一些指令或分支)。