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)
?
您想要做的事情基本上有三种选择.
使用time.sleep(...).
这是现实世界发展最糟糕的选择.这很糟糕,因为您可以保证每次都等待指定的时间.如果您发现有时您需要5秒钟才能通过测试,那么如果您等待的条件在1秒内准备就绪,您仍然需要等待5秒钟.在一个实质性的测试套件中,这些等待将累计并增加运行套件所需的总时间.
使用Selenium的隐式等待.
优点是你可以设置一个隐含的等待而忘记它.在等待之后,您不必在等待之后指定等待.但问题是隐式等待不会与显式等待混合.在这个答案中,很好地解释了为什么它们不混合的细节.根据我的经验,使用隐式等待只能在非常简单的情况下很好地工作.
使用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 次 |
| 最近记录: |