Web页面UI自动化
大多数公司是使用Selenium的API来做Web的UI自动化的。
从表面来看,很快是有成果的,因为结果非常直观。
再加上selenium可以兼容多种语言,所以在使用范围上也有较大的影响力。通过selenium我们基本上可以模拟到浏览器的全部行为。
之所以没有大范围的推广使用UI自动化技术,其中一个原因是维护成本比较高,我们的UI自动化是基于web的UI界面来实现的,前端的代码不规范,或者使用大量的自定义的控件,或者频繁更换UI界面都会对UI自动化的稳定性有很大的影响,这样会导致要投入很多的资源来维护UI自动化,相对于获得的收益,投入的成本就算比较高的了,性价比比较低,所以很多公司也不愿意投入资源来做UI的自动化,
当然,如果你的产品web页面很稳定了,同时代码也很规范,可以进行重要模块的UI自动化,这样性价比就比较高了。具体的要视情况而定。
Selenium对很多语言都是很兼容的,用纯代码的可以使用Java或者Python,这对代码的要求会高一些,
所以为了照顾整个团队的发展,更多的会选着Robot Framework这样的通用型框架来实现,再选用Selenium2Library这样的第三方库对selenium进行了封装使用。这样可以合理配置人力资源,让懂代码的对关键字进行封装,普通的测试员只需要根据关键字来写case就好了。
UI自动化主要分为三部分
- 定位
- 操作
- 断言
在UI自动化中元素的定位是很关键的,定位不准,也就无法操作页面元素,自动化也是白搭,
1 使用name和id定位
很多关键字默认使用了name和id定位,我们只需要输入id或者name就可以了,例如click element和input text
2 使用xpath定位,不用其他什么方法了,xpath是万能的
使用xpath定位的方式非常多,这里只是列举常用的,几乎可以满足所有情况
当页面元素有id和name属性时,最好尽量用id和name来定位。但由于现实项目代码并不规范,没有这些属性时,就要选择其他方法定位。
元素的操作
打开 open
关闭 close
点击 click
双击 Double
selenium2library期望值关键字
Element Should Be Visible
Element Should Not Be Visible
元素可见和不可见,可用id或者name或者其他来定位
适用于分级分权
Element Text Should Be
Element Should Not Contain
元素包含和不包含
Page should contain
Page should not contain
页面应该包含某文字
参数:文字
Page should contain button
Page should not contain button
页面应该包含某按钮
参数:定位到button的id或者name或者其他
Page should contain checkbox
Page should not contain checkbox
页面应该包含某选项框(单选)
参数:定位到checkbox的id或者name或者其他
Page should contain element
Page should not contain element
页面应该包含某元素
参数:定位到某元素的id或者name或者其他
Page should contain Image
Page should not contain Image
页面应该包含某图片
Page should contain Iink
Page should not contain Iink
页面应该包含链接
Page should contain Iist
Page should not contain Iist
Page should contain radio button
Page should not contain radio button
页面应该包含某选项框(多选)
参数:定位到checkbox的id或者name或者其他
Page should contain textfield
Page should not contain textfield
页面应该包含文本段
总结
Robot Framework是基于Python开发的,同时也支持Python的语法,可以根据自己的需要来定义关键字。
至于项目要不要做UI自动化,需要根据自身项目的特性来决定,而且也需要充分运用分层的思想,把基本控件提前出来。而且只验证页面逻辑,不进行数据验证。对于UI自动化,在移动端的发展比web端好很多。
由于前端代码的不严谨,UI的频繁迭代,UI自动化的投入成本是非常高昂的,就算进行UI自动化,也是选取重点模块进行自动化,这样的case数量就比较少,完全不能发挥出UI自动化的性价比,想进行大规模的自动化,又怕维护成本很高,所以,进入这样两难的境界,导致,UI自动化像鸡肋一样,真正运用的很成功的,在小公司可能很难实现,因为,这需要多方配合,才能使得项目真正的落地。
但是,无论怎么样,我们还是需要去了解一下,web端的UI自动化是怎么样做的,为什么要这样做,这样做能不能提升工作效率,现在很多测试,开口就谈什么自动化,或者就宣传自动化无用论,这样是很low的行为,无论这个技术有没有用,我们都是站在前人的基础上来完成的,就算无用,让你来实现,你可以吗,实现的效果怎么样,而不是去做键盘侠。