临时 CSS 元素遮挡了我要单击的 xpath 元素。
在 Visual Studio 中使用 Selenium 我正在编写一个要单击元素的测试用例。但是当我运行这个测试用例时,我收到一条错误消息告诉我:
OpenQA.Selenium.ElementClickInterceptedException Element <a href="#/app/customer/handling/devices"> is not clickable at point (105,221) because another element <div class="showbox layout-align-center-center layout-row ng-star-inserted"> obscures it
模糊元素似乎是一个 CSS 元素。但是当我手动转到此页面,检查代码并搜索此 css 元素时 <div class="showbox layout-align-center-center layout-row ng-star-inserted">,我没有得到任何结果。
因此,我假设这个 CSS 元素是临时的,并且只能在页面加载时被识别几秒钟。Task.Delay(4000).Wait();如果我在这个测试用例中放置一个静态等待方法,我就能够完成这个测试用例,这一事实证实了这个假设。
但是我对在代码中使用静态等待方法的解决方案不感兴趣。我希望能够等待临时 css 消失,这样我就可以点击我想要的 xpath 元素。
这是我的代码:
var wait = new WebDriverWait(driver, TimeSpan.FromSeconds(30));
wait.Until(ExpectedConditions.ElementIsVisible(By.CssSelector("div class='showbox layout-align-center-center layout-row ng-star-inserted'")));
//Waiting for temporary CSS element to be visible
wait.Until(ExpectedConditions.InvisibilityOfElementLocated(By.CssSelector("div class='showbox layout-align-center-center layout-row ng-star-inserted'")));
//Waiting for temporary CSS element to disappear
wait.Until(ExpectedConditions.ElementToBeClickable(By.XPath("//div/div[2]/nav[2]/div/ul/li[1]/a"))).Click();
//Click on "Handle Tools" link
正如您在我的代码中的注释中看到的那样,我在这里做了三件事:
1. I wait for the temporary CSS to be loaded
2. I wait for it to disappear
3. I click on the xpath element.
当我这样做时,我收到一条错误消息,告诉我我要查找的 CSS 选择器无效。
如果我跳过第一步,只是等待 CSS 消失/“不可见”,它会检查得太快,并在 CSS 元素开始加载之前查看。
所以要么我没有正确编写 By.CssSelector 格式。或者 CSS 元素被称为不同于 Visual Studio 在我上面引用的错误消息中调用它的东西。
所以请告诉我,如果我在这里使用不正确的方式来识别这个 CSS 元素:
wait.Until(ExpectedConditions.InvisibilityOfElementLocated(By.CssSelector("div class='showbox layout-align-center-center layout-row ng-star-inserted'")));
或者
还有另一种动态等待临时 CSS 元素的方法吗?
或者
我能以某种方式确认隐藏 CSS 元素的名称实际上称为“div class='showbox layout-align-center-center layout-row ng-star-inserted'”吗?
慕森王
拉莫斯之舞
相关分类