自动化测试在软件项目团队中的作用举足轻重,众所周知合理地展开自动化测试,可以有效降低错误修复成本,并对软件质量保证(QA)过程起到全面推进的作用。
以web自动化为例,在Selenium框架的辅助下,自动化测试工程师们编写web自动化测试脚本似乎是一项较简单的任务,但在项目进展过程中,尤其是迭代频繁的敏捷项目研发模式下,测试人员不经意而实现的那些低质量自动化测试脚本往往会引发后期高昂的代码维护成本,久而久之所谓的自动化测试在你的团队中就形同虚设了。
回想那些年被UI自动化坑过的桥段历历在目,当遇上敏捷项目中“短频快”迭代交付时,你的自动化测试脚本很可能成为团队成本开销最高昂的任务之一。
试想更改50个测试脚本中所依赖的某web页面元素(也许就1个元素)将涉及到至少50+个自动化测试脚本的更新,更新脚本的同时不可避免会出现一些其他连锁问题(不知道用蝴蝶效应来比喻这类糟糕的情况是否合适)。这项工程不仅耗时长,而且对于早期自动化测试在团队中的推广与实践也是一个严重的阻碍因素。
都说良好的开端是成功的一半,自动化测试的落地亦是如此,在脚本实现之前,我们需要有个相对精良的设计,面对避无可避的UI元素变更,除了将那些变更频度不高的回归测试进行自动化,还有什么方式能够降低我们日后对于脚本开销带来的高昂成本呢何避免一个元素定位变更导致“牵一发而动全身”呢们是否能对变更进行限制,只动一个地方,并且让每个与之相关的测试脚本都能使用它答是肯定的,相信大家不难得出PO模式可以帮我们落实。
下面我们就来聊一聊Selenium中如何使用页面对象模型(PO —— Page Object)来实现可维护和可重用的自动化测试脚本,让你秒懂PO在UI自动化中的价值。
1 Selenium模拟Github自动化登录流程
这里我们先以Github (http://6tt.co/rV8V) 为例,结合selenium自动化实现模拟登录:
完整登录流程代码如下:
2 Selenium+unittest实现Github自动化登录测试脚本
还是以上脚本和登录场景,既然是自动化测试,我们就结合python自带的unittest框架,进行自动化测试用例脚本编写,完整代码如下:
从脚本中可见,我们通过unittest把登录业务单独封装成了一个test_login()方法,即单独的测试用例,通过assertEqual进行断言判断登录后是否出现预期的信息:
PO的实现
页面对象模型(PO)的基本结构:将单个页面上所有Web元素和在这些Web元素上操作的方法都放在一个Page类文件中,而用于验证的测试用例需要单独作为测试方法的一部分。
我们还是以github登录流程为例,结合页面对象模型(PO)实现自动化测试,首先我们需要将登录页面作为一个类将其封装,并单独提炼出该页面中需要用到的元素(类的成员属性),把对所需元素的操作封装成独立的方法(类的成员方法):
该类需要一个初始化方法,其他操作有:打开页面,用户名输入,密码输入,登录按钮点击,登录后“Start a project”按钮文字提取,所以Login Page类的成员方法有:
针对每一个功能业务流测试,单独进行测试脚本的编写:
由此可见,无论login页面元素发生任何变化,我们需要修改的仅仅只是Login Page类,除此之外其余脚本均不受影响,页面对象模型大大降低了自动化脚本的维护成本及因脚本更新引发的出错概率。
4 框架的优化
很简单,只需要把这些定位作为数据单独存放在配置文件中(配置文件的类型可以是csv, excel,txt),通常csv文件较为常见。
下面我们把Login Page中需要定位的元素单独放到如下csv文件中,login_page.csv文件的第一行是标题,用来对每个字段做描述,以下每一行代表一组数据,不同字段数据间隔用逗 区分(当然用空格也行,只不过csv文件默认逗 间隔):
更改后完整版的login_page.py源码如下:
笔者跟大家分享一个福利!扫码回复【csdn码哥群】入软件测试自学交流群,可免费听技术讲座+领学习资料+视频课免费看
文章知识点与官方知识档案匹配,可进一步学习相关知识Python入门技能树首页概览210978 人正在系统学习中
声明:本站部分文章及图片源自用户投稿,如本站任何资料有侵权请您尽早请联系jinwei@zod.com.cn进行处理,非常感谢!