一、原理
1.UiAutomator——基于UIAutomation的用户界面自动化测试框架,可以跨应用工作,谷歌亲生的。
UIAutomation在Android4.3发布时有了新版本,官方简介:http://blog.csdn.net/zhubaitian/article/details/40504827。
Android4.3之前:使用inputManager或者更早的WindowsManager来注入KeyEvent
Android4.3之后:使用Accessibility APIs来注入事件。(AccessibilityService本来是做一些辅助功能的,提供了一系列的事件回调,帮助我们指示一些用户及界面的状态变化,主要给残障人群提供帮助。)
2.Robotium——基于Instrumentation开发出来的一套测试框架
Instrumentation的官方简介:http://blog.csdn.net/zhubaitian/article/details/39578915
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
Appium和Uiautomator是两个不同的自动化测试框架,它们在适用场景、作用域和原理上有所不同。以下是其详细介绍:12
- 适用场景。Appium适用于Android和iOS设备的自动化测试,而Uiautomator仅适用于Android设备。
- 作用域。在Android系统中,Uiautomator可以跨应用操作,直接在手机ROM层面实现交互,而Appium主要局限于应用内部,不支持跨应用操作。不过,Appium可以实现Webview界面的自动化测试,这是Uiautomator所不具备的功能。
- 原理。Appium是基于WebDriver协议实现的,它通过Appium Server作为桥梁,使用Bootstrap.jar来调用Android端的Uiautomator命令和iOS端的自动化命令(如iOS 8以上版本的XCTest),而Uiautomator则是基于Android的Instrumentation框架实现的,它通过获取系统上下文和设备信息状态来进行自动化测试。
- 支持的语言。Uiautomator主要使用Java语言,而Appium支持多语言,如Java、Python等,提高了测试脚本的编写效率。
- 开放性和可扩展性。Appium作为一个更开放的框架,它允许使用标准的WebDriver协议与移动应用进行交互,这使得Appium在跨平台和多语言支持方面比Uiautomator更为灵活和强大。
总的来说,选择哪个框架取决于具体的测试需求和目标平台。如果需要进行跨平台的自动化测试,特别是涉及iOS设备的测试,Appium会是更好的选择。而如果测试主要针对Android设备,且对跨应用操作有较高要求,Uiautomator可能更适合。
参考:https://www.163.com/dy/article/EGU3J6BD0511G03U.html
https://blog.csdn.net/Mielt/article/details/120967856
标签:Instrumentation,Appium,应用,Uiautomator,APP,UIAutomator,测试,Android From: https://www.cnblogs.com/klb561/p/18148053