随着应用的增长,您可能会发现将一些应用组件放在应用主进程以外的进程中很有用。要测试这些非默认进程中的应用组件,您可以使用多进程 Espresso 的功能。此工具在 Android 8.0(API 级别 26)及更高版本上可用,允许您无缝测试跨越应用进程边界的应用 UI 交互,同时保持 Espresso 的同步保证。
使用多进程 Espresso 时,请牢记以下版本控制和范围注意事项
- 您的应用必须面向 Android 8.0(API 级别 26)或更高版本。
- 此工具只能测试您包含在应用包内进程中的应用组件。它无法测试外部进程。
使用此工具
要使用多进程 Espresso 测试应用中的某个进程,请在应用的 build.gradle
文件中添加对 espresso-remote 工件的引用
Groovy
dependencies { ... androidTestImplementation 'androidx.test.espresso:espresso-remote:3.6.1' }
Kotlin
dependencies { ... androidTestImplementation('androidx.test.espresso:espresso-remote:3.6.1') }
您还需要将以下内容添加到应用的 androidTest
清单中
- 一个定义进程的
<instrumentation>
元素。 - 一个指示您要使用多进程 Espresso 的
<meta-data>
元素。
以下代码片段显示了如何添加这些元素
<manifest ... package="androidx.test.mytestapp.tests"> <uses-sdk android:targetSdkVersion="27" android:minSdkVersion="14" /> <instrumentation android:name="androidx.test.runner.AndroidJUnitRunner" android:targetPackage="androidx.test.mytestapp" android:targetProcesses="*"> <meta-data android:name="remoteMethod" android:value="androidx.test.espresso.remote.EspressoRemote#remoteInit" /> </instrumentation> </manifest>
前面的代码段指示 Android 框架您希望它测试应用包中的每个进程。如果您只想测试应用进程的一个子集,则可以在 targetProcesses
元素中指定一个逗号分隔的列表,而不是整个包。
<instrumentation
...
android:targetProcesses=
"androidx.test.mytestapp:myFirstAppProcessToTest,
androidx.test.mytestapp:mySecondAppProcessToTest" ... />
了解此工具的架构
当您测试应用并启动其默认进程时,您可能会执行 UI 交互(例如按下按钮),这会在辅助进程中启动一项活动。然后,系统会完成以下步骤以使用 Espresso 启用跨进程测试
- Android 框架创建并启动一个新进程以遵循应用的导航结构。每个
Instrumentation
进程都包含一个新的AndroidJUnitRunner
实例。在此阶段,这两个检测进程无法相互通信。 - 每个
AndroidJUnitRunner
实例都将 Espresso 注册为其测试框架。 - 两个
AndroidJUnitRunner
实例执行握手以建立彼此之间的连接。同时,每个AndroidJUnitRunner
实例将其所有已注册的客户端(如 Espresso)与其在其他进程中的相应客户端连接起来,以便这些客户端可以在它们之间形成直接的通信通道。 - 每个
AndroidJUnitRunner
实例继续查找新添加的检测实例和测试框架客户端,并根据需要建立其他通信通道。
图 1 说明了此过程的结果
其他资源
有关此主题的更多信息,请参阅以下资源。
- 使用 Android 测试支持库进行 Android 测试驱动开发 来自 Google I/O 2017 的会议视频,从 36:41 开始。