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 、页面刷新的时候。

总之,页面存在改变的时候;页面上本来没的元素,然后再出现的元素就需要用显性等待了。 返回搜狐,查看更多

责任编辑: