【问题标题】:Unable to run appium tests on Android 7.0无法在 Android 7.0 上运行 appium 测试
【发布时间】:2017-08-23 10:47:03
【问题描述】:

我在 Android 7.0 真实设备 (Nexus 6) 上运行测试时遇到问题 Appium 版本:1.6.3 操作系统:Windows 10 语言:Java Java客户端:4.1.2

有趣的是,当我插入任何 Android 6 设备(将 platformVersion 设置为 6.0)时 - 测试运行没有问题。但是当我尝试在 Android 7.0 设备上运行它们时,我得到了错误。

以下是我在 Android 7.0 上运行的能力:

DesiredCapabilities capabilities = new DesiredCapabilities();
capabilities.setCapability("deviceName", "Android");
capabilities.setCapability("browserName", "Android");
capabilities.setCapability("platformName", "Android");
capabilities.setCapability("platformVersion", "7.0");
capabilities.setCapability("fullReset", true);
capabilities.setCapability("autoAcceptAlerts", true);
capabilities.setCapability("newCommandTimeout", 0);
capabilities.setCapability("app", "C:\Apk\xxx-release.apk");
capabilities.setCapability("appPackage", "com.xxx.android.vvm");
capabilities.setCapability("appActivity", "com.xxx.android.vvm.activity.Splash");

以下是 IDE 控制台输出的日志:

    Feb 14, 2017 4:21:19 PM org.openqa.selenium.remote.ProtocolHandshake createSession
INFO: Attempting bi-dialect session, assuming Postel's Law holds true on the remote end
Feb 14, 2017 4:21:24 PM org.openqa.selenium.remote.ProtocolHandshake createSession
INFO: Falling back to original OSS JSON Wire Protocol.
Feb 14, 2017 4:21:29 PM org.openqa.selenium.remote.ProtocolHandshake createSession
INFO: Falling back to straight W3C remote end connection

org.openqa.selenium.SessionNotCreatedException: Unable to create new remote session. desired capabilities = Capabilities [{app=C:\Apk\xxx-release.apk, appPackage=com.xxx.android.vvm, appActivity=com.xxx.android.vvm.activity.Splash, newCommandTimeout=0, platformVersion=7.0, browserName=Android, platformName=Android, deviceName=Android, fullReset=true, autoAcceptAlerts=true}], required capabilities = Capabilities [{}]
Build info: version: '3.0.1', revision: '1969d75', time: '2016-10-18 09:48:19 -0700'
System info: host: 'TAC-45', ip: '10.3.184.68', os.name: 'Windows 10', os.arch: 'amd64', os.version: '10.0', java.version: '1.8.0_111'
Driver info: driver.version: AndroidDriver

at org.openqa.selenium.remote.ProtocolHandshake.createSession(ProtocolHandshake.java:91)

这里是服务器日志:

[debug] [AndroidDriver] Not cleaning generated files. Add clearSystemFiles capability if wanted.
[MJSONWP] Encountered internal error running command: Error: Error executing adbExec. Original error: 'Command 'C\:\Android\sdk\platform-tools\adb.exe -P 5037 -s ZX1G22D7HJ install C\:\Users\user\AppData\Roaming\npm\node_modules\appium\node_modules\io.appium.settings\bin\settings_apk-debug.apk' exited with code 1'; Stderr: 'Failed to install C:\Users\user\AppData\Roaming\npm\node_modules\appium\node_modules\io.appium.settings\bin\settings_apk-debug.apk: Failure [INSTALL_FAILED_UPDATE_INCOMPATIBLE: Package io.appium.settings signatures do not match the previously installed version; ignoring!]'; Code: '1'
at ADB.execFunc$ (../../../lib/tools/system-calls.js:195:13)
at tryCatch (C:\Users\user\AppData\Roaming\npm\node_modules\appium\node_modules\babel-runtime\regenerator\runtime.js:67:40)
at GeneratorFunctionPrototype.invoke as _invoke
at GeneratorFunctionPrototype.prototype.(anonymous function) as throw
at GeneratorFunctionPrototype.invoke (C:\Users\user\AppData\Roaming\npm\node_modules\appium\node_modules\babel-runtime\regenerator\runtime.js:136:37)
at process.tickCallback (internal/process/nexttick.js:103:7)
[HTTP] <-- POST /wd/hub/session 500 4879 ms - 754
[HTTP] --> POST /wd/hub/session {"capabilities":{"desiredCapabilities":{"app":"C:\Apk\xxx-release.apk","appPackage":"com.xxx.android.vvm","appActivity":"com.xxx.android.vvm.activity.Splash","newCommandTimeout":0,"platformVersion":"7.0","browserName":"Android","platformName":"Android","deviceName":"Android","fullReset":true,"autoAcceptAlerts":true},"requiredCapabilities":{}}}
[debug] [MJSONWP] Bad parameters: BadParametersError: Parameters were incorrect. We wanted {"required":["desiredCapabilities"],"optional":["requiredCapabilities","capabilities","sessionId","id","sessionId","id","sessionId","id"]} and you sent ["capabilities"]

功能似乎存在错误。但是,当我插入装有 Android 6 的手机并将 platformVersion 设置为 6.0 时,所有测试都可以正常运行!

我将不胜感激。

【问题讨论】:

    标签: android appium


    【解决方案1】:

    从设备中删除“解锁”和“Appium 设置”应用程序 - Appium 会自动安装这些应用程序。 (由于我的原因,这些应用在将 Android 从版本 6 更新到版本 7 后不兼容。

    【讨论】:

    • 这值得更多“向上箭头”。确实帮助了我
    【解决方案2】:

    你能发布 Java-Client 版本吗?

    注意:尝试最新的稳定 Java 客户端版本。

    https://mvnrepository.com/artifact/io.appium/java-client/4.1.2

    【讨论】:

    • 是的,我有 4.1.2
    【解决方案3】:

    删除每次尝试在设备上安装的“app”功能。相反,请在设备上手动安装该应用程序并尝试。如果它不起作用,请告诉我还有另一种解决方案,但我建议您先尝试一下。

    【讨论】:

    • 删除“应用程序”功能没有帮助。它显示相同的错误
    【解决方案4】:

    如错误日志所示

    [INSTALL_FAILED_UPDATE_INCOMPATIBLE: Package io.appium.settings signatures do not match the previously installed version;
    

    这些错误通常是由于设备上有一个签名的发布版本,然后尝试在上面部署调试版本。它卡在未完全卸载的无效状态。

    由于这些原因,您的会话未创建,为避免这些原因,请卸载设备上存在的应用程序,然后运行脚本。它应该可以工作。

    希望这些对你有所帮助。

    【讨论】:

    • 不幸的是,它没有用。再一次,无论是否安装了应用程序,我都能够在 Android 6 上运行测试。我认为问题出在:'错误参数:BadParametersError:参数不正确。我们想要 {"required":["desiredCapabilities"],"optional":["requiredCapabilities","capabilities","sessionId","id","sessionId","id","sessionId","id"] } 并且你发送了 ["capabilities"]' 但我找不到答案到底是什么问题
    • okey 那么您应该尝试使用最小参数尝试使用您怀疑的最小功能并运行脚本
    【解决方案5】:

    如果您遇到此错误,请使用 Android Studio 从您的测试设备中卸载所有工件。打开 Android Studio 右侧的 Gradle 视图。

    打开 :app > 任务 > 双击安装并运行 uninstallAll 任务

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 1970-01-01
      • 2017-11-07
      • 2015-05-27
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 2019-07-08
      相关资源
      最近更新 更多