Android官方技术文档翻译——Gradle 插件用户指南(6)
测试
从这里的 sourceSet 构建出来的是一个测试的apk,它可以部署到设备上,使用 Android 的测试框架去测试应用程序。它可以包含单元测试、 instrumentation 测试和后来的 uiautomator 测试。这个
SourceSet 不应该包含 AndroidManifest.xml ,因为它是会自动生成的。
下面是可以用来配置测试应用程序的几个值:
- testPackageName
- testInstrumentationRunner
- defaultConfig对象中配置:
android {defaultConfig {testPackageName "com.test.foo"testInstrumentationRunner "android.test.InstrumentationTestRunner"testHandleProfiling truetestFunctionalTest true}}
此外,sourceSet可以配置自己的依赖。
默认情况下,应用程序和它自己的依赖都会被添加到测试应用程序的classpath中,但是也可以通过以下来扩展
dependencies {androidTestCompile ‘com.google.guava:guava:11.0.2‘}
目前只有一种Build Type会进行测试。默认情况下是debugBuild Type,但它可以被重新配置:
android {...testBuildType "staging"}
运行测试
- 确保应用程序和测试应用程序都被构建 (依赖于 assembleDebug 和 assembleTest)
- 安装这两个应用程序
- 运行测试
- 卸载这两个应用程序。
所有测试结果都会保存为 XML 文件,路径为
build/androidTest-results
它可以通过以下方式来配置
配置
android {...
testOptions {resultsDir = "$project.buildDir/foo/results"}}
唯一的区别是整个库 (和它的依赖项) 会自动作为Library依赖添加到测试应用程序中。结果就是测试 APK 不只包含其自己的代码,还包括测试库以及测试库的所有依赖项。
这个Library的manifest 会合并到测试应用程序的manifest中(如引用此Library的任何项目)。
AndroidTest任务改为仅安装 (以及卸载)测试 APK (因为没有其他的 APK 要安装)
其他的都是相同的。
build/reports/androidTests
它类似于 jUnit 报告的位置build/reports/tests,或其他通常位于build/reports/<plugin>/的报告。
这个位置可以通过以下方式自定义
android {...
testOptions {reportDir = "$project.buildDir/foo/report"}}
要做到这一点,需要使用同一个文件中的另一个插件。这个插件可以如下配置:
buildscript {repositories {mavenCentral()}
dependencies {classpath ‘com.android.tools.build:gradle:0.5.6‘}}
apply plugin: ‘android-reporting‘
然后在根文件夹中,下面的命令就可以运行所有的测试并聚合测试报告:
gradle deviceCheck mergeAndroidReports --continue
注: --continue选项确保所有子项目的测试都会被运行,即使其中的一个子项目的测试失败了。如果不加上这个选项,第一个失败的测试将会中断所有测试的运行,这可能导致有些项目还没有执行它们的测试。
Lint 支持
android {
lintOptions {
// 设置为 true时lint将不报告分析的进度quiet true// 如果为 true,则当lint发现错误时停止 gradle构建abortOnError false// 如果为 true,则只报告错误ignoreWarnings true// 如果为 true,则当有错误时会显示文件的全路径或绝对路径 (默认情况下为true)//absolutePaths true// 如果为 true,则检查所有的问题,包括默认不检查问题checkAllWarnings true// 如果为 true,则将所有警告视为错误warningsAsErrors true// 不检查给定的问题iddisable ‘TypographyFractions‘,‘TypographyQuotes‘// 检查给定的问题 idenable ‘RtlHardcoded‘,‘RtlCompat‘, ‘RtlEnabled‘// * 仅 * 检查给定的问题 idcheck ‘NewApi‘, ‘InlinedApi‘// 如果为true,则在错误报告的输出中不包括源代码行noLines true// 如果为 true,则对一个错误的问题显示它所在的所有地方,而不会截短列表,等等。showAll true// 重置 lint 配置(使用默认的严重性等设置)。lintConfig file("default-lint.xml")// 如果为 true,生成一个问题的纯文本报告(默认为false)textReport true// 配置写入输出结果的位置;它可以是一个文件或 “stdout”(标准输出)textOutput ‘stdout‘// 如果为真,会生成一个XML报告,以给Jenkins之类的使用xmlReport false// 用于写入报告的文件(如果不指定,默认为lint-results.xml)xmlOutput file("lint-report.xml")// 如果为真,会生成一个HTML报告(包括问题的解释,存在此问题的源码,等等)htmlReport true// 写入报告的路径,它是可选的(默认为构建目录下的 lint-results.html )htmlOutput file("lint-report.html")
// 设置为 true, 将使所有release 构建都以issus的严重性级别为fatal(severity=false)的设置来运行lint// 并且,如果发现了致命(fatal)的问题,将会中止构建(由上面提到的 abortOnError 控制)checkReleaseBuilds true// 设置给定问题的严重级别(severity)为fatal (这意味着他们将会// 在release构建的期间检查 (即使 lint 要检查的问题没有包含在代码中)fatal ‘NewApi‘, ‘InlineApi‘// 设置给定问题的严重级别为errorerror ‘Wakelock‘, ‘TextViewEdits‘// 设置给定问题的严重级别为warningwarning ‘ResourceAsColor‘// 设置给定问题的严重级别(severity)为ignore (和不检查这个问题一样)ignore ‘TypographyQuotes‘}
}
郑重声明:本站内容如果来自互联网及其他传播媒体,其版权均属原媒体及文章作者所有。转载目的在于传递更多信息及用于网络分享,并不代表本站赞同其观点和对其真实性负责,也不构成任何其他建议。