Safari Bug-Selenium Actions单击方法

问题描述

我得到异常:

org.openqa.selenium.remote.UnreachablebrowserException:与远程浏览器通信时出错。它可能已经死了。

每次在Safari上使用时

Actions action = new Actions(WebDriverRunner.getWebDriver());
    action.click(packageCodeButton()).build().perform();
    

我使用browserstack(iPhone)和MacOS上的设备。当我选择12作为浏览器时,它将在MacOS上运行。

问题仅出现在Safari上,而不出现在任何其他浏览器上。它也不会计算我尝试单击哪个元素或何时执行此操作(在哪个测试阶段)。其他硒命令正常工作(我使用硒化框架)。

有人可以帮助我解决这个错误吗?

有人问了类似的问题: stack

但是所有浏览器和随机命令只有零星的问题。 就我而言,它看起来像是一些Safari驱动程序错误

编辑:

Stacktrace:

org.openqa.selenium.remote.UnreachablebrowserException:与远程浏览器通信时出错。它可能已经死了。 构建信息:版本:'3.141.59',修订版本:'e82be7d358',时间:'2018-11-14T08:17:03' 系统信息:主机:'L069G',ip:'10 .212.130.34',操作系统名称:'Windows 10',os.arch:'amd64',os.version:'10 .0',java.version:'11' 驱动程序信息:driver.version:RemoteWebDriver 功能{64bit:false,acceptSslCert:false,acceptSslCerts:false,自动名称:XCUITest,bootstrapPath:/usr/local/.browserstack/co ...,浏览器:iphone,browserName:苹果浏览器,browser_name:Safari,browserstack-tunnel:true ,browserstack.isTargetBased:否,databaseEnabled:否,detected_language:selenium / 3.141.59(java win ...,设备:iphone,deviceName:iPhone 7,deviceOrientation:PORTRAIT,javascriptEnabled:true,locationContextEnabled:false,loggingPrefs:org。 openqa.selenium.logging ...,移动设备:{浏览器:移动设备,版本:iPhone 7-12.1},networkConnectionEnabled:false,newCommandTimeout:0,new_bucketing:true,noreset:true,方向:PORTRAIT,orig_os:ios,osversion: 12,os_version:12,平台:MAC,platformName:MAC,platformVersion:12.1,realMobile:true,real_mobile:true,safari.options:{},safariIgnoreFraudWarning:true,safariInitialUrl:http:// mobile-internet-chec .. 。,sessionName:,takeScreenshot:true,udid:...,useXctestrunFile:true,版本: ,wda_port:8405,webStorageEnabled:否,webkitResponseTimeout:20000} 会话ID:

at org.openqa.selenium.remote.RemoteWebDriver.execute(RemoteWebDriver.java:573)
at org.openqa.selenium.remote.RemoteExecuteMethod.execute(RemoteExecuteMethod.java:35)
at org.openqa.selenium.remote.RemoteMouse.click(RemoteMouse.java:59)
at org.openqa.selenium.interactions.ClickAction.perform(ClickAction.java:39)
at org.openqa.selenium.interactions.CompositeAction.perform(CompositeAction.java:34)
at org.openqa.selenium.interactions.Actions$BuiltAction.perform(Actions.java:642)
at TestHelpers.Helpers.GoogleMap.selectClosestOnMapMobile(GoogleMap.java:99)(file:Tests/src/test/resources/1_SPY-2619.feature:12)

由以下原因引起:java.lang.IllegalArgumentException:预期有一个元素,但为:

browserstack可视日志显示信息:

方法尚未实现

解决方法

此错误消息...

org.openqa.selenium.remote.UnreachableBrowserException: Error communicating with the remote browser. It may have died.

...表示 RemoteWebDriver 实例突然关闭。

完整的错误堆栈跟踪将有助于更好地调试问题。但是,根据文章WebDriver fix for UnreachableBrowserException,可能的原因和解决方法可能是以下之一:

  • 如果原因是 java.net.SocketException:软件导致连接中止:recv失败:过早关闭连接时会发生此错误。它可能是由Java中的ssl证书处理引起的,这是非常随机的,因为所有http流量都由execute方法处理。因此,通过覆盖它并添加简单的重试功能,您可以提供一种解决方法。

  • 如果原因是 java.net.SocketTimeoutException:读取超时:如果您在系统上工作,那么您已经达到极限的机会可能的开放连接。通常会发生这种情况,因为Selenium创建了大量连接,即使Java触发了关闭连接命令,Windows也会保持打开/缓存状态。要解决此问题,您需要在以下位置更改Windows注册表值:

    • HKEY_LOCAL_MACHINE \ SYSTEM \ CurrentControlSet \ Services \ Tcpip \ Parameters :您需要设置/创建两个DWORD值:

      MaxUserPort = 32768
      TcpTimedWaitDelay = 30
      

    MaxUserPort将增加可能打开的连接的限制(您可以在5000-65534之间选择任意值,数值越高越好)。 TcpTimedWaitDelay确保Windows在30秒(无法设置为更低的值,但未设置此默认值为4分钟!!!)后关闭陈旧的连接(已由Java关闭)。


其他注意事项

确保:

注意:您正在使用java.version: '11'。根据记录,Selenium仍然与并不完全兼容。有关更多详细信息,请讨论Unable to import org.openqa.selenium.WebDriver using Selenium and Java 11


参考文献

您可以在以下位置找到一些相关的讨论

相关问答

Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其...
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。...
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbc...