2017-02-16 99 views
4

我有问题,在Android上运行测试7.0实设备(的Nexus 6) Appium版本:1.6.3 操作系统:Windows 10 语言:Java的 Java客户端:4.1.2无法运行在Android appium测试7.0

有趣的是,当我插入任何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时,所有测试运行都没有问题!

我将不胜感激任何帮助。

回答

5

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

+0

它的工作!谢谢! – APC551

+0

这值得更多的“箭头”。 帮助我肯定 – Dmitry

0

删除“应用”功能,它试图在设备上安装的每一次。相反,在设备上手动安装应用程序并尝试。如果它不起作用,让我知道还有一个解决方案,但我建议你先试试。

+0

取出“应用程序”的能力没有帮助它显示了同样的错误 – APC551

0

由于错误日志显示

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

通常这些错误出现,由于其设备上签署的发行版本,然后尝试部署在上面的调试版本。它陷入了一个无法完全卸载的无效状态。

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

希望这些帮助你。

+0

不幸的是,它不起作用。再次,无论应用程序是否安装,我都能够在Android 6上运行测试。我认为问题在于: '错误的参数:BadParametersError:参数不正确。我们希望{“required”:[“desiredCapabilities”],“optional”:[“requiredCapabilities”,“capabilities”,“sessionId”,“id”,“sessionId”,“id”,“sessionId”,“id”] }并且你发送了[“capabilities”]' 但是我找不到答案究竟是什么错误 – APC551

+0

okey然后你应该尝试用最小参数尝试最小功能,你有疑问并运行脚本 –

0

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

打开:。应用程序>任务>安装和运行由双uninstallAll任务单击它