appium+python自动化36-android7.0连不上的问题

前言

由于最近很多android手机升级到7.0系统了,有些小伙伴的appium版本用的还是1.4版本,在运行android7.0的app自动化时候遇到无法启动问题:WebDriverException: Message: A new session could not be created

我的电脑环境:

  • python 3.6
  • android 7.0
  • appium 1.4.13

android7.0遇到问题

1.执行代码:

# coding:utf-8

# 作者:上海-悠悠

from appium import webdriver
from time import sleep
desired_caps = {
                'platformName': 'Android',
                'deviceName': 'A5RNW18316011440',
                'platformVersion': '7.0',
                'appPackage': 'com.baidu.yuedu',
                'appActivity': 'com.baidu.yuedu.splash.SplashActivity'
                }
driver = webdriver.Remote('http://127.0.0.1:4723/wd/hub', desired_caps)

2.执行后报错如下:A new session could not be created

D:\soft\python3.6\python.exe D:/xcm_app_test/app/test_login.py
Traceback (most recent call last):
  File "D:/xcm_app_test/app/test_login.py", line 11, in <module>
    driver = webdriver.Remote('http://127.0.0.1:4723/wd/hub', desired_caps)
  File "D:\soft\python3.6\lib\site-packages\appium\webdriver\webdriver.py", line 36, in __init__
    super(WebDriver, self).__init__(command_executor, desired_capabilities, browser_profile, proxy, keep_alive)
  File "D:\soft\python3.6\lib\site-packages\selenium\webdriver\remote\webdriver.py", line 90, in __init__
    self.start_session(desired_capabilities, browser_profile)
  File "D:\soft\python3.6\lib\site-packages\selenium\webdriver\remote\webdriver.py", line 177, in start_session
    response = self.execute(Command.NEW_SESSION, capabilities)
  File "D:\soft\python3.6\lib\site-packages\selenium\webdriver\remote\webdriver.py", line 236, in execute
    self.error_handler.check_response(response)
  File "D:\soft\python3.6\lib\site-packages\selenium\webdriver\remote\errorhandler.py", line 192, in check_response
    raise exception_class(message, screen, stacktrace)
selenium.common.exceptions.WebDriverException: Message: A new session could not be created. (Original error: Command failed: )

分析问题

1.遇到无法启动问题,报错都一样:A new session could not be created,看编辑器报错是没啥用的,这个时候就需要打开appium的日志界面,分析走到哪一步报错了,日志太多,就贴一部分了

> info: [debug] Device is at API Level 24
> info: Device API level is: 24
> info: [debug] Extracting strings for language: default
> info: [debug] Apk doesn't exist locally
> info: [debug] Could not get strings, but it looks like we had an old strings file anyway, so ignoring

2.从上面日志可以看出,当前的设备API版本是24,而appium1.4支持的最高API版本是23。打开appium客户端,左上角点机器人图标,点开platformVersion如下图所示

3.也就是说appium1.4支持最高android版本是6.0,查下资料可以知道android7.0需使用appium1.6.3以上版本才能支持。

解决问题

1.重新下载最新版appium,appium1.6以后版本都是以appium-desktop命名的,目前我使用的版本是appium-desktop1.2.2,安装完之后也就是V1.7.1版本

