博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
UI自动化测试元素定位思想
阅读量:7119 次
发布时间:2019-06-28

本文共 872 字,大约阅读时间需要 2 分钟。

2014年的最后一天,以一篇短文纪念一下。

 

经常看到有同学说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)到元素,一切方法和手段都是等价的。

 

转载地址:http://asiel.baihongyu.com/

你可能感兴趣的文章
一个维护版本日志整洁的Git提交规范
查看>>
单例模式总结
查看>>
bootstrapSwitch bootstrap 的开关组件扩展
查看>>
冒泡排序
查看>>
阿里云 OSS 如何设置防盗链, 上个月图床流量耗费50G+,请求次数10W+,什么鬼?
查看>>
Node.js折腾记一(改进):文件夹目录树获取
查看>>
【机器学习】深度学习开发环境搭建
查看>>
Spring核心技术原理-(1)-通过Web开发演进过程了解一下为什么要有Spring?
查看>>
聊聊Elasticsearch RestClient的RequestLogger
查看>>
iOS视频采集实战(AVCaptureSession)
查看>>
使用java9的uuid生成方式,让uuid生成速度提升一个档次
查看>>
SpringData JDBC
查看>>
Vue源码阅读一:说说vue.nextTick实现
查看>>
《iOS面试之道》算法基础学习(上)
查看>>
js定义到执行(转)
查看>>
Google陆续收购技能机器人技术公司——智能机器人未来是否会发热?
查看>>
前端埋点方法解析及优缺点分析
查看>>
笔记:Gitlab-CI部署流程
查看>>
面向对象-day02
查看>>
如果要学习web前端,需要学习什么
查看>>