51Testing软件测试论坛

 找回密码
 (注-册)加入51Testing

QQ登录

只需一步,快速开始

微信登录,快人一步

手机号码,快捷登录

查看: 766|回复: 0
打印 上一主题 下一主题

[转贴] 阿里测试师用UI自动化测试实现元素定位

[复制链接]
  • TA的每日心情
    无聊
    前天 09:05
  • 签到天数: 1050 天

    连续签到: 1 天

    [LV.10]测试总司令

    跳转到指定楼层
    1#
    发表于 2022-7-18 14:15:37 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
    随着IT行业的发展,产品愈渐复杂,web端业务及流程更加繁琐,目前UI测试仅是针对单一页面,操作量大。为了满足多页面功能及流程的需求及节省工时,设计了这款UI 自动化测试程序。旨在提供接口,集成到蜗牛自动化测试框架,方便用例的设计。

    目前,在自动化测试的实际应用中,接口自动化测试被广泛使用,但UI自动化测试也并不会被替代。让我们看看二者的对比:
      接口自动化测试是跳过前端界面直接对服务端的测试,执行效率和覆盖率更高,维护成本更低,整体而言投出产出比更高,因此在项目上的使用更广泛。
      而UI自动化测试则是模拟用户在前端页面中的操作行为进行测试,虽然在执行过程中易收到其他因素的影响(如电脑卡顿,[url=]浏览器[/url]卡顿,网速等)而导致用例执行失败,且后期维护成本较高,但是UI自动化测试更贴近用户使用时的真实情况,也能够发现一些接口自动化无法发现的bug。
      因此,在实际项目的自动化测试中,通常采用以接口自动化为主、系统稳定后通过UI自动化对重点业务流程进行覆盖的方案。而UI自动化的基础,就是元素定位。只有完成了元素定位,才可以操作定位到的元素,模拟手工测试进行一系列的页面交互,比如点击、输入等。
      一、常用的元素定位方式
      对于web端的UI自动化测试,元素定位通常使用[url=]selenium[/url]提供的以下8种定位方式:
      id:根据id定位,是最常用的定位方式,因为id具有唯一性,定位准确快捷。
      name:通过元素的【name】属性定位,会存在不唯一的情况。
      class_name:通过class 属性名称进行定位。
      tag_name:通过标签名定位,一般不建议使用。
      link_text:专用于定位超链接元素(即a标签),需要完全匹配超链接的内容。
      partial_link_text:同样用于定位超链接元素,但可以模糊匹配超链接的内容。
      xpath:根据元素路径进行定位,分为绝对路径和相对路径,可以定位到所有目标元素。
      css_selector:selenium官方推荐的元素定位方式,比xpath效率更高,但需要掌握一些css基础。
      在实际的项目中,更推荐使用xpath和css定位方式,这两种可以定位到页面中的所有元素,使用限制较小。如果对css没有了解的话,推荐使用xpath的方式,上手更快;如果对css有一定基础的朋友,更推荐使用css进行元素定位。
      接下来,以百度首页为例,在实际使用中对各种定位方式进行详细介绍。
      二、元素定位的实际应用
      以百度首页的搜索框为例,介绍id、name、class、tag_name四种元素定位方式。

    1.id定位
      通过id属性对百度首页的的输入框进行定位。
    1.    # 通过input标签的id属性进行定位 find_element_by_id('su')
    复制代码
    2.name定位
      通过name属性对百度首页的输入框进行定位。
    1.    # 通过input标签的name属性进行定位 find_element_by_name('wd')
    复制代码
    3.class_name定位
      通过class属性对百度首页的输入框进行定位。
    1.    # 通过input标签的class属性进行定位 ind_element_by_class_name('s_ipt')
    复制代码
    4.tag_name定位
      通过标签名称来定位,这种方式很少会使用,因为页面中的同一个标签通常都会重复。
    1.    # 通过input标签名进行定位 find_element_by_tag_name('input')
    复制代码
    接下来,以页面底部的“意见反馈”为例,介绍linkText和partialLinkText两种定位方式。

    5.linkText定位
      通过a标签的文本信息进行定位,仅用于定位超链接a标签。
    1.    # 通过a标签的文本信息进行定位 find_element_by_link_text('意见反馈')
    复制代码
    6.partialLinkText定位
      通过对a标签的部分文本信息模糊匹配进行定位。
    1.   # 通过对a标签的部分文本信息模糊匹配进行定位 find_element_by_partial_link_text('反馈')
    复制代码
    7.xpath定位
      xpath定位方式是通过页面元素的属性和路径进行元素定位,理论上可以对页面中所有的元素精选定位。下面介绍xpath的几种定位方式。
      首先,介绍一下xpath的路径节点表达式,如图:

    (1) xpath绝对路径定位
      仍已百度首页的搜索框为例进行介绍。
    1.   find_element_by_xpath('/html/body/div[1]/div[1]/div[5]/div/div/form/span[1]/input')
    复制代码
    通常情况下,不会选择使用xpath绝对路径进行元素定位,原因有二:一是绝对路径繁琐冗长,影响运行速度;二是涉及的层级较多,任何一个层级发生变化都会导致定位失败,需要重新进行修改,不利于后期维护。
      (2) xpath相对路径和元素属性结合定位
      若目标元素的某个属性具有唯一性,则可直接对目标元素进行定位;否则,需要在目标元素附近寻找一个具有唯一性的元素,然后通过二者的层级关系进行定位。
      接下来,依然以百度首页的页面元素为例,对xpath定位的方式举例说明。
    1. # 通过元素属性定位百度首页的搜索框
    2.   find_element_by_xpath("//input[@id='su']")
    3.   find_element_by_xpath("//input[@name='wd']")
    4.   find_element_by_xpath("//input[@class='s_ipt']")
    5.   find_element_by_xpath("//input[@autocomplete='off']")
    6.   # 通过文本信息定位(和text_link方法不同,不局限于a标签)
    7.   find_element_by_xpath("//a[text()='意见反馈']")
    8.   find_element_by_xpath("//span[text()='设置']")
    9.   # 通过父级定位子级元素,举例百度首页搜索按钮
    10.   find_element_by_xpath("//span[@class='bg s_btn_wr']/input")
    11.   # 通过子级定位父级元素,举例百度首页百度热榜的换一换
    12.   find_element_by_xpath("//span[text()='换一换']/..")
    13.   # 通过contains方法模糊匹配定位,举例百度首页搜索按钮
    14.   find_element_by_xpath("//input[contains(@class,'s_btn')]")
    15.   find_element_by_xpath("//a[contains(text(),'反馈')]")
    复制代码
    (3) 浏览器复制xpath
      除了上述两个方法之外,还有一个简单的方法,就是在浏览器的F12开发者工具中找到目标元素,鼠标右键进行复制即可,如下图。

    但复制的xpath路径可能会很冗长,还是推荐大家根据需求自己写目标元素的xpath路径。
      8.css_selector定位
      (1) css定位简介
      css_selector定位(下文简称css定位),它的定位方式,利用选择器进行的。在CSS 中,选择器是一种模式,用于选择需要添加样式的对象。通过css进行元素定位,理论上也是可以定位到页面中的所有元素的。
      和xpath相比,css的语法更简洁、定位速度更快,但是css的语法比xpath较为复杂一些,相对难记。
      (2) css定位实例
      下面,仍以百度首页搜索框为例,对css定位方式举例说明。
    1. # 通过id定位,id名前加#
    2.   find_element_by_css_selector("#kw")
    3.   # 通过class定位,class名前加.
    4.   find_element_by_css_selector(".s_ipt")
    5.   # 通过标签定位
    6.   find_element_by_css_selector("input")
    7.   # 通过其它属性定位
    8.   find_element_by_css_selector("[name='wd']")
    9.   # 标签和属性组合定位
    10.   find_element_by_css_selector("input#kw")
    11.   find_element_by_css_selector("input.s_ipt")
    12.   find_element_by_css_selector("input[name='wd']")
    13.   find_element_by_css_selector("[name='wd'][autocomplete='off']")
    14.   # 通过父级定位子级元素
    15.   find_element_by_css_selector("from#form>span[@class='bg s_ipt_wr']>input")
    复制代码
    三、小结
      以上,就是selenium的各种元素定位方法的简单介绍。项目的实际使用中,在定位方法的选择上,比较推荐大家采用“id > name > xpath/css > 其它”的顺序进行选择。
      虽然UI自动化测试没有接口自动化测试使用广泛,但也是自动化测试中不可获取的一部分,希望本文能对学习UI自动化的小伙伴产生一定的帮助。

















    本帖子中包含更多资源

    您需要 登录 才可以下载或查看,没有帐号?(注-册)加入51Testing

    x
    分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
    收藏收藏
    回复

    使用道具 举报

    本版积分规则

    关闭

    站长推荐上一条 /1 下一条

    小黑屋|手机版|Archiver|51Testing软件测试网 ( 沪ICP备05003035号 关于我们

    GMT+8, 2024-11-23 09:38 , Processed in 0.064232 second(s), 24 queries .

    Powered by Discuz! X3.2

    © 2001-2024 Comsenz Inc.

    快速回复 返回顶部 返回列表