美文网首页
web自动化测试——xpath常用案例

web自动化测试——xpath常用案例

作者: 辣椒爸 | 来源:发表于2021-03-21 12:48 被阅读0次

XPath基本概念

XPath 是一门在 XML 文档中查找信息的语言。XPath 用于在 XML 文档中通过元素和属性进行导航。HTML也属于XML文档,在web自动化测试中常使用xpath进行页面元素的定位,要学好XPath需要先理解XPath节点和轴。

XPath节点

在 XPath 中,有七种类型的节点:元素、属性、文本、命名空间、处理指令、注释以及文档节点(或称为根节点),下图中未标识出命名空间、处理指令节点

web自动化测试——xpath常用案例

XPath轴

XPath 使用路径表达式在 XML 文档中进行导航,html文档会被解析为一颗树。

下图中self表示为参照节点,parent表示为self的父节点,following-sibling表示为self之后的兄弟节点,同理其他的都是以self为参照来表示的。

web自动化测试——xpath常用案例

XPath编写原则

在自动化测试中,web页面自动化的稳定性一直被人诟病,我认为除了功能需求的频繁变更之外,很大一部分原因是页面元素的XPath定位写得不够好导致页面元素有一点点变更就无法定位,从而导致用例失败,我接触到的自动化测试人员中很少遇到对XPath非常熟悉的。XPath编写重要原则就是要通过尽量不变化或少变化的元素去定位,使写出的XPath能够在页面需求变动较小的情况下也能顺利定位,达到这样的要求不仅需要对XPath足够熟悉而且还要结合项目的实际情况灵活处理。

接下来,我针对XPath常用的一些情景进行讲解,以定位
https://www.w3school.com.cn/xpath/index.asp该网站的页面元素为例进行介绍。

相对路径、绝对路径

绝对路径:/html/body//h1

--- 从html根节点开始查找,最终定位到所需的h1元素

image.png

相对路径://h1

web自动化测试——xpath常用案例

使用属性定位

//ul/li/a[@title="XPath 教程"]

-- @title=表示定位title等于匹配值的元素,注意这里共匹配到了3个元素,后面会讲到如何处理这种情况

web自动化测试——xpath常用案例

定位兄弟节点

//ul/li/a[text()="XPath 语法"]/../following-sibling::li[2]

-- 通过导航菜单"XPath 语法"找到其下面的兄弟元素的第二个节点,即"XPath 运算符",使用following-sibling,如何找之前的兄弟元素则使用preceding-sibling,其他的轴如祖先节点、子孙节点定位也使用同样的方式

注:其中/..表示返回其父节点,等同于//ul/li/a[text()="XPath 语法"]
/parent::li/following-sibling::li[2]

image.png

使用索引下标定位

//ul[@id="menu"]/li[4]

-- 导航菜单中的li元素为相邻的兄弟元素,通过下标[4]选中第四个元素

web自动化测试——xpath常用案例

还有一种情况,XPath定位到的元素并不是相邻的兄弟元素,此时可以使用(xpath)[index]的方式定位所需的元素

(//ul/li/a[@title="XPath 教程"])[1]

web自动化测试——xpath常用案例

使用函数

XPath定义100多个内建函数,参见链接
https://www.w3school.com.cn/xpath/xpath_functions.asp

contains函数

//strong[contains(text(),"XPath 用于在 XML 文档中通过")]

-- 定位strong元素中的文本内容包含匹配内容的元素,其中text()表示取strong元素文本内容

-- contains函数中的第一个参数不仅可以是text(),也可以是属性,如contains(@name, "匹配值")

web自动化测试——xpath常用案例

//p[contains(.,"XPath 用于在 XML 文档中通过")]

-- 其中contains参数中的.表示p内所有所有元素匹配条件即可

[图片上传失败...(image-c400be-1616302004141)]

starts-with函数

//strong[starts-with(text(),"XPath 是一门在 XML 文档中查找信息的语言")]

-- 匹配strong元素文本内容以匹配内容开始的元素

web自动化测试——xpath常用案例

text函数

//ul/li/a[text()="XPath 简介"]

-- 匹配a元素文本等于匹配内容的元素

web自动化测试——xpath常用案例

and、or、not

复杂的xpath需要使用多个条件进行定位,可以使用and、or进行多条件组合,使用not匹配不满足条件的元素

//table/tbody/tr/td[starts-with(text(),"fn") and not(contains(text(),"error"))]

-- 匹配表格td元素中以"fn"开头但是不包含"error"的td元素

web自动化测试——xpath常用案例

normalize-space函数:首尾去除空格

//ul/li/a[normalize-space(text())="职业规划"]

-- 有些页面元素的文本内容首尾是有空格的,这种情况可以使用normalize-space去除首尾的空格

web自动化测试——xpath常用案例

相关文章

  • web自动化测试——xpath常用案例

    XPath基本概念 XPath 是一门在 XML 文档中查找信息的语言。XPath 用于在 XML 文档中通过元素...

  • 自动化测试——selenium之JS定位及

    在自动化测试中,我们常用的元素定位方式有id,name,class_name,xpath,css_selector...

  • selenium2学习

    自动化介绍:UI自动化测试 Selenium简介:测试web应用程序用户界面(ui)的常用框架pip instal...

  • 2018-04-17 xpath

    xpath教程(非常不错!!) web端功能自动化定位元素 XPath、XQuery 以及 XSLT 函数 Sel...

  • 第十九单元 web端自动化基础篇

    一、认识web自动化测试 什么是自动化测试? 了解为什么要进行自动化测试? 掌握自动化测试的分类? web自动化测...

  • Appium Xpath 选择元素

    大家还记得我们做 web 自动化的时候,最灵活的定位方式就是 css 和 xpath 了。我们也经常用它来选择一些...

  • 安装Appium

    一、web自动化与移动自动化比较 web自动化测试的路线是这样的:编程语言基础--->测试框架--->webdri...

  • 软件自动化测试开发–前言

    1、接口自动化测试 2、App自动化测试 3、Web自动化测试 4、性能自动化测试 使用技术:Appium功能自动...

  • python爬虫之selenium获取网页

    本质: 代码操纵浏览器,自动化访问网页 环境: selenium模块:Web自动化测试工具,应用于Web自动化测试...

  • helium初体验(基于python的自动化测试)

    web自动化测试,大家常用的是selenium(定位,操作,获取数据),看这名字? helium ,很像对不对是...

网友评论

      本文标题:web自动化测试——xpath常用案例

      本文链接:https://www.haomeiwen.com/subject/sqvncltx.html