LinkedIn Test Butler 旨在改进 Android UI 测试

  • Sergio De Simone
  • 谢丽

2016 年 8 月 30 日

话题:Java开源移动Android语言 & 开发

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

Java开源移动Android语言 & 开发