详解uiautomator2,让你摆脱usb

详解uiautomator2,让你摆脱usb
UiAutomator
 
背景介绍:
 
        UiAutomator是Google提供的用来做安卓自动化测试的一个Java库,基于Accessibility服务。功能很 强,可以对第三方App进行测试,获取屏幕上任意一个APP的任意一个控件属性,并对其进行任意 操作,
 
        但有两个缺点:
 
                1. 测试脚本只能使用Java语言
 
                2. 测试脚本要打包成jar或者apk包上传到设备上才能运
 
        python-uiautomator2封装了谷歌自带的uiautomator测试框架,提供便利的python接口。他允许测 试人员直接在PC上编写Python的测试代码,操作手机应用,完成自动化,大大提高了自动化代码 编写的效率。 
 
        python-uiautomator2是一个自动化测试开源工具,仅支持Android平台的原生应用测试。
 
        原理: 在手机上运行了一个http rpc服务,将uiautomator中的功能开放出来,然后再将这些http接口封 装成Python库
 
Uiautomator2
 
环境搭建
 
        1.安装adb
 
                此处早已经安装了,讲adb命令及monkey的时候就有讲过,Android-SDK自带
 
        2. 安装uiautomator2,此处有三种方式,推荐方式二、三,直接cmd命令输入即可
 
                方式一: pip install --upgrade --pre uiautomator2
 
                方式二:git clone https://github.com/openatx/uiautomator2 pip install -e uiautomator2
 
                方式三:离线安装 python安装目录-lib-sit-packages,将这个目录打包
 
        3.设备初始化,此处有个便捷的方式方法,直接建立连接,u2.connect('127.0.0.1:62001'),并跑一次程序,真机或模拟器上就会自动安装了,此处详细代码看后续展示。
 
                首先设备连接到PC,并能够adb devices发现该设备 命令: python -m uiautomator2 init(从github下载atx-agent文件,并推送到手机。在手机上安装包名为 ——com.github.uiautomator——的apk) 如果有多台设备,指定设备初始化加参数:--serial 如 python3 -m uiautomator2 --serial bff1234
 
常用操作
 
 1.devices.click_post_delay=1 #全局设置,每次操作休眠1s
 
 2.uninstall: 卸载uiautomator2 uninstall # 卸载一个包
 
 3.d.screen_on() /d.screen_off() 屏幕关闭的情况下点亮一次/锁屏
 
 4.d.press("home") # press the home key, with key name 按键主页键
 
 5.d.press("back") # press the back key, with key name 按键返回键
 
 6.d.app_info("com.examples.demo")  app信息
 
 7.d.app_start("com.example.hello_world" , ".MainActivity") # 通过指定main activity的方式启动应用,等价于调用am start -n com.example.hello_world/.MainActivity  
 
 8.d.implicitly_wait(10.0) :设置元素查找等待时间(默认20s)全局 
 
 9.d.app_stop("com.example.hello_world")  停止运行app
 
 10. d.app_clear('com.example.hello_world')  清理app
 
 11.d.app_stop_all() 关闭所有应用
 
连接设备
 
        python-uiautomator2连接手机的方式有两种,一种是通过WIFI,另外一种是通过USB。两种方法各 有优缺点。
 
Wifi连接
 
        手机获取到手机的IP,并确保电脑可以PING通手机。手机的IP可以在设置-WIFI设置里面获取到。 比如手机的IP是192.168.1.111,连接设备的代码为
 
import uiautomator2 as u2
 
d = u2.connect('192.168.1.111')
 
USB连接
 
        手机的序列号可以通过adb devices获取到,假设序列号是emulator-5554,连接代码为
 
import uiautomator2 as u2 
 
d = u2.connect_usb('emulator-5554')
 
        此处不管是手机还是模拟器,查询到序列号填入即可
 
定位工具
 
        安装weditor元素定位工具 前置条件:设备需要初始化init (类似uiautomatorview,编辑器能够提供辅助编写脚本,查看组件信息,调试代码等功能。)
 
        pip install --pre wedi
 
        安装好了之后运行命令,会得到一个网页窗口:
 
       python -m weditor
 
         输入设备号后,点击connect进行连接,成功后后面会显示一棵绿草,此时刷新一个界面Dump Hierarchy即可,如果你想实时刷新界面就打开实时按钮即可。
 
定位元素
 
启动应用
 
        # 默认的这种方法是先通过atx-agent解析apk包的mainActivity,然后调用am start -n $package/$activity启动
 
import uiautomator2 as u2
 
devices = u2.connect('emulator-5554')
 
print(devices.info)
 
d.app_start("com.netease.cloudmusic")
 
# 启动应用并跳转到对应的界面
 
d.app_start("com.netease.cloudmusic" , "com.netease.cloudmusic.activity.MainActivity")
 
         此处打印设备信息的时候,如环境搭建初始化所说,这里运行之后设备端会自行安装atx
 
停止应用
 
import uiautomator2 as u2
 
devices = u2.connect('emulator-5554')
 
print(devices.info)
 
d.app_start("com.netease.cloudmusic")
 
# 启动应用并跳转到对应的界面
 
d.app_start("com.netease.cloudmusic" , "com.netease.cloudmusic.activity.MainActivity")
 
# 停止运行
 
d.app_stop("com.netease.cloudmusic")
 
查包名
 
        此处介绍一个uiautomator2独有了查看包名及活动界面信息的命令 uiautomator2 current

推荐阅读