Android运行测试

  • 单元测试
  • JUnit
  • 功能测试
  • Espresso


单元测试

在项目中拥有好的单元测试,不仅可以保证项目的质量,还可以很容易的检测新代码是否会中断一些功能。Android Studio和Gralde的Android插件原生支持单元测试,但在使用他们之前需要做一些配置。

JUnit

JUnit是一个非常受欢迎的测试依赖库,从诞生到现在已超过十年。它可以很容易的编写测试,同时确保他们的可读性。注意,这些特定的单元测试用例只对业务逻辑有效,对和Android SDK相关的代码无效。

在为你的Android项目编写JUnit之前,你需要为测试用例创建一个文件夹。按照惯例,这个文件夹被命名为test,并且应该和你的main目录在同一级别上。如下:

android VTS认证 android test station_android VTS认证

添加JUnit 4依赖

dependencies {
    testImplementation 'junit:junit:4.12'
}

注意,在这里,使用的是testCompile,而不是compile。使用该配置可以确保依赖只在运行测试时构建,而不会在分发的app中打包。在常规的assemble任务中,通过testCompile添加的依赖将永远不会被包含在releases的APK中。

如果在你的构建类型或product flavor中有任何特定的条件,那么你都可以针对该特殊构建添加只用于测试的依赖。例如,如果你只想添加JUnit测试到paid flavor中,那么你可以像下面这样操作:
dependencies{
testPaidCompile ‘junit:junit:4.12’
}

下面就可以编写测试代码了:

package com.muheda.test;

import org.junit.Test;

import static org.junit.Assert.*;

/**
 * Example local unit test, which will execute on the development machine (host).
 *
 * @see <a href="http://d.android.com/tools/testing">Testing documentation</a>
 */
public class ExampleUnitTest {
    @Test
    public void addition_isCorrect() {
        assertEquals(4, 2 + 3);
    }
}

只需要执行gradlew test,就可以通过Gradle运行所有的测试了。如果你只想在某个构建variant上运行测试,那么只需简单加该variant的名称即可。如果一个测试用例失败了,则Gradle会在命令行界面上打印错误消息。如果所有的测试都运行通过,则Gradle会显示BUILD SUCCESSFUL信息。

一个失败的测试用例会导致整个test任务失败,并立即停止整个进程。这意味着,在失败的情况下,不是所有的测试用例都会被执行。如果你想确保所有的构建variant都执行整套测试,请使用continue:

gradlew test -continue

你也可以通过在相应的目录下存储测试类,来编写针对某一构建variant的特定测试用例。例如:如果你想在付费版本的App中测试特定的行为,那么可以将测试类放在src/testPaid/java/包名 文件夹中。

如果你不想运行整套测试用例,而是只针对一个特定的测试类,那么可以像下面这样使用测试标识:

gradlew testDebug --tests="*.addition_isCorrect"

执行测试task不仅会运行所有的测试用例,而且会在app/build/reports/tests/debug/index.html中创建一份测试报告。你也可以在Android Studio中运行测试用例。这样你就可以在IDE中立即得到反馈,并且可以点击失败的测试用例导航到相应的代码。

如果你想测试包含引用Android特有的类或资源的部分代码,则常规的单元测试将无法满足。

功能测试

功能测试用于测试应用中的几个组件是否可以一起正常工作。例如,你可以创建一个功能测试用例来确认某个按钮是否打开了一个新的Activity。Android中有几个功能测试框架,但最简单最基础的测试框架是Espresso框架。

Espresso

Google创造了Espresso框架,使其更容易为开发人员编写功能测试。该依赖库由Android support repository提供。为了在设备上运行测试用例,你需要定义一个测试执行器,通过测试支持依赖库。Google提供了AndroidJUnitRunner测试执行器,其可以让你在Android设备上运行JUnit测试类。测试执行器加载应用APK和测试APK到一个设备上,并运行所有的测试用例,然后根据测试结果生成测试报告。

defaultConfig{
testInstrumentationRunner “android.support.test.runner.AndroidJUnitRunner”
}

在可以开始使用Espresso之前,你还需要设置一些依赖:

dependencies {
    implementation fileTree(dir: 'libs', include: ['*.jar'])
    implementation 'com.android.support:appcompat-v7:28.0.0'
    implementation 'com.android.support.constraint:constraint-layout:1.1.3'
    testImplementation 'junit:junit:4.12'
    androidTestImplementation 'com.android.support.test:runner:1.0.2'
    androidTestImplementation 'com.android.support.test.espresso:espresso-core:3.0.2'
}

在开始使用Espresso之前,你还需要引用测试支持依赖库和espresso-core。注意,这些依赖使用的是androidTestCompile配置,而不是之前我们使用的testCompile配置。其可用来区分单元测试和功能测试。功能测试的目录是src/androidTest/java/包名,如下所示:

android VTS认证 android test station_android_02

运行测试后可以在build/outputs/reports/androidTests/connected文件夹下找到生成的测试报告。功能测试报告展示了测试用例运行在哪个设备和哪个Android版本。你可以在多个设备上同时运行这些测试用例,这样会更快的找到设备或版本相关的bugs。