问题描述
我得到异常:
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:读取超时:如果您在windows系统上工作,那么您已经达到极限的机会可能的开放连接。通常会发生这种情况,因为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关闭)。 -
其他注意事项
确保:
- JDK 已升级到当前级别JDK 8u251。
注意:您正在使用
java.version: '11'
。根据记录,Selenium仍然与java-11并不完全兼容。有关更多详细信息,请讨论Unable to import org.openqa.selenium.WebDriver using Selenium and Java 11
-
将硒升级到当前水平Version 3.141.59。
-
将 ChromeDriver 升级到当前的ChromeDriver v84.0级别。
-
将 Chrome 升级到当前的 Chrome v84.0 (as per ChromeDriver v84.0 release notes)。
-
(仅适用于 WindowsOS )使用CCleaner工具清除执行 Test Suite 之前和之后的所有操作系统琐事。>
-
(仅限 LinuxOS )Free Up and Release the Unused/Cached Memory in Ubuntu/Linux Mint,在执行 Test Suite 之前和之后。
-
如果您的基本 Web客户端版本太旧,请通过Revo Uninstaller卸载它,并安装最新版本的 Web客户端
-
正如您提到的每小时运行一堆测试用例 ,可能有多个 ChromeDriver 和 Chrome 悬挂的实例可以通过进程列表(Linux OS)或 TaskManager (Windows OS)查看。您需要始终在
driver.quit()
方法内调用tearDown(){}
才能正常关闭并销毁 WebDriver 和 Web Client 实例。 -
如果 WebDriver 和 Web浏览器的悬空实例仍然存在,请考虑使用蛮力杀死它们。您可以在Selenium : How to stop geckodriver process impacting PC memory,without calling driver.quit()?
中找到详细的讨论 -
如果您的程序尝试从大于5000的端口建立TCP连接,则可以参考此article
参考文献
您可以在以下位置找到一些相关的讨论
- org.openqa.selenium.remote.UnreachableBrowserException: Error communicating with the remote browser. It may have died.
- Getting "Error communicating with the remote browser. It may have died." with chromedriver
- IE11: UnreachableBrowserException: Error communicating with the remote browser. It may have died.