51Testing软件测试论坛

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

QQ登录

只需一步,快速开始

微信登录,快人一步

手机号码,快捷登录

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

UI自动化测试元素定位思想

[复制链接]

该用户从未签到

跳转到指定楼层
1#
发表于 2018-4-13 13:56:42 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
经常看到有同学说UI自动化测试定位难,找不到北。这话是不错的,定位是难,灵活且复杂,需要经验加技术,
但是有写东西是可以提炼出来作为思想去推而广之的。



简单来说,UI元素定位思想应该如下:



大道至简
大道至简指的是有明显特征的元素一定要用明显的特征去定位。比如有id有name的元素,就不要舍近求远,
一定要用最简单的办法去定位。



分而治之
一般来说,良好的html代码页面结构是很清晰的。很多同学在用class定位的时候经常会发现页面上有很多同
名class,很难定位到自己需要的那一个class。这时候需要应用分而治之的思想,也就是分治法。先把页面划
分成几个单独的区域(有点像是html5里的section),这样每个区域的class就是有特征的了,这时候定位就
很容易了。



由大至小
跟上面的思想差不多,先定位大一点的有特征的元素,再去这里面定位具体的细小的元素。这是我一直以来
强调的层级定位



酌情而定
定位最怕在一棵树上吊死。当你一种方式不行的时候就要视情况换一种方式。比如用xpath定位在firefox上是
妥妥的,结果去了ie上就各种碰壁,这是因为低版本的ie xpath支持的不好,所以有些表达式不识别。这时候
你就需要换个方法去做。另外自动生成的xpath是魔鬼,不要把你的灵魂出卖给魔鬼。



动静结合
有些元素是有特殊属性的,但是这些属性是动态变化的。我记得我在wordpress实战里专门讲过这个问题。比
如每一篇新文章的id都是post-(post_id)的形式,这时候我们就要想办法去获得post_id,然后拼接字符串得到
新文章的id,再通过这个id去定位元素。



殊途同归
我记得有些同学用类似于sizzle之类的js框架结合webdriver的js引擎去做元素定位和测试,然后顿时觉得自己逼
格爆表,横行霸盗。其实webdriver现在用的也是sizzle,注入sizzle其实是不需要的。不过殊途同归,只要能够
优雅的定位(不要用机器自动生成的xpath)到元素,一切方法和手段都是等价的。

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

使用道具 举报

本版积分规则

关闭

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

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

GMT+8, 2024-11-17 22:25 , Processed in 0.063433 second(s), 24 queries .

Powered by Discuz! X3.2

© 2001-2024 Comsenz Inc.

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