Web UI 自动化测试之元素定位
本文首发于:行者AI
目前,在自动化测试的实际应用中,接口自动化测试被广泛使用,但 UI 自动化测试也并不会被替代。让我们看看二者的对比:
接口自动化测试是跳过前端界面直接对服务端的测试,执行效率和覆盖率更高,维护成本更低,整体而言投出产出比更高,因此在项目上的使用更广泛。
而 UI 自动化测试则是模拟用户在前端页面中的操作行为进行测试,虽然在执行过程中易收到其他因素的影响(如电脑卡顿,浏览器卡顿,网速等)而导致用例执行失败,且后期维护成本较高,但是 UI 自动化测试更贴近用户使用时的真实情况,也能够发现一些接口自动化无法发现的 bug。
因此,在实际项目的自动化测试中,通常采用以接口自动化为主、系统稳定后通过 UI 自动化对重点业务流程进行覆盖的方案。而 UI 自动化的基础,就是元素定位。只有完成了元素定位,才可以操作定位到的元素,模拟手工测试进行一系列的页面交互,比如点击、输入等。
1. 常用的元素定位方式
对于 web 端的 UI 自动化测试,元素定位通常使用 selenium 提供的以下 8 种定位方式:
id:根据 id 定位,是最常用的定位方式,因为 id 具有唯一性,定位准确快捷。
name:通过元素的【name】属性定位,会存在不唯一的情况。
class_name:通过 class 属性名称进行定位。
tag_name:通过标签名定位,一般不建议使用。
link_text:专用于定位超链接元素(即 a 标签),需要完全匹配超链接的内容。
partiallinktext:同样用于定位超链接元素,但可以模糊匹配超链接的内容。
xpath:根据元素路径进行定位,分为绝对路径和相对路径,可以定位到所有目标元素。
css_selector:selenium 官方推荐的元素定位方式,比 xpath 效率更高,但需要掌握一些 css 基础。
在实际的项目中,更推荐使用 xpath 和 css 定位方式,这两种可以定位到页面中的所有元素,使用限制较小。如果对 css 没有了解的话,推荐使用 xpath 的方式,上手更快;如果对 css 有一定基础的朋友,更推荐使用 css 进行元素定位。
接下来,以百度首页为例,在实际使用中对各种定位方式进行详细介绍。
2. 元素定位的实际应用
以百度首页的搜索框为例,介绍 id、name、class、tag_name 四种元素定位方式。
2.1 id 定位
通过 id 属性对百度首页的的输入框进行定位。
2.2 name 定位
通过 name 属性对百度首页的输入框进行定位。
2.3 class_name 定位
通过 class 属性对百度首页的输入框进行定位。
2.4 tag_name 定位
通过标签名称来定位,这种方式很少会使用,因为页面中的同一个标签通常都会重复。
接下来,以页面底部的“意见反馈”为例,介绍 linkText 和 partialLinkText 两种定位方式。
2.5 linkText 定位
通过 a 标签的文本信息进行定位,仅用于定位超链接 a 标签。
2.6 partialLinkText 定位
通过对 a 标签的部分文本信息模糊匹配进行定位。
2.7 xpath 定位
xpath 定位方式是通过页面元素的属性和路径进行元素定位,理论上可以对页面中所有的元素精选定位。下面介绍 xpath 的几种定位方式。
首先,介绍一下 xpath 的路径节点表达式,如图:
(1) xpath 绝对路径定位
仍已百度首页的搜索框为例进行介绍。
通常情况下,不会选择使用 xpath 绝对路径进行元素定位,原因有二:一是绝对路径繁琐冗长,影响运行速度;二是涉及的层级较多,任何一个层级发生变化都会导致定位失败,需要重新进行修改,不利于后期维护。
(2) xpath 相对路径和元素属性结合定位
若目标元素的某个属性具有唯一性,则可直接对目标元素进行定位;否则,需要在目标元素附近寻找一个具有唯一性的元素,然后通过二者的层级关系进行定位。
接下来,依然以百度首页的页面元素为例,对 xpath 定位的方式举例说明。
(3) 浏览器复制 xpath
除了上述两个方法之外,还有一个简单的方法,就是在浏览器的 F12 开发者工具中找到目标元素,鼠标右键进行复制即可,如下图。
但复制的 xpath 路径可能会很冗长,还是推荐大家根据需求自己写目标元素的 xpath 路径。
2.8 css_selector 定位
(1) css 定位简介
css_selector 定位(下文简称 css 定位),它的定位方式,利用选择器进行的。在 CSS 中,选择器是一种模式,用于选择需要添加样式的对象。通过 css 进行元素定位,理论上也是可以定位到页面中的所有元素的。
和 xpath 相比,css 的语法更简洁、定位速度更快,但是 css 的语法比 xpath 较为复杂一些,相对难记。
(2) css 定位实例
下面,仍以百度首页搜索框为例,对 css 定位方式举例说明。
3. 小结
以上,就是 selenium 的各种元素定位方法的简单介绍。项目的实际使用中,在定位方法的选择上,比较推荐大家采用“id > name > xpath/css > 其它”的顺序进行选择。
虽然 UI 自动化测试没有接口自动化测试使用广泛,但也是自动化测试中不可获取的一部分,希望本文能对学习 UI 自动化的小伙伴产生一定的帮助。
PS:更多技术干货,快关注【公众号 | xingzhe_ai】,与行者一起讨论吧!
版权声明: 本文为 InfoQ 作者【行者AI】的原创文章。
原文链接:【http://xie.infoq.cn/article/f3a384186d929d290c51cf4d0】。
本文遵守【CC BY-NC】协议,转载请保留原文出处及本版权声明。
评论 (1 条评论)