LinkedIn 工程师兼 Test Butler 创建者 Drew Hannay写道,Test Butler 是一款面向 Android 的开源测试工具,它允许开发人员对若干测试环境设置通过编程进行控制,从而使开发人员可以可靠地运行测试。
据 Hannay 介绍,Test Butler 的灵感来自谷歌 2014 年的演讲“环保之路:清理有毒的移动环境”。该演讲介绍了如何解决反复出现并影响移动测试的问题,比如缺少可靠性和可再现性、速度缓慢等。Hannay 表示,当结果可能受到环境因素影响时,测试就不可靠了,尤其是当它们出现在设备 / 操作系统层面时,比如 Android 模拟器的 CPU 突然休眠,不正常的设备方向变化,随机出现的锁屏,意外弹出的系统对话框,等等。所有那些事件都会导致 Espresso UI 测试失败。
为了解决这些问题,按照最初的设计,Test Butler 将作为一个后台服务在 Android 模拟器上运行,提供一些旨在增加测试环境稳定性的特性,比如:
- 禁用动画,这是 Espresso 正常运行所需要的;
- 通过安装一个自定义的 IActivityController 禁用系统对话框;
- 监控模拟器的锁屏、Wi-Fi 和 CPU,保证它们不会休眠。
测试中的应用可以和 Test Butler 进行通信,并控制多个测试环境变量,比如:
- 启用 / 禁用 Wi-Fi;
- 在测试执行过程中通过编程改变设备方向;
- 模拟不同的定位服务模式,比如,省电模式或者高精度模式;
- 定义应用程序运行的区域设置。
Test Butler 的一个关键方面是,它使用面向内置 Android 模拟器的系统密钥库进行签名。也就是说,它会自动取得自己所需的任何 signature
级的权限,而不需要通过 ADB,或者篡改清单文件。
下面的代码展示了如何设置应用,让其和 Test Butler 一起工作:
public class ExampleTestRunner extends AndroidJUnitRunner { @Override public void onStart() { TestButler.setup(InstrumentationRegistry.getTargetContext()); super.onStart(); } @Override public void finish(int resultCode, Bundle results) { TestButler.teardown(InstrumentationRegistry.getTargetContext()); super.finish(resultCode, results); } }
当应用和 Test Butler 的连接建立后,你可以使用 TestButler 类
提供的多种方法控制测试环境,比如修改定位服务模式、设置 Wi-Fi 状态、触发设备反转,等等。
据 Hannay 介绍,目前,LinkedIn 每天使用 Test Butler 运行超过 1 百万次测试。该工具是开源的,代码托管在GitHub 上。
查看英文原文: LinkedIn Test Butler Aims to Improve UI Testing on Android
评论