Selenium概述
1.selenium是测试工具
2.开源的
3.selenium1.0=IDE+Grid+RC
4.IDE:Selenium IDE是嵌入到Firefox浏览器中的一个插件,实现简单的浏览器操作的录制不回
放功能。
5.Grid:是一种自劢化的测试辅助工具,利用Grid可以很方便地实现在多台机器上和异构环境中
运行测试用例。
6.RC:Selenium RC分为Client Libraries和Selenium Server。Client Libraries库主要用于编写测试
脚本,用来控制Selenium Server的库。Selenium Server负责控制浏览器行为。
7.1.0的工作原理:python脚本->Selenium Server->浏览器
8.Selenium 2.0 = Selenium 1.0 + WebDriver
9.WebDriver是通过原生浏览器支持或者浏览器扩展来直接控制浏览器
10.Selenium 3.0 = Selenium 2.0 - Selenium RC
11.Selenium3.0中的Firefox浏览器驱劢独立了,现在也要下载浏览器驱动
11.Selenium3.0=IDE+Grid+WebDriver
Selenium IDE简述
1.Selenium IDE是嵌入到Firefox浏览器中的一个插件,实现简单的浏览器操作的录制与回放功能。
2.是Selenium 三大组件之一
3.这里说的Selenium是一个大的概念
页面元素定位介绍
selenium可以识别的元素,要求属性必须唯一
1)id
2)xpath
3)css selector
4)link text
5)patial link text
6)name
7)class name
8)tag name
一次识别一个元素的api
• find_element_by_id()
• find_element_by_name()
• find_element_by_link_text()
• find_element_by_partial_link_text()
• find_element_by_tag_name()
• find_element_by_class_name()
• find_element_by_xpath()
• find_element_by_css_selector()
• Selenium一次识别多个元素的API
• find_elements_by_id()
• find_elements_by_name()
• find_elements_by_link_text()
• find_elements_by_partial_link_text()
• find_elements_by_tag_name()
• find_elements_by_class_name()
• find_elements_by_xpath()
• find_elements_by_css_selector()
find_element_by_id()函数
1.在id定位里,会返回第一个id属性匹配的元素,如果没有元素匹配,会抛出NoSuchElementException异常。
2.函数说明:
find_element_by_id("元素的id值")
返回的是元素
3.获取远程页面的元素
dr = webdriver.Firefox()
dr.get("完整域名")
4.获取本地html页面的元素
dr = webdriver.Firefox()
dr.get("file:///'+文件的绝对路径)
5.通过元素获取元素其他属性值
n=e.get_attribute('name')
find_element_by_name()函数
1.在name定位里,会返回第一个name属性匹配的元素,如果没有元素匹配,会抛出NoSuchElementException异常。
2.函数说明:
find_element_by_name("元素的name值")
返回元素
find_element_by_link_text()函数
链接文本定位,<a></a>标签
1.在超链接定位里,会返回第一个文本属性匹配的元素,如果没有元素匹配,会抛出NoSuchElementException异常。
2.函数说明:
find_element_by_link_text("链接文字")
返回元素
find_element_by_partial_link_text()函数
链接文本定位,不只<a></a>标签
1.在超链接定位里,输入字符串的子串也会返回第一个文本属性匹配的元素,如果没有元素匹配,会抛出NoSuchElementException异常。
2.函数说明:
find_element_by_partial_link_text("链接文字")
返回元素
find_element_by_tag_name()函数
1.元素标签名定位,如果没有元素匹配,会抛出NoSuchElementException异常
2.函数说明:
find_element_by_tag_name("标签名")
返回元素
find_element_by_class_name()函数
1.知道class就使用这个定位,只返回匹配的第一个,无元素匹配,会抛出NoSuchElementException异常。
2.函数说明:
find_element_by_class_name("class属性值")
返回元素
find_element_by_xpath()函数
1.XPath是用来定位XML文档节点的语言。不过HTML可以看成是XML(XHTML)的一种实现,你想定位的元素没有合适的id或者name属性的时候,你可以用XPath来对元素进行绝对定位(不推荐)或者把这个元素和另外一个有确定id或者name的元素关联起来(即相对定位)。XPath定位器也可以用来找出那些具有id,name以外属性的元素
绝对的XPath定位包含了从HTML根节点起的所有元素,并且一些轻微的改变就会失效。而用id或者name属性来找到一个靠近的元素(比较理想的是父元素),这样你就可以依靠他们的相对关系来确定目标元素的位置。这种情况改变的可能就小了很多了,我们写的测试程序也会更可靠。
2.函数说明:
find_element_by_xpath()
返回元素
查找方式:
1./html/body/form[1] --该路径下第一个form
2.//form[1] --html下第一个form
3.//form[@id='loginForm'] --id属性为loginForm的form
4.//form[input/@name='username'] --form里有input,input里的属性name是叫username的,第一个form,找的是form
5.//form[@id='loginForm']/input[1] --id属性为'loginForm'的form元素的第一个input子元素,[]里的数据可以改变,变为2就表示是第二个子元素
6.//input[@name='username'] --name属性为'username'的第一个input元素
7.//input[@name='continue'][@type='submit'] --type属性为'submit',name属性为'continue'的第一个input元素
8.//*[@name='cin'][@type='submit']--#找的是input
总结:
1.绝对路径
2.标签加标签的属性及属性值方式,可以多个属性及属性作为条件
3.标签中的子标签也可以使用第2个方式
4.可以通过子标签的属性和属性值作为条件,查找父标签元素
5.可以通过父标签的属性和属性值作为条件,查找子标签元素
6.可以就通过属性和属性值作为条件来查找元素
7.可以通过标签的顺号来找元素
find_element_by_css_selector()函数
1.css选择器定位,只返回匹配的第一个,无元素匹配,会抛出NoSuchElementException异常。
2.函数说明:
find_element_by_css_selector(选择器.类样式值)
注意:#class=btn-search tb-bg 表示class的值有两个btn-search和tb-bg,使用时只能使用一个
也就是说要么button.btn-search或button.tb-bg