java使用Appium测试Android Webview的各种问题
我有一个混合应用程序,主要是一个网络视图。以下是基本测试的代码:
@BeforeClass
public static void setupAppium() throws MalformedURLException {
DesiredCapabilities capabilities = new DesiredCapabilities();
capabilities.setCapability("appium-version", "1.5.3");
capabilities.setCapability("platformName", "Android");
capabilities.setCapability("platformVersion", "6.0");
capabilities.setCapability(MobileCapabilityType.DEVICE_NAME, "AppiumTesterDevice");
capabilities.setCapability("app", "/work/builds/unify/app/build/outputs/apk/app-debug.apk");
capabilities.setCapability("appPackage", "com.company.unify");
capabilities.setCapability("appActivity", "AdministerActivity");
driver = new AndroidDriver<>(new URL("http://0.0.0.0:4723/wd/hub"), capabilities);
}
@Test
public void CompanyUrlTest() {
driver.findElement(By.xpath("//安卓.widget.LinearLayout[1]/安卓.widget.FrameLayout[1]/安卓.widget.LinearLayout[1]/安卓.widget.LinearLayout[1]/安卓.widget.EditText[1]")).clear();
driver.findElement(By.xpath("//安卓.widget.LinearLayout[1]/安卓.widget.FrameLayout[1]/安卓.widget.LinearLayout[1]/安卓.widget.LinearLayout[1]/安卓.widget.EditText[1]")).sendKeys(companyserverUrl);
driver.findElement(By.xpath("//安卓.widget.LinearLayout[1]/安卓.widget.FrameLayout[1]/安卓.widget.LinearLayout[1]/安卓.widget.LinearLayout[3]/安卓.widget.Button[2]")).click();
}
@Test
public void SimpleTest() {
driver.context("WEBVIEW_com.company.unify");
WebDriverWait wait = new WebDriverWait(driver,20);
wait.until(ExpectedConditions.visibilityOfElementLocated(By.cssSelector(".localPickerList")));
driver.findElementByCssSelector(".localePickerList").click();
driver.findElementByCssSelector(".SPANISH_PR").click();
}
第一个测试很好,因为它只是在普通的安卓应用程序上运行,没有webview。因此,它只是在文本字段中更改URL,然后按下按钮将我们带到webview中的URL
第二个测试是出现问题的地方,问题的变化取决于安卓版本和chromedriver版本。我在谷歌上搜索了很多次,只能断定appium/selendroid/chromedriver上有无数的bug
我从https://sites.google.com/a/chromium.org/chromedriver/downloads下载了最新的Chromedriver。在我的appium设置中,我已经将chromedriver路径设置为指向这个位置。在我的Android 6.0中,这个版本的ChromeDriver出现了以下错误:
org.openqa.selenium.WebDriverException: An unknown server-side error occurred while processing the command. Original error: Can't stop process; it's not currently running (WARNING: The server did not provide any stacktrace information)
Command duration or timeout: 224 milliseconds
Build info: version: 'unknown', revision: '1969d75', time: '2016-10-18 09:43:45 -0700'
System info: host: 'company-me-m', ip: '192.168.1.154', os.name: 'Mac OS X', os.arch: 'x86_64', os.version: '10.11.4', java.version: '1.8.0_45'
Driver info: io.appium.java_client.安卓.AndroidDriver
Capabilities [{app=/work/builds/unify/app/build/outputs/apk/app-debug.apk, appPackage=com.company.unify, networkConnectionEnabled=true, warnings={}, databaseEnabled=false, deviceName=emulator-5554, platform=LINUX, deviceUDID=emulator-5554, appActivity=AdministerActivity, desired={app=/work/builds/unify/app/build/outputs/apk/app-debug.apk, appPackage=com.comany.unify, appActivity=AdministerActivity, appium-version=1.5.3, platformVersion=6.0, automationName=Appium, platformName=Android, deviceName=AppiumTesterDevice}, appium-version=1.5.3, platformVersion=6.0, webStorageEnabled=false, locationContextEnabled=false, automationName=Appium, takesScreenshot=true, javascriptEnabled=true, platformName=Android}]
Session ID: bc7100bd-2498-47d2-b0f2-3b29602c8e0d
at sun.reflect.NativeConstructorAccessorImpl.newInstance0(Native Method)
at sun.reflect.NativeConstructorAccessorImpl.newInstance(NativeConstructorAccessorImpl.java:62)
at sun.reflect.DelegatingConstructorAccessorImpl.newInstance(DelegatingConstructorAccessorImpl.java:45)
at java.lang.reflect.Constructor.newInstance(Constructor.java:422)
at org.openqa.selenium.remote.ErrorHandler.createThrowable(ErrorHandler.java:216)
at org.openqa.selenium.remote.ErrorHandler.throwIfResponseFailed(ErrorHandler.java:168)
at org.openqa.selenium.remote.RemoteWebDriver.execute(RemoteWebDriver.java:635)
at io.appium.java_client.DefaultGenericMobileDriver.execute(DefaultGenericMobileDriver.java:40)
at io.appium.java_client.AppiumDriver.execute(AppiumDriver.java:1)
at io.appium.java_client.安卓.AndroidDriver.execute(AndroidDriver.java:1)
at io.appium.java_client.AppiumDriver.context(AppiumDriver.java:557)
at com.comapny.UnifyAppiumJunit.BasicTest.SimpleTest(BasicTest.java:57)
如果没有在appium选项中设置这个版本的Chromedriver,我会得到一个不同的错误(但是,当我没有指定Chromedriver时,我不知道它使用什么Chromedriver可执行文件)。这是一个错误:
Jan 27, 2017 3:02:39 PM org.openqa.selenium.support.ui.ExpectedConditions findElement
WARNING: WebDriverException thrown by findElement(By.cssSelector: .localPickerList)
org.openqa.selenium.NoSuchSessionException: no such session
在这两种情况下,它似乎都不允许我的webview加载。当应用程序加载webview时,代码仍在运行,这看起来很糟糕。为什么等待似乎没有起作用?这有关系吗
最后,如果我使用Android 5.1.1仿真器,会出现以下错误:
WebDriverException thrown by findElement org.openqa.selenium.WebDriverException: unknown error: Maximum call stack size exceeded
有什么想法吗?为了这个,我整天都在和谷歌碰头
# 1 楼答案
使用新的UIautomator,您无需将驱动程序切换到webview。它具有识别webView内部元素的内置功能
请更新您的Android SDK一次
WebView中的元素将在Android版本6.0+的UIAutomator中可见。但是,一旦您为Android 6.0+设备自动化了脚本,您就可以为低于6.0的Android版本使用相同的脚本
您还可以使用UIAutomator在Android 6.0+设备上查看webView中的元素
有关更多信息,请参阅此link