Selenium - 在每行代码之后等待

alm*_*gra 2 python selenium webdriver

我正在使用Selenium(python)来测试Web应用程序.但是,有时一行代码会触发错误,导致第一行没有足够的时间来运行.例如:

...
driver.find_element_by_id("form_widget_date").click()
driver.find_element_by_link_text(str(self.day)).click()
...
Run Code Online (Sandbox Code Playgroud)

其结果是,第二行(有时)woudn't找到LINK_TEXT因为硒,显然,没有足够的时间完成第一线.当我在线之间进行睡眠时,不会发生错误.

我的问题是:有没有办法让每行代码自动等待一段时间,而不是像这样解决它:

...
time.sleep(2)
driver.find_element_by_id("form_widget_date").click()
time.sleep(2)
driver.find_element_by_link_text(str(self.day)).click()
time.sleep(2) 
...
Run Code Online (Sandbox Code Playgroud)

Lou*_*uis 8

您想要做的事情基本上有三种选择.

  1. 使用time.sleep(...).

    这是现实世界发展最糟糕的选择.这很糟糕,因为您可以保证每次都等待指定的时间.如果您发现有时您需要5秒钟才能通过测试,那么如果您等待的条件在1秒内准备就绪,您仍然需要等待5秒钟.在一个实质性的测试套件中,这些等待将累计并增加运行套件所需的总时间.

  2. 使用Selenium的隐式等待.

    优点是你可以设置一个隐含的等待而忘记它.在等待之后,您不必在等待之后指定等待.但问题是隐式等待不会与显式等待混合.在这个答案中,很好地解释了为什么它们不混合的细节.根据我的经验,使用隐式等待只能在非常简单的情况下很好工作.

  3. 使用Selenium的显式等待.

    如果您的应用程序属于动态类型,如果您有Ajax,如果您动态修改DOM,您将不得不迟早使用显式等待,此时您将停止依赖隐式等待.缺点是你的代码会更加冗长.您可以使用包装函数来缓解它.这是一个如何做到的例子,假设driver设置为一个WebDriver对象:

    from selenium.webdriver.common.by import By
    from selenium.webdriver.support.ui import WebDriverWait
    
    
    class MyDriver(object):
        def __init__(self, driver, default_timeout=2):
            self.driver = driver
            self.timeout = default_timeout
    
        def find_element(self, locator):
            return WebDriverWait(self.driver, self.timeout).until(
                EC.presence_of_element_located(locator))
    
    mydriver = MyDriver(driver)
    foo = mydriver.find_element((By.CSS_SELECTOR, ".foo"))
    
    Run Code Online (Sandbox Code Playgroud)


归档时间:

查看次数:

3390 次

最近记录:

11 年,7 月 前