软件测试 / 测试开发丨 Web 自动化测试策略
免费领取:测试资料+测试用例+简历模板+测试文档
本文为霍格沃兹测试开发学社学员学习笔记分享
一、元素定位策略
在实际自动化测试过程中常常遇到以下几个问题
不知道该用哪种方式进行元素定位?
元素有时候无法定位如何解决?
1.1、 定位方式
定位方式通用场景通用 Web 定位方式 js 定位(CSS)特殊场景弹框-alert()日期控件文件上传其他场景…
1.2、选择定位器通用原则
与研发约定的属性优先(class 属性: [name='locate'])
身份属性 id,name(web 定位)
复杂场景使用组合定位:
xpath,css
属性动态变化(id,text)
重复元素属性(id,text,class)
父子定位(子定位父)
js 定位
1.3、相关章节
高级定位-xpath
高级定位-css
执行 JavaScript 脚本
面试题-定位不到元素
1.4、特殊场景
(一)Web 弹框定位
场景 web 页面 alert 弹框
解决:web 需要使用 driver.switch_to().alert() 处理
(二)下拉框/日期控件定位
场景:<input>标签组合的下拉框无法定位<input>标签组合的日期控件无法定位
解决:面对这些元素,我们可以引入 JS 注入技术来解决问题。
(三)文件上传定位
场景:input 标签文件上传
解决:input 标签直接使用 send_keys()方法
二、显示等待与隐式等待
为什么要添加等待
避免页面未渲染完成后操作,导致的报错
2.1、强制(直接)等待
解决方案:在报错的元素操作之前添加等待
原理:强制等待,线程休眠一定时间
演练环境:vip.ceshiren.com/
time.sleep(3)
强制等待的缺点
如果设置的等待时间过长,可能会影响用例的执行效率;
如果设置的等待时间过短,页面可能依然加载不全,从而导致定位失败。
强制等待一般只用于代码调试场景
解决方案:针对于寻找元素的这个动作,使用隐式等待添加配置。
2.1、隐式等待
原理:设置一个等待时间,轮询查找(默认 0.5 秒)元素是否出现,如果没出现就抛出异常
特点:隐式等待是全局生效,在其之后的所有的 find_element 动作都会先执行隐式等待。所以在代码一开始的时候就要添加隐式等待配置。
优点:隐式等待可以解决元素查找的问题
缺点:隐式等待不能解决元素交互问题,如点击,输入等。
2.3、显式等待
隐式等待无法解决的问题
元素可以找到,使用点击等操作,出现报错
原因:页面元素加载是异步加载过程,通常 html 会先加载完成,js、css 其后元素存在与否是由 HTML 决定,元素的交互是由 css 或者 js 决定隐式等待只关注元素能不能找到,不关注元素能否点击或者进行其他的交互
解决方案:使用显式等待
WebDriverWait(driver 对象,最长等待时间).until()
2.4、总结
三、自动化实战
3.1、产品分析
产品:测试人论坛
功能:搜索
3.2、测试用例分析
自动化测试也是功能测试的一部分,我们会挑选一些核心的功能来做自动化测试自动化测试无需编写测试用例,直接使用已有的功能测试用例就可以了
3.3、编写脚本
前置:setup 初始化浏览器驱动
后置:teardown 关闭浏览器
版权声明: 本文为 InfoQ 作者【测试人】的原创文章。
原文链接:【http://xie.infoq.cn/article/e43a0e27bf46c0724ad1c43c8】。文章转载请联系作者。
评论