2022-01-04 Selenium的基本用法以及操作

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异常。

缺点:使用相对比较复杂

优点:等待判断准确,不会浪费多余的等待时间,在用例中使用,可以提高执行效率

你可能感兴趣的:(2022-01-04 Selenium的基本用法以及操作)