java - 当我尝试执行 selendroid 命令时出错

标签 java selenium selendroid

我在网上读了一些教程,但我不知道我做得是否正确。

我写了这个方法,当我点击我的android应用程序的某个按钮时,我希望我点击这个按钮能够打开android浏览器并访问google。

代码:

package com.example.androidapp;

import org.openqa.selenium.WebDriver;
import org.openqa.selenium.remote.DesiredCapabilities;
import org.openqa.selenium.remote.RemoteWebDriver;

public class Sel {
	
	public void Trabalha(){
		WebDriver driver = new RemoteWebDriver(DesiredCapabilities.android());
		driver.get("http://google.com");		
		
	}

}

在此步骤之后,我将 selendroid .jar 放在我的项目 apk 的同一目录中,并尝试了以下命令:

java -jar selendroid-standalone-0.15.0

-with-dependency.jar -app AndroidApp.apk

执行此命令后,我收到一些错误 ->

C:\Users\Cleiton\workspace\AndroidApp\bin>java -jar selendroid-standalone-0.15.0
-with-dependencies.jar -app AndroidApp.apk
abr 16, 2015 10:41:50 PM io.selendroid.standalone.SelendroidLauncher main
INFORMAÃıES: ################# Selendroid #################
abr 16, 2015 10:41:50 PM io.selendroid.standalone.SelendroidLauncher main
INFORMAÃıES: ################# Configuration in use #################
abr 16, 2015 10:41:50 PM io.selendroid.standalone.SelendroidLauncher main
INFORMAÃıES: io.selendroid.standalone.SelendroidConfiguration@3b07d329[
  port=4444
  timeoutEmulatorStart=300000
  supportedApps=[AndroidApp.apk]
  verbose=false
  emulatorPort=5560
  deviceScreenshot=false
  selendroidServerPort=8080
  keystore=<null>
  keystorePassword=<null>
  keystoreAlias=<null>
  emulatorOptions=<null>
  keepEmulator=false
  registrationUrl=<null>
  proxy=<null>
  serverHost=<null>
  keepAdbAlive=false
  maxSession=5
  maxInstances=5
  noWebViewApp=false
  noClearData=false
  sessionTimeoutSeconds=1800
  forceReinstall=false
  logLevel=ERROR
  deviceLog=true
  serverStartTimeout=20000
  printHelp=false
  serverStartRetries=5
  folder=<null>
]
abr 16, 2015 10:41:50 PM io.selendroid.standalone.SelendroidLauncher launchServe
r
INFORMAÃıES: Starting Selendroid standalone on port 4444
abr 16, 2015 10:41:50 PM io.selendroid.standalone.SelendroidLauncher launchServe
r
GRAVE: Error building server: Environment variable 'ANDROID_HOME' was not found!

Exception in thread "main" io.selendroid.server.common.exceptions.SelendroidExce
ption: Environment variable 'ANDROID_HOME' was not found!
        at io.selendroid.standalone.android.AndroidSdk.androidHome(AndroidSdk.ja
va:97)
        at io.selendroid.standalone.android.AndroidSdk.platformToolsHome(Android
Sdk.java:86)
        at io.selendroid.standalone.android.AndroidSdk.aapt(AndroidSdk.java:39)
        at io.selendroid.standalone.android.impl.DefaultAndroidApp.deleteFileFro
mWithinApk(DefaultAndroidApp.java:107)
        at io.selendroid.standalone.builder.SelendroidServerBuilder.deleteFileFr
omAppSilently(SelendroidServerBuilder.java:135)
        at io.selendroid.standalone.builder.SelendroidServerBuilder.resignApp(Se
lendroidServerBuilder.java:144)
        at io.selendroid.standalone.server.model.SelendroidStandaloneDriver.addT
oAppsStore(SelendroidStandaloneDriver.java:121)
        at io.selendroid.standalone.server.model.SelendroidStandaloneDriver.init
ApplicationsUnderTest(SelendroidStandaloneDriver.java:155)
        at io.selendroid.standalone.server.model.SelendroidStandaloneDriver.<ini
t>(SelendroidStandaloneDriver.java:94)
        at io.selendroid.standalone.server.SelendroidStandaloneServer.initialize
SelendroidServer(SelendroidStandaloneServer.java:65)
        at io.selendroid.standalone.server.SelendroidStandaloneServer.<init>(Sel
endroidStandaloneServer.java:54)
        at io.selendroid.standalone.SelendroidLauncher.launchServer(SelendroidLa
uncher.java:65)
        at io.selendroid.standalone.SelendroidLauncher.main(SelendroidLauncher.j
ava:117)

C:\Users\Cleiton\workspace\AndroidApp\bin>

-------------已更新--------------------

更新为系统变量后,一切正常。

我成功运行了服务器!!!

但是现在,当我单击调用函数“TRABALHA”的按钮时,应用程序就会终止。

enter image description here

-----已更新------------

这是应用程序崩溃时的 logcat 输出。

