一、原理
1.UiAutomator——基于UIAutomation的用户界面自动化测试框架,可以跨应用工作,谷歌亲生的。 UIAutomation在Android4.3发布时有了新版本,

Android4.3之前:使用inputManager或者更早的WindowsManager来注入KeyEvent

Android4.3之后:使用Accessibility APIs来注入事件。(AccessibilityService本来是做一些辅助功能的,提供了一系列的事件回调,帮助我们指示一些用户及界面的状态变化,主要给残障人群提供帮助。)

2.Robotium——基于Instrumentation开发出来的一套测试框架
Instrumentation的官方简介:

Instrumentation可以把测试包和目标测试应用加载到同一个进程中进行。既然各个控件和测试代码都运行在同一个进程中了,测试代码当然就可以调用这些控件的方法了,同时修改和验证这些控件的一些项就不在话下了。

Instrumentation的运行原理:InstrumentationTestRunner会在目标应用代码运行之前调用onCreate方法建立一个新的线程并为这个线程添加一个消息队列,这个线程循环处理其他线程发过来的消息事件,并与之进行交互。

跨应用:Android4.3之后Instrumentation引入了getUiAutomation接口的实例进行跨应用测试。

3.Appium——跨平台,允许采用同一套API在不同的平台(IOS,Android)上编写测试代码,让测试套件在IOS和Android平台上实现代码复用成为可能。
Appium的核心是一个暴露了REST API的网络服务器。这个服务器接收客户端过来的连接,监听客户端过来的命令,在移动设备上运行命令,然后把代表命令运行结果的HTTP响应包发送回客户端。

二、优缺点对比

UiAutomator
Robotium
Appium
是否支持设备无源码测试(黑盒测试) 是 是 是
能否进行跨应用测试 能 不能 能
是否是谷歌原生 是 不是 不是
支持编程语言 Java Java
几乎所有语言

是否有签名一致的问题 否 是 否
是否需要解决中文输入问题 是 否 是
建议开发团队增加的控件信息 Content Description resource-id Content Description
是否需要API17及以上 是 否 否
Junit支持版本 Junit4 Junit3 Junit3/Junit4
是否支持webview 否 是 是
支持平台 Android Android IOS

三、补充内容——Android三种注入事件的方式

1、使用内部APIs(内部API是谷歌没有对外开放的代码,存在一定的风险)
通过获得WindowManager的一个实例来访问injectKeyEvent/injectPointerEvent这两个事件注入方法。

在应用内可正常工作,在应用外不能正常工作(INJECT_EVENTS是需要系统权限的)。

2、使用instrumentation对象(开放的API,比内部API干净)
通过instrumentation的一个实例来访问injectEvent,同上面的内部APIs的方法。
所以在应用内部可以正常的工作,在应用外部不嫩正常的工作。

3、直接注入事件到设备 /dev/input/eventX
linux以系统设备的方式向用户暴露了一套统一的事件注入接口 /dev/input/eventX(其中X代表一个整数)。我们可以直接调用。
需要rooted过的设备,如:
adb shell
su
chmod 666 /dev/input/event3