APP自动化测试框架-UiAutomator2基础

前言很早以前,我用uiautomator+JAVA实践过Android App自动化测试,不过今天要提的不是uiautomator,而是uiautomator2 。听起来uiautomator2像是uiautomator的升级版,但是这两款框架仅仅是名字上比较相似,实际上没有任何关联 。
一、uiautomator/uiautomator2的前生今世项目地址:
https://github.com/openatx/uiautomator2
1.官方文档介绍2.梳理一下脉络

  • 先有的谷歌uiautomator,但是只支持java;
  • 后来一个名为hexiaocong的开发者基于uiautomator封装了Python/ target=_blank class=infotextkey>Python版本,支持python代码运行;
  • 而受其启发,uiautomator2作者开发了uiautomator2 。所以它们的诞生顺序应该是:uiautomator(谷歌版)-->uiautomator(python版)-->uiautomator2
3.三款框架对比 框架
支持语言
特点
uiautomator
java
谷歌开源,仅支持Android
xiaocong/uiautomator
python
开源,仅支持Android
uiautomator2
python
开源,仅支持Android
二、uiautomator2简介1.项目组成
  • uiautomator-server:主服务
  • minicap:实现实时屏幕投屏,以及实时截图
  • minitouch:用于精确实时控制设备
  • atx-agent:运行在设备上的驻守程序,go开发,用于保活设备上相关的服务
  • weditor:类似于uiautomatorviewer,专门为本项目开发的辅助编辑器
2.工作原理
APP自动化测试框架-UiAutomator2基础

文章插图
 
1)各部分职责
  • Python:编写脚本,向移动设备发起http请求;
  • 移动设备:运行了封装了uiautomator2的http服务,解析python脚本发起的请求,并转化成uiautomator2可识别的代码;
2)运行过程
  1. 移动设备上运行atx-agent守护进程,随后atx-agent启动uiautomator2服务,默认7912端口进行监听;
  2. 在PC上编写python脚本并执行(相当于发送 HTTP 请求到移动设备的 server 端);
  3. 移动设备通过 wifi 或 USB 接收到 PC 上发来的 HTTP 请求,执行指定的操作,从而操作移动设备;
三、环境搭建1.安装uiautomator2pip install uiautomator2pip install -U weditor# 安装weditor2.初始化设备python -m uiautomator2 init初始化成功会出现如下提示
APP自动化测试框架-UiAutomator2基础

文章插图
 
当PC或linux服务器连接了多台adb device的情况下,“python -m uiautomator2 init”默认初始化的是所有设备,若指定设备初始化,则需使用“--serial”参数:
python -m uiautomator2 init --serial $SERIAL# $SERIAL为手机序列号,可通过adb devices查看3.init时都干了啥?执行“python -m uiautomator2 init”命令,会自动往手机上安装一堆东西:
  • app-uiautomator.apk
  • app-uiautomator-test.apk
  • atx-agent
  • minicap
  • minitouch
更多信息详见:
https://github.com/openatx/uiautomator2/wiki/Manual-Init
APP自动化测试框架-UiAutomator2基础

文章插图
 
四、基础操作1.连接设备uiautomator2提供了3种连接方式
1)通过WiFi连接import uiautomator2 as u2d = u2.connect('10.0.0.1') # alias for u2.connect_wifi('10.0.0.1')print(d.info)2)通过USB连接import uiautomator2 as u2d = u2.connect('123456f') # alias for u2.connect_usb('123456f')print(d.info)3)通过ADB WiFi连接import uiautomator2 as u2d = u2.connect_adb_wifi("10.0.0.1:5555")# 等同于# + Shell: adb connect 10.0.0.1:5555# + Python: u2.connect_usb("10.0.0.1:5555")2.命令行工具1)截图uiautomator2 screenshot test.jpg2)获取当前APP报名及Activityuiautomator2 current3)卸载应用uiautomator2 uninstall <package-name> # 卸载一个包uiautomator2 uninstall <package-name-1> <package-name-2> # 卸载多个包uiautomator2 uninstall --all # 全部卸载


推荐阅读