04-21 16:40:53.602: E/AndroidRuntime(1092): FATAL EXCEPTION: main
04-21 16:40:53.602: E/AndroidRuntime(1092): Process: com.example.androidapp, PID: 1092
04-21 16:40:53.602: E/AndroidRuntime(1092): java.lang.NoClassDefFoundError: Failed resolution of: Lorg/openqa/selenium/remote/RemoteWebDriver;
04-21 16:40:53.602: E/AndroidRuntime(1092):     at com.example.androidapp.Sel.Trabalha(Sel.java:10)
04-21 16:40:53.602: E/AndroidRuntime(1092):     at com.example.androidapp.MainActivity.onClick(MainActivity.java:48)
04-21 16:40:53.602: E/AndroidRuntime(1092):     at android.view.View.performClick(View.java:4780)
04-21 16:40:53.602: E/AndroidRuntime(1092):     at android.view.View$PerformClick.run(View.java:19866)
04-21 16:40:53.602: E/AndroidRuntime(1092):     at android.os.Handler.handleCallback(Handler.java:739)
04-21 16:40:53.602: E/AndroidRuntime(1092):     at android.os.Handler.dispatchMessage(Handler.java:95)
04-21 16:40:53.602: E/AndroidRuntime(1092):     at android.os.Looper.loop(Looper.java:135)
04-21 16:40:53.602: E/AndroidRuntime(1092):     at android.app.ActivityThread.main(ActivityThread.java:5257)
04-21 16:40:53.602: E/AndroidRuntime(1092):     at java.lang.reflect.Method.invoke(Native Method)
04-21 16:40:53.602: E/AndroidRuntime(1092):     at java.lang.reflect.Method.invoke(Method.java:372)
04-21 16:40:53.602: E/AndroidRuntime(1092):     at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:903)
04-21 16:40:53.602: E/AndroidRuntime(1092):     at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:698)
04-21 16:40:53.602: E/AndroidRuntime(1092): Caused by: java.lang.ClassNotFoundException: Didn't find class "org.openqa.selenium.remote.RemoteWebDriver" on path: DexPathList[[zip file "/data/app/com.example.androidapp-2/base.apk"],nativeLibraryDirectories=[/vendor/lib, /system/lib]]
04-21 16:40:53.602: E/AndroidRuntime(1092):     at dalvik.system.BaseDexClassLoader.findClass(BaseDexClassLoader.java:56)
04-21 16:40:53.602: E/AndroidRuntime(1092):     at java.lang.ClassLoader.loadClass(ClassLoader.java:511)
04-21 16:40:53.602: E/AndroidRuntime(1092):     at java.lang.ClassLoader.loadClass(ClassLoader.java:469)
04-21 16:40:53.602: E/AndroidRuntime(1092):     ... 12 more
04-21 16:40:53.602: E/AndroidRuntime(1092):     Suppressed: java.lang.ClassNotFoundException: org.openqa.selenium.remote.RemoteWebDriver
04-21 16:40:53.602: E/AndroidRuntime(1092):         at java.lang.Class.classForName(Native Method)
04-21 16:40:53.602: E/AndroidRuntime(1092):         at java.lang.BootClassLoader.findClass(ClassLoader.java:781)
04-21 16:40:53.602: E/AndroidRuntime(1092):         at java.lang.BootClassLoader.loadClass(ClassLoader.java:841)
04-21 16:40:53.602: E/AndroidRuntime(1092):         at java.lang.ClassLoader.loadClass(ClassLoader.java:504)
04-21 16:40:53.602: E/AndroidRuntime(1092):         ... 13 more
04-21 16:40:53.602: E/AndroidRuntime(1092):     Caused by: java.lang.NoClassDefFoundError: Class not found using the boot class loader; no stack available

最佳答案

set ANDROID_HOME=C:\<installation location>\android-sdk-windows
set PATH=%PATH%;%ANDROID_HOME%\tools;%ANDROID_HOME%\platform-tools

尝试通过cmd设置ANDROID_HOME,因为我在最初启动服务器时也遇到了同样的问题,但在 Getting Started with Selendroid 时他们提供了一个设置 ANDROID_HOME 变量的链接,该变量通过 cmd 设置它。

关于java - 当我尝试执行 selendroid 命令时出错,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29688884/

相关文章:

java - Spring 集成 sftp :inbound-channel-adapter delete-remote-files=false

java - 无法对 ROOM 和 Retrofit 使用相同的模型

java - 无法获取星期几

ruby - 使用 Cucumber - Selenium Ruby 测试报告输出

selenium - 到达错误页面 : about:neterror when trying to navigate to other tabs if there is a form submit under that tab

java - 发现多个文件的操作系统独立路径为 'README.md'

java - Hibernate一对多问题

java - 具有优先级的测试用例执行的 TestNG 顺序

selenium-webdriver - 如何在 Appium ( selenium Java ) 中测试 Android Toast 消息

android - apk 没有 INTERNET 权限。 Selendroid 需要互联网许可才能继续