我正在尝试在 Android 模拟器(Mac)上运行https://code.google.com/p/selenium/wiki/AndroidDriver#Run_the_Tests中的示例测试,但是在尝试运行测试时遇到了问题.
我已经设置了一个模拟器并安装了 WebDriver APK,然后在 Eclipse 中我创建了一个新的 Android 应用程序项目并创建了一个类 OneTest.java 并复制了代码(也导入了 org.openqa.selenium.WebDriver;示例代码)。然后我将两个 selenium-java-2.33.0 jar 导入到库中。我还将我的 androidmanifest 更新为:
<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
package="com.example.test"
android:versionCode="1"
android:versionName="1.0" >
<uses-sdk
android:minSdkVersion="8"
android:targetSdkVersion="17" />
<application
android:allowBackup="true"
android:icon="@drawable/ic_launcher"
android:label="@string/app_name"
android:theme="@style/AppTheme" >
<activity
android:name="com.example.test.MainActivity"
android:label="@string/app_name" >
<intent-filter>
<action android:name="android.intent.action.MAIN" />
<category android:name="android.intent.category.LAUNCHER" />
</intent-filter>
</activity>
<uses-library android:name="android.test.runner" />
</application>
<instrumentation android:name="android.test.InstrumentationTestRunner"
android:targetPackage="com.example.test" />
</manifest>
当我尝试将 OneTest.java 作为 Android Junit 测试运行时,我看到了错误:
[2013-07-25 11:53:36 - Test] The library 'selenium-java-2.33.0.jar' contains native libraries that will not run on the device.
[2013-07-25 11:53:36 - Test] The following libraries were found:
[2013-07-25 11:53:36 - Test] - org/openqa/selenium/firefox/amd64/libibushandler.so
[2013-07-25 11:53:36 - Test] - org/openqa/selenium/firefox/amd64/x_ignore_nofocus.so
[2013-07-25 11:53:36 - Test] - org/openqa/selenium/firefox/x86/libibushandler.so
[2013-07-25 11:53:36 - Test] - org/openqa/selenium/firefox/x86/x_ignore_nofocus.so
如果我忽略错误并尝试再次运行它,我会看到:
[2013-07-25 11:59:43 - Test] Installing Test.apk...
[2013-07-25 11:59:44 - Test] Installation failed due to invalid APK file!
[2013-07-25 11:59:44 - Test] Please check logcat output for more details.
[2013-07-25 11:59:44 - Test] Launch canceled!
在 LogCat 中:
07-25 10:59:44.188: D/zipro(23141): Zip: EOCD not found, /data/local/tmp/Test.apk is not zip
07-25 10:59:44.188: D/asset(23141): failed to open Zip archive '/data/local/tmp/Test.apk'
07-25 10:59:44.219: W/PackageParser(23141): Unable to read AndroidManifest.xml of /data/local/tmp/Test.apk
07-25 10:59:44.219: W/PackageParser(23141): java.io.FileNotFoundException: AndroidManifest.xml
07-25 10:59:44.219: W/PackageParser(23141): at android.content.res.AssetManager.openXmlAssetNative(Native Method)
07-25 10:59:44.219: W/PackageParser(23141): at android.content.res.AssetManager.openXmlBlockAsset(AssetManager.java:487)
07-25 10:59:44.219: W/PackageParser(23141): at android.content.res.AssetManager.openXmlResourceParser(AssetManager.java:455)
07-25 10:59:44.219: W/PackageParser(23141): at android.content.pm.PackageParser.parsePackageLite(PackageParser.java:733)
07-25 10:59:44.219: W/PackageParser(23141): at com.android.defcontainer.DefaultContainerService$1.getMinimalPackageInfo(DefaultContainerService.java:171)
07-25 10:59:44.219: W/PackageParser(23141): at com.android.internal.app.IMediaContainerService$Stub.onTransact(IMediaContainerService.java:110)
07-25 10:59:44.219: W/PackageParser(23141): at android.os.Binder.execTransact(Binder.java:351)
07-25 10:59:44.219: W/PackageParser(23141): at dalvik.system.NativeStart.run(Native Method)
07-25 10:59:44.219: W/DefContainer(23141): Failed to parse package
我确实尝试了这里的建议如何解决 Selenium 中的库问题?改用 android_webdriver_library.jar ,但我在导入 org.openqa.selenium.android.AndroidDriver 时遇到错误;和 WebDriver driver = new AndroidDriver(); 我可以使用 android.AndroidWebDriver 解决第一个问题;但我无法解决 AndroidDriver() 的问题。
任何帮助都会很棒,因为我是 Eclipse/Android 菜鸟 :)
编辑:我通过添加:
<uses-permission android:name="android.permission.INTERNET" />
到清单,但我看到错误“找不到类 'org.openqa.selenium.android.AndroidDriver',从方法 com.example.test.OneTest.testGoogle 引用