2.appium-desktop所以版本在github都能下载到: appium-desktop 所有版本下载地址(https://github.com/appium/appium-desktop/tags)

3.appium-desktop和之前老的appium版本是可以共存的,所有不需要卸载之前的版本,重新打开appium1.7版本,运行代码

4.重新运行时候发现报这个错,从报错信息看是手机上安装的unlock版本不匹配(因为之前运行appium1.4版本有残留),解决办法:手动卸载手机上的appium settings和Unlock就可以了

selenium.common.exceptions.WebDriverException: 
Message: An unknown server-side error occurred while processing the 
command. Original error: Error executing adbExec. Original error: 
'Command 'D\:\\soft\\Android\\platform-tools\\adb.exe 
-P 5037 -s A5RNW18316011440 install C\:\\Users\\admin\\AppData\\Local
\\Programs\\appium-desktop\\resources\\app\\node_modules\\appium\\
node_modules\\appium-unlock\\bin\\unlock_apk-debug.apk' exited with 
code 1'; Stderr: 'Failed to install C:\Users\admin\AppData\Local\
Programs\appium-desktop\resources\app\node_modules\appium\node_module
s\appium-unlock\bin\unlock_apk-debug.apk: Failure [INSTALL_FAILED_UPDA
TE_INCOMPATIBLE: Package io.appium.unlock signatures do not match 
the previously installed version; ignoring!]'; Code: '1'

备注

1.有些小伙伴可能用的appium1.6版本,可以尝试加上这个参数,用uiautomator2运行

‘automationName’: ‘uiautomator2’

# coding:utf-8

# 作者:上海-悠悠

from appium import webdriver
from time import sleep
desired_caps = {
                'platformName': 'Android',
                'deviceName': 'A5RNW18316011440',
                'platformVersion': '7.0',
                'automationName': 'uiautomator2',
                'appPackage': 'com.baidu.yuedu',
                'appActivity': 'com.baidu.yuedu.splash.SplashActivity'
                }
driver = webdriver.Remote('http://127.0.0.1:4723/wd/hub', desired_caps)

原文发布于微信公众号 - 从零开始学自动化测试(yoyoketang)

原文发表时间:2018-04-09

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏zhangdd.com

windows系统Tomcat启动过程中找不到JAVA_HOME解决方法

在winserver上明明已经安装了JDK1.6并设置好了JAVA_HOME,可偏偏Tomcat在启动过程中找不到。

9710
来自专栏FreeBuf

三星KNOX远程静默安装漏洞深入分析报告

漏洞来源 11月中旬,三星手机被国外安全研究人员曝光了一个严重的安全漏洞,该漏洞影响Galaxy S5,S4,S4 mini,Note 4,Note3以及Ace...

26290
来自专栏SDNLAB

脱坑神器,让你一步了解ODL控制器集群

一、控制器集群基本知识 1.1 Consensus一致性 Consensus一致性是指多个服务器在状态达成一致,但是在一个分布式系统中,因为各种意外可能,有的...

48970
来自专栏黑白安全

php漏洞与代码审计

在甲方公司做代码审计一般还是以白盒为主,漏洞无非这么几类,XSS、sql注入、命令执行、上传漏洞、本地包含、远程包含、权限绕过、信息泄露等。

15150
来自专栏雪胖纸的玩蛇日常

python3+django2 开发易语言网络验证(上)

40240
来自专栏安富莱嵌入式技术分享

【安富莱】【RL-TCPnet网络教程】第8章 RL-TCPnet网络协议栈移植(RTX)

本章教程为大家讲解RL-TCPnet网络协议栈的RTX操作系统移植方式,学习了第6章讲解的底层驱动接口函数之后,移植就比较容易了,主要是添加库文件、配置文件和驱...

17440
来自专栏腾讯移动品质中心TMQ的专栏

像 google 一样测试系列之六: 实战篇

本文主要介绍 google 一样测试系列的实战内容,Mock 和反射执行,会穿插在各章节中,因此不单独成节了。

17710
来自专栏王磊的博客

深入解读RabbitMQ工作原理及简单使用

MQ全称是Message Queue,可以理解为消息队列的意思,简单来说就是消息以管道的方式进行传递。

39720
来自专栏恰童鞋骚年

.NET Core微服务之基于Consul实现服务治理(续)

上一篇发布之后,很多人点赞和评论,不胜惶恐,这一篇把上一篇没有弄到的东西补一下,也算是给各位前来询问的朋友的一些回复吧。

18350
来自专栏calvin

jira webhook 事件触发并程序代码调用jenkins接口触发构建操作

开发管理工具触发站点构建事件,事件处理中需要调用Jenkins接口开始构建动作。 我的应用场景: 使用jira作为管理工具,在jira中创建自定义的工作流来...

91230

扫码关注云+社区

领取腾讯云代金券