Selenium的基本用法以及操作
1、测试对象:网页 Web自动化即通过代码模拟人工操作的方式来执行测试用例
2、Selenium的介绍、内容以及相关环境的配置
3、常用方法
Webdriver.Chrome(驱动文件路径) 打开浏览器
Driver.get(网址) 打开网址
元素.send_keys(文本) 输入
元素.click() 点击元素
Driver.maximize_window() 浏览器最大化
Driver.quit 关闭浏览器退出测试
4、网页元素
输入框input div
按钮input button sumbit
图片img div
标题title
网页上的任何东西都是可以定位的
5、元素定位
定位元素时可以借助Chrome开发者工具 快捷键ctrl+shif+c
八大定位(运用原则:能用id用id,不能则用xpath,任意元素都可以通过前五种方式定位)
driver.find_element_by_id('kw').send_keys('python自动化') 通过id定位元素
driver.find_element_by_xpath('//*[@id="kw"]').send_keys('python自动化') 通过xpath定位元素
driver.find_element_by_name('wd').send_keys('python自动化') 通过name定位元素
driver.find_element_by_class_name('s_ipt').send_keys('python自动化') 通过class定位元素
driver.find_element_by_css_selector('#kw').send_keys('python自动化') 通过css selector定位元素
driver.find_element_by_link_text('新闻').click() 通过link_text定位元素 超链接独有
driver.find_element_by_partial_link_text('新闻').click() 通过partial_link_text模糊定位元素 超链接独有
driver.find_element_by_tag_name('input').send_keys('python自动化') 通过tag_name标签值定位元素
6、元素定位机制
无法定位元素就抛出异常selenium.common.exceptions.NoSuchElementException
定位到元素就返回元素对象selenium.webdriver.remote.webelement.WebElement
7、查找多个元素
Find_elements_by
找到元素时[元素1,元素2]
没有找到元素时[]
Find_element 和find_elements的区别?
find_element定位的是一个元素webelement
find_elements定位的是一组元素list【webelement1,webelement2.....】,如一个表格的所有内容(以行为单位)
8、断言
通过文本值断言
# 通过价格是否一样来判断
price =
driver.find_element_by_xpath('/html/body/div[4]/div/ul/li/div/p[2]/strong')
assert price.text == "¥168.00"
通过判断元素是否存在断言,缺点是不够准确
# 通过图片是否存在来判断
goods =
driver.find_elements_by_xpath('/html/body/div[4]/div/ul/li/div/a/img')
assert len(goods) != 0
9、等待
原因:因为浏览器加载需要时间而代码不会等你,因此在某些情况下需要加等待
方法:1、固定等待time.sleep(10)
使用方法:sleep(X),等待X秒后,进行下一步操作。
第一种也是使用最简单的一种办法就是强制等待sleep(X),强制让浏览器等待X秒,不管当前操作是否完成,是否可以进行下一步操作,都必须等X秒的时间。
缺点:不能准确把握需要等待的时间(有时操作还未完成,等待就结束了,导致报错;有时操作已经完成了,但等待时间还没有到,浪费时间),如果在用例中大量使用,会浪费不必要的等待时间,影响测试用例的执行效率。
优点:使用简单,可以在调试时使用。
2、隐式等待driver.implicitly_wait(10)
第二种方法是隐形等待,其设置了一个最长等待时间,如果在规定时间内网页加载完成,则执行下一步,否则一直等到时间结束,然后执行下一步操作。
缺点:使用隐式等待,程序会一直等待整个页面加载完成,才会执行下一步操作;
但有时候页面想要的元素早已经加载完成了,但是因为网页上个别元素还没有加载完成,仍要等到页面全部完成才能执行下一步,使用也不是很灵活。
优点:隐性等待对整个driver的周期都起作用,所以只要设置一次即可。
3、显式等待 动态查找元素WebDriverWait方法
第三种办法就是显性等待,WebDriverWait,配合该类的until()和until_not()方法,就能够根据判断条件进行灵活地等待了。它主要的意思就是:程序每隔X秒看一眼,如果条件成立了,则执行下一步,否则继续等待,直到超过设置的最长时间,然后抛出TimeoutException异常。
缺点:使用相对比较复杂
优点:等待判断准确,不会浪费多余的等待时间,在用例中使用,可以提高执行效率