Appium Appium 在 Android7.0 以上版本找不到元素的问题

wuranxu · 发布于 2017年08月11日 · 最后由 guguge 回复于 2017年11月03日 · 1091 次阅读

Appium适配Android7.0以上版本

  • 测试机型: 华为荣耀V9
  • 安卓版本: Android7.0
  • appium版本: 1.65

说明:

公司新采购了一批安卓机器,拿了其中一台华为荣耀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。

  • 5037端口是否被占用

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

image

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

image

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

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

  • 安装Uiautomator2

使用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

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

共收到 9 条回复
2562

可以下载源码自己uiautomator server打包啊

3652

上个月oppo安卓7也遇到过一样的问题,也是改UiAutomator2后好了

B08795
wuranxu · #3 · 2017年08月11日 作者
2562carl 回复

哈哈,uiautomator不太熟悉,看着好像是安卓开发那块的。还望大佬指点指点~~

B08795
wuranxu · #4 · 2017年08月11日 作者
3652cs_awater 回复

😂 哈哈哈~找不到元素我也是一脸懵逼,开始慌了。。

8331

3月前 踩得坑 也是添加 UiAutomator2 后可以了

7147

我查看目录下有那两个apk的文件,在脚本设置automationName为uiautomator2
在运行过程中没有帮我自动安装那两个apk文件
报错日志如下:
selenium.common.exceptions.WebDriverException: Message: An unknown server-side error occurred while processing the command. Original error: Could not sign with default certificate. Original error Command '/Library/Java/JavaVirtualMachines/jdk1.8.0_91.jdk/Contents/Home//bin/java -jar /usr/local/lib/node_modules/appium/node_modules/._appium-adb\@2.26.0\@appium-adb/jars/sign.jar /usr/local/lib/node_modules/appium/node_modules/._appium-uiautomator2-driver\@0.5.2\@appium-uiautomator2-driver/uiautomator2/appium-uiautomator2-server-v0.1.8.apk --override' exited with code 1

B08795
wuranxu · #7 · 2017年09月11日 作者
7147zhangzili 回复

https://stackoverflow.com/questions/42816545/appium-android-app-not-signed-with-debug-cert
给你找了下对应的问题,我这边的appium是命令行启动的,不是桌面版~~

14947

WebDriverException: Message: An unknown server-side error occurred while processing the command. Original error: java.lang.SecurityException: Injecting to another application requires INJECT_EVENTS permission
这个是我的报错

appium:1.6.5
Android:7.1.1
uiautomator:uiautomator2
求大神帮忙

14947
14947guguge 回复

把小米手机换成三星的 问题解决了

10楼 已删除
需要 登录 后方可回复, 如果你还没有账号请点击这里 注册