Appium 适配 Android7.0 以上版本

说明:

公司新采购了一批安卓机器,拿了其中一台华为荣耀 V9 跑之前写的测试用例,发现每次登陆以后进入到 MainActivity 了之后,==元素就获取不到了==,试了一下==driver.page_source==也是报了超时。本能反应是==Android7.0==的问题,于是去testerhome搜了巨多安卓 7.0 的东东。找到了一些头绪。

感谢一下这位 meil000 小伙伴的分享~~

image

可以看到他说的 3 个关键:

  1. appium 版本要高于 1.63
  2. 启动的时候要声明 automation 版本
  3. 保障 5037 端口不被占用

解决方案:

我这里下载的是 1.65 版本,看版本用以下命令。

image

如果版本过低,建议去官网下载最新的 realease 版本,也可以看下我的appium 环境搭建里边的如何安装 appium。

在控制台输入, netstat -ano | findstr 5037
这里 findstr 类似于 grep 的作用

image

可以看到 listening 状态栏是被 PID 为 13076 占用了, 打开任务管理器找到 PID 为 13076 的进程。

image

可以看到是 adb.exe 占用了这个端口。

==不过这里我没有遇到这个问题,这一步我跳过了。。。==

使用 npm 安装:

在控制台输入: npm install appium-uiautomator2-driver

我用的是cnpm安装,如果用 cnpm 安装的话请务必在你的 nodejs 目录安装,因为 cnpm 会默认安装在当前目录,会导致 node 找不到你安装的包。

__author__ = 'Woody'
from appium import webdriver


desired_capabilities = dict(platformName="Android",platformVersion=7.0,
            deviceName="6EB0217526007136",
            appPackage="net.yitu8.drivier",
            appActivity=".modles.WelcomeActivity",
            newCommandTimeout=200,
            automationName="uiautomator2")


driver = webdriver.Remote("http://127.0.0.1:4723/wd/hub", desired_capabilities)

print(driver.current_activity)


我们先来试试,一起踩坑~

首先我们在配置里边加入 automationName="uiautomator2"此选项适配 Android7.0,运行代码报错了。。

image

提示: Command 'D:\Android\android-sdk-windows\build-tools\23.0.1\aapt.exe dump badging ==D:\nodejs\node_modules\_appium-uiautomator2-driver\@0.4.0\@appium-uiautomator2-driver\uiautomator2\appium-uiautomator2-server-v0.1.6.apk==' exited with code 1

呐,缺了这个 apk~~

==前方高能==: 尽管你提示你安装成功了,但其实并没有。

比如我这儿就是如下提示:

image

提示安装次数太多,失败了。。。

一句话就想打发我?我不服。。

但是大家可以看到上面提供了下载地址, 我点开下载地址,原来是被墙了。。

没事,我给大家提供一下这 2 个文件。

UiAutomator2.zip

复制刚才提示的报错信息里的路径 (我本机) D:\nodejs\node_modules_appium-uiautomator2-driver@0.4.0@appium-uiautomator2-driver 在资源管理器打开。
然后把你下载的 zip 解压到此目录。

image

再次运行代码,OK

image

==Android7.0 环境下,case 也可以照常运行了!!!==

温馨提示: 如果不是我给的下载文件,是自己 *** 去 github 下的文件,可以看到 apk server 的版本是 0.1.8 而和报错提示的 0.1.6 不一致,我这里直接改了 0.1.8 的文件名为 0.1.6 去适配这个问题,猜测源码里写死了,手动滑稽一下~~~

adb.exe 的版本也需要注意喔,我一开始版本太低连不上 Android7.0 的机器。。

image

关键字: UiAutomator2

==有疑惑的同学欢迎大家一起讨论~~~==


↙↙↙阅读原文可查看相关链接,并与作者交流