如何使用 Selenium WebDriver 等待重定向链在最终页面加载不可预测的情况下解决?

Avi*_*ash 6 url selenium redirect selenium-webdriver webdriverwait

我想自动化一个脚本来验证网页中的某些内容。

登录页面在登陆应用程序页面之前重定向了几次,这些重定向偶尔会导致问题。这个问题肯定与时间有关。那么 webdriver 如何等到最终页面完全加载或稳定?

典型的解决方案是等待目标页面上的元素变为可用。不幸的是,我们使用了 100 多个唯一网址,因此没有可预测的着陆页。

那么如何实现一个 ExpectedCondition 来等待应用程序在重定向方面稳定下来呢?

主要议程是,我有一组 URL,我想通过检查其中的内容来验证所有这些 URL 是否有效。所有这些都是我的组织合作的学习内容的直接 URL,例如 Lynda、skillsoft 等。因此,当我们首先通过自动脚本启动这些 URL 时,它会询问身份验证(我的组织凭据),然后它会重定向到相应的站点。在这些重定向期间,在某些情况下会发生多次重定向,最后加载内容页面。这就是场景。我猜我的脚本失败主要是因为等待

Deb*_*anB 7

正如你提到的multiple redirection happening and finally the content page is loaded,这script fails mainly due to the wait几乎是可能的。在这些情况下,我们需要将ExplicitWaitie WebDriverWaitwithexpected_conditions子句设置为以下任一项:


爪哇:

  1. urlToBe:检查当前 url 的期望是完全匹配。

    new WebDriverWait(driver, 10).until(ExpectedConditions.urlToBe("https://www.facebook.com/"));
    
    Run Code Online (Sandbox Code Playgroud)
  2. urlContains: 检查当前 url 是否包含区分大小写的子字符串的期望。

    new WebDriverWait(driver, 10).until(ExpectedConditions.urlContains("facebook"));
    
    Run Code Online (Sandbox Code Playgroud)
  3. urlMatches: 检查当前 url 模式的期望是预期模式必须完全匹配。

    new WebDriverWait(driver, 10).until(ExpectedConditions.urlMatches("my_regex"));
    
    Run Code Online (Sandbox Code Playgroud)

Python :

  1. url_to_be:期望当前页面的 URL 是一个特定的 url。

    WebDriverWait(driver, 10).until(EC.url_to_be("https://www.google.co.in/"))
    
    Run Code Online (Sandbox Code Playgroud)
  2. url_matches:期望 URL 匹配特定的正则表达式。

    WebDriverWait(driver, 10).until(EC.url_matches("my_regex"))
    
    Run Code Online (Sandbox Code Playgroud)
  3. url_contains:期望当前页面的 URL 包含特定文本。

    WebDriverWait(driver, 10).until(EC.url_contains("google"))
    
    Run Code Online (Sandbox Code Playgroud)
  4. url_changes: 检查当前 url 的期望,它不能完全匹配。

    WebDriverWait(driver, 10).until(EC.url_changes("https://www.google.co.in/"))
    
    Run Code Online (Sandbox Code Playgroud)