Selenium3種等待方式(二)(精述篇)

1、前言

一、強制等待是sleep,強烈不推薦,設定的時間太固定,若是是模擬器等待3秒,真機可能只須要等待2秒。css

二、driver.implicitly.wat(timeout) ,貫穿所有元素的等待,只須要設定一次便可,一般是在建立driver的時候後的代碼運行,是dom創建以後的等待。html

三、顯式等待是在客戶端的等待:引用連個包和一個例子python

from selenium.webdriver.support.wait import WebDriverWait
from selenium.webdriver.support import expected_conditions
WebDriverWait(self.driver,10).until(expected_conditions.element_to_be_clickable(loca
tor))

 

2、強制等待

強制等待,線程休眠必定時間。android

import time
time.sleep(3)

 

3、隱式等待

隱式等待,就是在建立driver時,設置全局元素等待超時時間。web

當要查找元素,而這個元素沒有立刻出現時,告訴 WebDriver 查詢 Dom 必定時間,實際上瀏覽器會在你本身設定的時間內不斷的刷新頁面去尋找咱們須要的元素。面試

默認值是 0.5秒,可是設置以後,這個時間將在WebDriver 對象實例整個生命週期都起做用。(處理 Table 對象時,須要將此設置爲默認值)ajax

self.driver.implicitly_wait(10)

 

設置等待時長爲10秒,首先這10秒並不是一個固定的等待時間,它並不影響腳本的執行速度。其次,它並不針對頁面上的某一元素進行等待。瀏覽器

當腳本執行到某個元素定位是,若是元素能夠定位,則繼續執行,若是元素定位不到,則它將以輪詢的方式不斷地判斷元素是否被定位到。app

假設在第六秒定位到了元素則繼續執行,若直到超出設置的時長10秒尚未定位到元素,則拋出異常。dom

4、顯式等待

一、顯式等待的簡介

(1)顯式等待與隱式等待相對,顯式等待必須在每個須要等待的元素前面進行聲明。

(2)是針對某個特定的元素設置等待時間,在設置時間內,默認每隔一段時間檢測一次當前某個元素是否存在。

(3)若是在規定的時間內找到元素,則直接執行,即找到元素就執行相關操做。

(4)若是超過設置時間檢測不到就拋出異常,默認檢測頻率爲0.5s,默認拋出的異常時NoSuchElementException。

(5)用到的兩個經常使用類:
WebDriverWait
expected_condition

二、爲何要用顯式等待,爲何隱式等待沒法替代顯式等待?

(1)顯式等待能夠等待動態加載的ajax元素,須要配合expected_condition來檢查條件。

(2)通常頁面上元素的呈現順序是:
首先出現title。

而後是dom樹的出現,presence還不完整,dom樹出現就是隱式等待了,但此時的元素可能尚未是可點擊的狀態,因此只用隱式等待,使用click方法,確定會報錯的。

css出現:可見visbility。

js的出現,js特效執行:可點擊clickable。

(3)html文檔是自上而下加載的。

(4)js文件加載會阻塞html內容的加載,有些js異步加載的方式來完成js的加載 樣式表下載完成以後跟以前的樣式表一塊兒進行解析,會對以前那的與元素從新渲染。

(5)presence-visibility-clickabe,元素出現-可見-可點擊,是元素的三個性質,當DOM樹出現時,定位元素可能已經顯示出來了,可是可見和可點擊的屬性可能還沒加載出來,這時候元素的一些方法是不可用的,好比 element.click() ,要等到js渲染出來之後,元素的click屬性才能夠用。

對應 element.is_displayed()
對應 element.is_selected()
對應 element.is_enabled()

三、js的同步加載和異步加載

同步加載:同步模式,又稱阻塞模式,會阻止瀏覽器的後續處理,中止了後續的解析,所以中止了後續的文件加載(如圖像)、渲染、代碼執行。

異步加載:異步加載又叫非阻塞,瀏覽器在下載執行 js 同時,還會繼續進行後續頁面的處理。

四、WebDriverWait用法

WebDriverWait(self, driver, timeout, poll_frequency=POLL_FREQUENCY,
ignored_exceptions=None)

driver:瀏覽器驅動

timeout:超時時間,單位秒

poll_frequency:檢查的間隔步長,默認是0.5s

ignored_exceptions:超時最後的拋出的異常,默認是NoSuchElementException

一般咱們只會用到driver和timeout

WebDriverWait().unti(self, method, message=’’) or until_not()的方法:
(1)method:在等待期間,每一個一段時間(__init__中的poll_frequency)調用這個傳入的方法,直到返回值不是False

(2)message:若是超時,拋出
TimeoutException,將message傳入異常

(3)until not:是當某個元素小時或什麼條件則繼續執行,參數也相同

五、expected_conditions類

appium直接幫咱們封裝好了類,只須要傳參數便可,好比咱們使用的是click(),只須要判斷這個元素是否可點擊屬性才繼續點擊。

用法:expected_conditions.element_to_be_clickable(locator) ,其中locator就是:(By.ID,
「com.xueqiu.android:id/tv_search」)

經常使用的幾個以下:
expected_conditions.element_to_be_clickable :元素是否可點擊

expected_conditions.presence_of_element_located :元素是否被加到dom樹裏面

expected_conditions.visibility_of_element_located :元素是否可見

