Chromedriver 78 可能存在问题,Selenium 找不到在 Chrome 中打开的

在我的谷歌浏览器没有更新到版本 78 之前,我的代码工作正常。我还将 chromedriver 更新到版本 78.0.3904.70。所以我无法再使用 Selenium WebDriver 和 Java 找到 id='plugin' 的 WebElement:


<html>

<div id="content">

<embed id="plugin" type="application/x-google-chrome-pdf" src="http://??????????/offer_printed.php?printable=yes&amp;reanudar=&amp;>

</div>

</html>

除了那部分之外,我的测试工作正常。我以前从未遇到过类似的问题。我还尝试查找 WebElement id='content' 但收到相同的错误。


WebDriverWait wait = new WebDriverWait (driver, 90);

WebElement scrollvalid = wait.until(ExpectedConditions.visibilityOfElementLocated(By.id("plugin")));


scrollvalid.sendKeys(Keys.PAGE_DOWN);                       scrollvalid.sendKeys(Keys.PAGE_DOWN);

我的自动化脚本应该找到 PDF 元素并向下滚动页面。相反,我收到此错误:org.openqa.selenium.TimeoutException:等待 By.id 定位的元素的可见性 90 秒后超时:插件


有人面临类似的问题吗?提前致谢。


慕码人8056858
浏览 211回答 5
5回答

四季花海

我遇到了同样的问题。显然 Chrome 会自动更新。昨天(2019 年 10 月 29 日)我的 ChromeDriver 开始抱怨它与 Chrome 78 不兼容。我将驱动程序更新到 78 版本。当我尝试查找我确认存在的元素时,我开始收到随机的 org.openqa.selenium.NoSuchElementException 异常。当我使用断点时,findElement[s] 也可以工作。我也尝试过隐式等待,但效果有限。我尝试了 zsbappa 的 ChromeOption 解决方案,但没有任何乐趣。Google 很难获取旧版本的 Chrome,但我在https://www.neowin.net/news/google-chrome-76-offline-installer/找到了版本 76 。请注意,在线安装程序会安装最新版本。我花了 76 美元回到了司机那里,一切都很好。我所有的 Selenium 测试都恢复正常了。我的结论是,Chrome 78 及其相关驱动程序存在竞争条件,Selenium 会在网页完成之前尝试询问该网页。

芜湖不芜

我们在 Chrome 78.0.3904.7、Chromedriver 77/78、Python Selenium 3.141.0 中也遇到了类似的问题。在我们的自动化 Python Selenium 测试中,我们发现了多次失败,似乎未发生对元素的点击。更奇怪的是,该元素似乎已变为活动状态(就好像即将被单击一样),但实际的单击事件从未发生。因此,不会发生页面切换等导致各种下游故障的情况。通过反复试验,我们发现使用标准 .click() 函数现在不可靠:webdriver_element.click()但使用动作链似乎确实可靠:ActionChains(context.browser).click(webdriver_element).perform()目前尚不清楚为什么会出现这种情况。当我们升级到 Chrome 78.0.3904.7 后,故障就开始了。我们使用的是 Chromedriver 77.0.3865.90,但相同的测试在 Chrome 77.x 版本上可靠地通过,因此 Chrome 78 中似乎出现了问题或发生了变化。

ibeautiful

我昨天确认,只有当元素包含在 iframe 中时,此问题才会显现出来。在这些情况下,iframe 的位置很好。但是,尝试使用驱动程序或 Web 驱动程序等待对象来定位 Web 元素将分别产生NoSuchElement或TimeoutException。我向 chromedriver 团队提供了详细的 chrome 驱动程序日志,他们正在处理它。更新:来自chromedriver 问题 3223日志显示,直到 FindElement 返回 null 后,该帧的最终executionContextCreated 才完成。从版本 77 开始,ChromeDriver 在继续导航之前停止等待所有帧加载。不幸的是,该更改阻止了等待当前帧加载。第3164章 会全部等待当前帧加载;这应该会阻止 FindElement 进行搜索,直到框架停止加载并创建executionContext。基本上,这个错误是在 v.77 中引入的。我们中的许多人只是注意到这个问题,因为我们从 v.76 升级到了 .v78。有消息称他们的目标是修复 .v80(而不是 v.79)。Thread.sleep作为一种解决方法,我在切换到 iframe 和尝试查找组件之间使用。这个解决方法效果很好。事实上,您只需在调试模式下运行应用程序即可自行验证这一点。当您暂停执行(通过使用断点)时,您会发现原始代码(没有睡眠)工作正常。

HUWWW

通过添加以下参数我已经解决了我的问题。&nbsp;&nbsp;&nbsp;ChromeOptions&nbsp;options&nbsp;=&nbsp;new&nbsp;ChromeOptions(); &nbsp;&nbsp;&nbsp;&nbsp;options.addArguments("--disable-gpu"); &nbsp;&nbsp;&nbsp;&nbsp;options.addArguments("--disable-extensions"); &nbsp;&nbsp;&nbsp;&nbsp;options.setExperimentalOption("useAutomationExtension",&nbsp;false); &nbsp;&nbsp;&nbsp;&nbsp;options.addArguments("--window-size=1920,1080"); &nbsp;&nbsp;&nbsp;&nbsp;options.merge(seleniumCapabilities); &nbsp;&nbsp;&nbsp;&nbsp;driver&nbsp;=&nbsp;new&nbsp;ChromeDriver(options);

胡说叔叔

我在尝试访问 iframe 内的选项卡时遇到了同样的问题,它曾经在版本 76 上工作正常。现在它已更新到 78,它失败了。尝试过 waits 、隐式 waits 、 sleep 、使用 xpath、CSS、id 定位元素、 switch context 、滚动直到 view 等,但没有成功。我使用的是 Windows 10 , 1809。我不知道其他操作系统是否也会发生这种情况。
打开App,查看更多内容
随时随地看视频慕课网APP

相关分类

Java