博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
python selenium expected_conditions使用实例
阅读量:6243 次
发布时间:2019-06-22

本文共 3628 字,大约阅读时间需要 12 分钟。

今天正好问到selenium python binding中的用法,顺手总结了一下,希望对大家有所帮助。

场景

Expected Conditions的使用场景有2种

  • 直接在断言中使用
  • 与WebDriverWait配合使用,动态等待页面上元素出现或者消失

方法注释

先翻译一下这些方法的用法

  • title_is: 判断当前页面的title是否精确等于预期

  • title_contains: 判断当前页面的title是否包含预期字符串

  • presence_of_element_located: 判断某个元素是否被加到了dom树里,并不代表该元素一定可见

  • visibility_of_element_located: 判断某个元素是否可见.可见代表元素非隐藏,并且元素的宽和高都不等于0

  • visibility_of: 跟上面的方法做一样的事情,只是上面的方法要传入locator,这个方法直接传定位到的element就好了

  • presence_of_all_elements_located: 判断是否至少有1个元素存在于dom树中。举个例子,如果页面上有n个元素的class都是'column-md-3',那么只要有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: 判断某个元素中是否可见并且是enable的,这样的话才叫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,这是个老问题,很多同学会问到

具体的例子

例子的代码在,并且是可以运行通过的。

下面的代码演示了一些常见疑问

  • 如何等待页面上的某个元素出现,然后再对这个元素进行操作
  • 如何在unittest框架中所有的用例都共用1个浏览器实例,然后在全部用例结束后关闭浏览器

expected_conditions.py

#encoding:utf-8# example of how to use https://github.com/SeleniumHQ/selenium/blob/master/py/selenium/webdriver/support/expected_conditions.pyfrom selenium import webdriverfrom selenium.webdriver.support import expected_conditions as ECfrom selenium.webdriver.support.wait import WebDriverWaitfrom selenium.webdriver.common.by import Byimport unittest# dr = webdriver.PhantomJS('phantomjs')dr = webdriver.Firefox()# dr = webdriver.Chrome()url = 'http://www.baidu.com'search_text_field_id = 'kw'dr.get(url)class ECExample(unittest.TestCase):  def test_title_is(self):    ''' 判断title是否符合预期 '''    title_is_baidu = EC.title_is(u'百度一下,你就知道')    self.assertTrue(title_is_baidu(dr))  def test_titile_contains(self):    ''' 判断title是否包含预期字符 '''    title_should_contains_baidu = EC.title_contains(u'百度')    self.assertTrue(title_should_contains_baidu(dr))  def test_presence_of_element_located(self):    ''' 判断element是否出现在dom树 '''    locator = (By.ID, search_text_field_id)    search_text_field_should_present = EC.visibility_of_element_located(locator)    ''' 动态等待10s,如果10s内element加载完成则继续执行下面的代码,否则抛出异常 '''    WebDriverWait(dr, 10).until(EC.presence_of_element_located(locator))    WebDriverWait(dr, 10).until(EC.visibility_of_element_located(locator))    self.assertTrue(search_text_field_should_present(dr))  def test_visibility_of(self):    search_text_field = dr.find_element_by_id(search_text_field_id)    search_text_field_should_visible = EC.visibility_of(search_text_field)    self.assertTrue(search_text_field_should_visible('yes'))  def test_text_to_be_present_in_element(self):    text_should_present = EC.text_to_be_present_in_element((By.NAME, 'tj_trhao123'), 'hao123')    self.assertTrue(text_should_present(dr))  @classmethod  def tearDownClass(kls):    print 'after all test'    dr.quit()    print 'quit dr'if __name__ == '__main__':  unittest.main()

分析

以title_is为例

class title_is(object):    """An expectation for checking the title of a page.    title is the expected title, which must be an exact match    returns True if the title matches, false otherwise."""    def __init__(self, title):        self.title = title    def __call__(self, driver):        return self.title == driver.title

可以看到title_is实际上是1个class,其__call__方法被定义成是返回1个bool值。因此,一般的用法就是

# 实例化the_instance = title_is('expected')# 直接在实例上调用__call__the_instance(dr) #return True or False

转载地址:http://yosia.baihongyu.com/

你可能感兴趣的文章
【跃迁之路】【657天】程序员高效学习方法论探索系列(实验阶段414-2018.12.01)...
查看>>
Testng(二):监听
查看>>
重构改善既有的代码设计(代码的坏味道)
查看>>
入门量子计算
查看>>
为什么全栈JavaScript经常被黑,而Java却不会被黑?
查看>>
Java设计模式的6大原则
查看>>
在2018年如何优雅的开发一个typescript语言的npm包?
查看>>
一些小小的总结
查看>>
Homestead 环境搭建
查看>>
Retrofit源码分析
查看>>
零基础兴趣或者转行学习Python,我们应该如何入门呢?
查看>>
electron 仿制QQ登录界面
查看>>
基于Spring Boot实现图片上传/加水印一把梭操作
查看>>
聊聊storm的LoggingClusterMetricsConsumer
查看>>
vue-waterfall2 基于Vue.js 瀑布流组件
查看>>
Vue一个案例引发的递归组件的使用
查看>>
Canvas 实现一个简单的贪吃蛇
查看>>
前后端导出/下载excel方法
查看>>
JVM之垃圾回收与内存动态分配
查看>>
Numpy中的广播原则/机制
查看>>