六、lambda獲取元素

#能夠獲取到元素
element = WebDriverWait(self.driver, 10).until(lambda x: x.find_element(By.XPATH,'//*
[@text="個人"]'))
#這裏找到元素後,不用等待,實測證實過了
element.click()

 

顯式等待

使webdriver等待某個條件成立時繼續執行,不然在最大時長時拋出超時溢出。

from selenium.webdriver.support.wait import WebDriverWait
from selenium.webdriver.support import expected_conditions as EC
def find_element(self,*loc):
'''尋找元素'''
try:
WebDriverWait(self.driver,10).until(EC.visibility_of_element_located(loc)) #顯示
等待
return self.driver.find_element(*loc)
except:
print('%s頁面未找到元素'% loc)

 

until:

'''隱式等待和顯示等待都存在時,超時時間取兩者中較大的'''
locator = (By.ID,'kw')
driver.get(base_url)

WebDriverWait(driver,10).until(EC.title_is(u"百度一下,你就知道"))
'''判斷title,返回布爾值'''

WebDriverWait(driver,10).until(EC.title_contains(u"百度一下"))
'''判斷title,返回布爾值'''

WebDriverWait(driver,10).until(EC.presence_of_element_located((By.ID,'kw')))
'''判斷某個元素是否被加到了dom樹裏,並不表明該元素必定可見,若是定位到就返回WebElement'''

WebDriverWait(driver,10).until(EC.visibility_of_element_located((By.ID,'su')))
'''判斷某個元素是否被添加到了dom裏而且可見,可見表明元素可顯示且寬和高都大於0'''

WebDriverWait(driver,10).until(EC.visibility_of(driver.find_element(by=By.ID,value='kw'))
)
'''判斷元素是否可見,若是可見就返回這個元素'''

WebDriverWait(driver,10).until(EC.presence_of_all_elements_located((By.CSS_SELECTOR,'.mna
v')))
'''判斷是否至少有1個元素存在於dom樹中,若是定位到就返回列表'''

WebDriverWait(driver,10).until(EC.visibility_of_any_elements_located((By.CSS_SELECTOR,'.m
nav')))
'''判斷是否至少有一個元素在頁面中可見,若是定位到就返回列表'''

WebDriverWait(driver,10).until(EC.text_to_be_present_in_element((By.XPATH,"//*
[@id='u1']/a[8]"),u'設置'))
'''判斷指定的元素中是否包含了預期的字符串,返回布爾值'''

WebDriverWait(driver,10).until(EC.text_to_be_present_in_element_value((By.CSS_SELECTOR,'#
su'),u'百度一下'))
'''判斷指定元素的屬性值中是否包含了預期的字符串,返回布爾值'''

#WebDriverWait(driver,10).until(EC.frame_to_be_available_and_switch_to_it(locator))
'''判斷該frame是否能夠switch進去,若是能夠的話,返回True而且switch進去,不然返回False'''
#注意這裏並無一個frame能夠切換進去

WebDriverWait(driver,10).until(EC.invisibility_of_element_located((By.CSS_SELECTOR,'#swfE
veryCookieWrap')))
'''判斷某個元素在是否存在於dom或不可見,若是可見返回False,不可見返回這個元素'''
#注意#swfEveryCookieWrap在此頁面中是一個隱藏的元素

WebDriverWait(driver,10).until(EC.element_to_be_clickable((By.XPATH,"//*
[@id='u1']/a[8]"))).click()
'''判斷某個元素中是否可見而且是enable的,表明可點擊'''

driver.find_element_by_xpath("//*[@id='wrapper']/div[6]/a[1]").click()
#WebDriverWait(driver,10).until(EC.element_to_be_clickable((By.XPATH,"//*
[@id='wrapper']/div[6]/a[1]"))).click()

#WebDriverWait(driver,10).until(EC.staleness_of(driver.find_element(By.ID,'su')))
'''等待某個元素從dom樹中移除'''
#這裏沒有找到合適的例子

WebDriverWait(driver,10).until(EC.element_to_be_selected(driver.find_element(By.XPATH,"//
*[@id='nr']/option[1]")))
'''判斷某個元素是否被選中了,通常用在下拉列表'''

WebDriverWait(driver,10).until(EC.element_selection_state_to_be(driver.find_element(By.XP
ATH,"//*[@id='nr']/option[1]"),True))
'''判斷某個元素的選中狀態是否符合預期'''

WebDriverWait(driver,10).until(EC.element_located_selection_state_to_be((By.XPATH,"//*
[@id='nr']/option[1]"),True))
'''判斷某個元素的選中狀態是否符合預期'''
driver.find_element_by_xpath(".//*[@id='gxszButton']/a[1]").click()

instance = WebDriverWait(driver,10).until(EC.alert_is_present())
'''判斷頁面上是否存在alert,若是有就切換到alert並返回alert的內容'''
print instance.text
instance.accept()

driver.close()

 

5、最後

對軟件測試、接口測試、自動化測試、軟件測試零基礎入門、性能測試、LR腳本開發、python自動化全棧、面試經驗感興趣能夠175317069,羣內會有不按期的發放免費的資料連接。若是你有好的學習也資料能夠私聊發我,我會註明出處以後分享給你們。

相關文章
相關標籤/搜索