软件测试自动化测试工具

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()函数

链接文本定位,标签

1.在超链接定位里,会返回第一个文本属性匹配的元素,如果没有元素匹配,会抛出NoSuchElementException异常。

2.函数说明:

find_element_by_link_text("链接文字")

返回元素

find_element_by_partial_link_text()函数

链接文本定位,不只标签

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

你可能感兴趣的:(软件测试自动化测试工具)