2017-02-16 9 views
4

にappiumテストを実行することができません(ネクサス6) Appiumバージョン:1.6.3 OS:Windowsの10 言語:Javaの Javaクライアント:4.1.2私は、Android 7.0実際のデバイス上でテストを実行しているとの問題を抱えているのAndroid 7.0

興味深いことに、Android 6デバイスを接続すると(platformVersionを6.0に設定)、テストは問題なく実行されています。しかし、私はAndroid 7.0のデバイスでそれらを実行しようとすると、私はエラーが表示されます。ここで

は、Android 7.0上で実行するために私の能力を以下のとおりです。

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"] 
ここ

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のコンソール出力からのログがあります

機能にエラーがあるようです。しかし、Android 6を搭載した電話機を接続し、platformVersionを6.0に設定すると、すべてのテストが問題なく実行されます。

私は助けていただきありがとうございます。

答えて

5

デバイスから「アンロック」と「Appium設定」アプリを削除する - Appiumはこれらのアプリを自動的にインストールします。 (私の場合、バージョン6からバージョン7にAndroidをアップデートした後、これらのアプリは互換性がありませんでした。

+0

ありがとうございました! – APC551

+0

これは、より多くの "矢のアップ"に値する。 確かに手伝ってください – Dmitry

0

Javaクライアントバージョンを投稿できますか?

注:最新の安定したJavaクライアントバージョンをお試しください。

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

+0

うん、それをクリックすることでuninstallAllタスクをインストールして実行、私はそれを示して助けにはならなかった「アプリ」機能を削除4.1.2 – APC551

0

デバイス上のすべての時間をインストールしようとすると、「アプリ」機能を削除します。代わりに、デバイスに手作業でアプリをインストールし、試してみてください。それがうまくいかない場合はもう1つの解決方法があることをお知らせしますが、最初に試してみることをお勧めします。エラーログとして

+0

を持っています。同じエラー – APC551

0

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

を示し通常、これらのエラーは、上部のデバッグバージョンを展開しようとし、その後、デバイス上の署名リリースバージョンを持つことになります。完全にアンインストールされていない無効な状態になってしまいます。

あなたのセッションは作成されていないため、これらを避けるために、デバイス上に存在するアプリケーションをアンインストールしてからスクリプトを実行してください。動作するはずです。

これらの情報が役立ちます。

+0

残念ながら、それはうまくいかなかったし、アプリのインストールの有無に関係なく、Android 6でテストを実行することができました。私は問題がこれにあると思う: 'Bad parameters:BadParametersError:パラメータが間違っていた。私たちは{"required": "desiredCapabilities"、 "optional":["requiredCapabilities"、 "capabilities"、 "sessionId"、 "id"、 "sessionId"、 "id"、 "sessionId"、 "id"] }あなたは["capabilities"] 'を送った しかし、私は正確に何が間違っているのか答えを見つけることができませんでした – APC551

+0

okey次に、最小限のパラメータで試してみてください。疑問があり、スクリプトを実行してください。 –

0

このエラーが発生した場合、Androidスタジオを使用してテストデバイスからすべての成果物をアンインストールします。 Androidのスタジオ

オープン:アプリ>タスク>ダブル

関連する問題