Selenium
自动化入门小白都有遇到过如下情况:运行时报错说找不到元素,但是检查确认了好多遍元素定位没有问题,怎么会找不到呢?
然后一查,哎呦,果然是
selenium
运行机制都没搞清楚。在我们打开一个页面时,页面有一个加载的过程,但是我们在页面没有加载完的时候去查了那个元素,当然查不到,那怎么办呢?那就等一下呗,等页面都加载完了,或者我要找的元素加载出来了,我再去执行下面的操作。
等待也是有很多讲究的,用的好了才能让自动化更有效率,
level
才更高。selenium中支持三种等待方式,各有特点,各有不足,适当运用可以让我们的自动化快的飞起。
一、
强制等待(
sleep
)
强制等待方法即用
time.sleep(n)
,当运行到这里的时候,不管是什么情况下,程序运行到这里都会停下来
n
秒,
n
秒之后再继续执行下面的操作。
这种等待用作调试很有用,有时候也可以在代码里这样用,但是不建议总是这样等待,太死板,严重影响程序执行速度。
二、
隐性等待(
implicitly_wait
)
隐性等待对整个
driver
周期起作用,就是说,selenium中使用的这个浏览器不管打开哪个网站
implicitly_wait
都对它有效。所以它只需要设置一次就行,不要像
sleep
一样走到哪都随手写一个。
那么隐性等待到底是怎么工作的呢?
隐性等待是设置了一个最长等待时间,如果在规定时间内网页加载完成,则执行下一步,否则一直等到时间截止,报超时加载。注意这里有一个弊端,那就是程序会一直等待整个页面加载完成,也就是一般情况下你看到浏览器标签栏那个小圈不再转,才会执行下一步,但有时候页面想要的元素早就加载完成了,但是因为个别
js
之类的东西特别慢,我们仍得等到页面全部完成才能执行下一步,我想等我要的元素出来之后就下一步怎么办?有办法,这就要看
selenium
提供的另一种等待方式——显性等待了,请继续往下看。
三、
显性等待(
WebDriverWait
)
selenium
中的
wait
模块的
WebDriverWait()
方法,配合
until
或者
until_not
方法,再辅助一些判断条件,就可以构成这样一个场景:每经过多少秒就查看一次要查找的元素是否可见,如果可见就停止等待,如果不可见就继续等待直到超过等待规定的时间后,报超时异常;当然也可以判断某元素是否在规定时间内不可见等等的各种场景,需要根据自己实际的场景选择判断条件。由此也可以看出三种等待是可以互相辅助的。
显性等待的使用实例如下:
上例中,我们设置了隐性等待和显性等待,在其他操作中,隐性等待起决定性作用,在
WebDriverWait
中显性等待起主要作用,但要注意的是:
最长的等待时间取决于两者之间的大者,此例中为
3
0
,如果隐性等待时间
>
显性等待时间,则最长等待时间等于隐性等待时间。
显性等待主要用到了
WebDriverWait
类与
expected_conditions
模块。
首先介绍一下
WebDriverWait
类的使用方法:
1
、
until()
until()
方法:直到条件成立返回为真,等待结束。如果超时,抛出
TimeoutException
,将
message
传入异常。
2、
not_until()
until_not()
方法:直到条件不成立返回为真,是当某元素消失或什么条件不成立则继续执行,等待结束。如果超时,抛出
TimeoutException
,将
message
传入异常。
其次介绍
expected_conditions
模块:
1
、以下两个条件验证
title
,验证传入的参数
title
是否等于或包含于
driver.title
。
title_is
title_contains
2
、以下两个条件是验证元素是否出现的,传入的参数都是元组类型的
locator
,如
(By.ID,
‘
kw
’
)
,第一个是只要一个符合条件的元素加载出来就通过;第二个必须所有符合条件的元素都加载出来才行。
presence_of_element_located
presence_of_all_elements_located
3
、
以下三个条件验证元素是否可见
前两个传入参数是元组类型的
locator
,
第三个传入
W
ebElement
,
第一个和第三个实质是一样的
。
visibility_of_element_located
invisibility_of_element_located
visibility_of
4
、以下两个条件判断某段文本是否出现在某元素中。
text_to_be_present_in_element
(判断元素的
text
)
text_to_be_present_in_element_value
(判断元素的
value
)
5
、以下条件判断
frame
是否可切入,可传入
locator
元组或者直接传入定位方式:
id
、
name
、
index
或
WebElement
。
frame_to_be_available_and_switch_to_it
6
、以下条件判断是否有
alert
出现。
alert_is_present
7
、以下条件判断元素是否可点击,传入
locator
。
element_to_be_clickable
8
、以下四个条件判断元素是否被选中。
element_to_be_selected
(条件传入
WebElement
对象)
element_located_to_be_selected
(传入
locator
元组)
element_selection_state_to_be
(传入
WebElement
对象以及状态,相等返回
True
,否则返回
False
)
element_located_selection_state_to_be
(传入
locator
以及状态,相等返回
True
,否则返回
False
)
9
、下面一个条件判断一个元素是否仍在
DOM
中,传入
WebElement
对象,可以判断页面是否刷新。
staleness_of
学习完三种等待方式之后,我们怎么灵活的使用三种等待来最大效果的提高自动化执行效率,相信大家都心里有点数啦,下面我还是再唠叨总结一下吧!
固定等待
sleep
与隐性等待
implicitly_wait
尽量少用,它会对测试用例的执行效率有影响。
显性的等待
WebDriverWait
可以灵活运用,什么时候需要用到呢?
1
、页面加载的时候,确认页面元素是否加载成功可以使用
WebDriverWait
。
2
、页面跳转的时候,等待跳转页面的元素出现,需要选一个在跳转前的页面不存在的元素。
3
、下拉菜单的时候,如百度搜索设置的下拉菜单,需要加上个时间等待元素可点击。
4
、页面刷新的时候。
总之,页面存在改变的时候;页面上本来没的元素,然后再出现的元素就需要用显性等待了。
返回搜狐,查看更多
责任编辑: