Selenium自动化测试-设置元素等待(1),颠覆认知

先自我介绍一下,小编浙江大学毕业,去过华为、字节跳动等大厂,目前阿里P7

深知大多数程序员,想要提升技能,往往是自己摸索成长,但自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年最新软件测试全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友。
img
img
img
img
img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,涵盖了95%以上软件测试知识点,真正体系化!

由于文件比较多,这里只是将部分目录截图出来,全套包含大厂面经、学习笔记、源码讲义、实战项目、大纲路线、讲解视频,并且后续会持续更新

如果你需要这些资料,可以添加V获取:vip1024b (备注软件测试)
img

正文

  • driver: 传入WebDriver实例;
  • timeout:指最大超时时间,默认单位为秒;
  • poll_frequency:调用until或until_not方法,每隔一定时间不断尝试是否能找到页面元素,默认间隔是0.5s,可自行调整间隔时间。
  • ignored_exceptions:超时后的异常信息,默认情况下NoSuchElementException 异常。

使用WebDriverWait,需要先导入WebDriverWait模块。

from selenium.webdriver.support.ui import WebDriverWait

我们使用WebDriverWait方式来定位百度页面的新闻链接,

代码如下:

  1. from selenium import webdriver
  2. from selenium.webdriver.support.ui import WebDriverWait
  3. driver = webdriver.Chrome()
  4. driver.get('https://www.baidu.com/')
  5. # 设置显式等待,超时时长最大为 5s,每隔0.5s查找元素一次
  6. element = WebDriverWait(driver,5).until(
  7. lambda x: x.find_element_by_link_text('新闻'))
  8. element.click()

注意:until或until_not中的method参数一定要是可以调用的对象,即这个对象一定有 __call__方法,否则会抛出异常。

例如:

  1. from selenium import webdriver
  2. from selenium.webdriver.support.ui import WebDriverWait
  3. driver = webdriver.Chrome()
  4. driver.get('https://www.baidu.com/')
  5. # 设置显式超时时长最大为5s,每隔0.5s查到元素一次
  6. element = WebDriverWait(driver,5).until(
  7. driver.find_element_by_link_text('新闻'))
  8. element.click()

运行的结果是报错的:

  1. Traceback (most recent call last):
  2. File "C:/Users/96984/PycharmProjects/vivi_python/selenium_vivi/radio.py", line 7, in <module>
  3. element = WebDriverWait(driver,5).until(driver.find_element_by_link_text('新闻'))
  4. File "C:\Users\96984\AppData\Local\Programs\Python\Python37-32\lib\site-packages\selenium\webdriver\support\wait.py", line 71, in until
  5. value = method(self._driver)
  6. TypeError: 'WebElement' object is not callable

所以我们可以用selenium提供的expected_conditions,提供一些场景的判断,或者用自己封装的方法都可以。

使用expected_conditions,需先导入。

from selenium.webdriver.support import expected_conditions as EC

以下是常用的expected_conditions方法:

方法说明
title_is判断当前页面的 title 是否完全等于(==) 预期字符串,返回布尔值
title_contains判断当前页面的 title 是否包含预期字符串,返回布尔值
presence_of_element_located判断某个元素是否被加到了 dom 树里,并不代表该元素一定可见
visibility_of_element_located判断元素是否可见(可见代表元素非隐藏,并且元素宽和高都不等于 0)
visibility_of同上一方法,只是上一方法参数为locator,这个方法参数是 定位后的元素
presence_of_all_elements_located判断是否至少有 1 个元素存在于 dom 树中。举例:如果页面上有 n 个元素的 class 都是’qw’,那么只要有 1 个元素存在,这个方法就返回 True
text_to_be_present_in_element判断某个元素中的 text 是否包含了预期的字符串
text_to_be_present_in_element_value判断某个元素中的 value 属性是否包含了预期的字符串
frame_to_be_available_and_switch_to_it判断该 frame 是否可以 switch进去,如果可以的话,返回 True 并且 switch 进去,否则返回 False
invisibility_of_element_located判断某个元素中是否不存在于dom树或不可见
element_to_be_clickable判断某个元素中是否可见并且可点击
staleness_of等某个元素从 dom 树中移除,注意,这个方法也是返回 True或 False
element_to_be_selected判断某个元素是否被选中了,一般用在下拉列表
element_selection_state_to_be判断某个元素的选中状态是否符合预期
element_located_selection_state_to_be跟上面的方法作用一样,只是上面的方法传入定位到的 element,而这个方法传入 locator
alert_is_present判断页面上是否存在 alert

我们以presence_of_element_located这个方法为例,看下WebDriverWait怎么和expected_conditions配合使用。

  1. from selenium import webdriver
  2. from selenium.webdriver.support.ui import WebDriverWait
  3. from selenium.webdriver.support import expected_conditions as EC
  4. driver = webdriver.Chrome()
  5. driver.get('https://www.baidu.com/')
  6. # 设置显式等待,超时时长最大为5s,每隔0.5s查找元素一次
  7. element = WebDriverWait(driver,5).until(
  8. EC.presence_of_element_located(('id','kw')))
  9. element.send_keys('vivi')

最后总结下三种元素等待的优缺点:

元素等待方式优点缺点
ime使用简单,在程序调试时使用浪费不必要的等待时间,影响用例执行效率
implicitly_wait一旦设置,这个隐式等待会在WebDriver对象实例的整个生命周期起作用程序等待整个页面加载完成,才会下一步操作,不够灵活
WebDriverWait条件成立,就会下一步操作,节省等待时间,提高用例执行效率使用相对复杂,学习成本相对较大

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化的资料的朋友,可以添加V获取:vip1024b (备注软件测试)
img

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!
024b (备注软件测试)**
[外链图片转存中…(img-IHvVKx06-1713413314554)]

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

  • 4
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值