四种常用的自动化测试框架
一直想仔细研究框架,写个流水账似的测试程序不难,写个低维护成本的测试框架就很难了,所以研究多种测试框架还是很有必要的,知道孰优孰劣,才能在开始编写框架的时候打好基础,今天读到了KiKi Zhao的翻译文章,觉得很是不错,写了一点学习心得,有不正确之处,请指出。
中文原文地址:http://www.cnblogs.com/nckiki/articles/244202.html
英文原文地址:http://www.ibm.com/developerworks/rational/library/591.html
原文对自动化测试架构做了如下四种分类:
1. 数据驱动测试框架(The Data-Driven Testing Framework)
说明:
仅仅是将测试数据从测试脚本中分离出来,开始了非混沌状态的第一步,这也是所有测试架构中最简单的一种
优点:
至少测试数据可以单独维护了
缺点:
任何被测试程序的变更所导致的工作量是所有架构中最多的,因此维护成本非常高
2. 测试脚本模块化框架(The Test Script Modularity Framework)
说明:
l 箭头方向代表的是被调用和调用关系
l 测试脚本中包含了各功能点中涉及到的控件识别和业务逻辑操作,其中包含了外部测试数据的调用
l 测试脚本的维护由自动化测试开发工程师负责,要求必须懂自动化编程和业务逻辑
l 测试数据的维护由测试工程师负责
优点:
控件和业务逻辑一旦发生变化,要进行修改和维护的是底层的测试脚本(比无任何抽象封装的自动化测试程序稍好一些)
缺点:
l 几乎所有大的变更引起的工作量都由自动化测试开发工程师完成
l 控件识别和业务逻辑本身属于不同的领域,没有很好进行抽象封装
3. 测试库构架框架(The Test Library Architecture Framework)
说明:
l 箭头方向代表的是被调用和调用关系
l 将所有的针对测试系统本身的控件识别和控件支持的操作封装在测试库中
l 测试脚本调用测试库的同时传递外部的测试数据
l 测试库的编写由自动化测试开发工程编写(可以不懂业务),负责控件的变更和维护
l 测试脚本的编写可由对业务比较掌握的自动化测试开发工程编写,负责业务逻辑的变更和维护
l 测试数据由测试工程师维护(可以不懂自动化开发)
优点:
l 被测试系统无论是哪层发生变化,只需要相应的人员进行变更维护即可
l 完成了控件识别操作和业务逻辑的抽象分离
缺点:
变更引起的工作量还是附加在自动化测试开发工程师身上
4. 关键字驱动或表驱动测试框架(The Keyword-Driven or Table-Driven Testing Framework)
说明:
l 说到关键字驱动,当然得说QTP。确实当对象库(很类似测试库架构中的测试库)添加完成后,测试case步骤的组织就相当于是在关键字试图中选择控件对象(Control),动作(Action),参数(Parameters)。
l 仔细想想,当QTP在完成对被测试程序的录制后,完成了对象库的记录,关键字驱动测试case的步骤设置,如果再在table中存放一些测试数据,在测试步骤中进行调用的话,似乎以上三种架构所涉及的内容都得到了很好的运用,但再仔细一想,就QTP录制的测试程序来讲,其实什么架构都没有做,因为录制下来的脚本的维护成本是非常高昂的,因为从测试数据的维护,对象库的维护,业务逻辑的维护等等都必须要求维护者懂的QTP的使用,而且是具备一定水平的。这违背了架构的本身理念。所以得基于QTP做更上层次的对象抽象,最终QTP仅仅是个识别对象和运行VBScript脚本的工具,这一层次的架构设计就体现在VBScript的脚本组织上了。
l 换个角度,框架到底用来做什么,最终的目的无非是将不同层次的对象和逻辑进行抽象和分离封装,从而使得被测试程序的变更所导致的测试脚本框架的变更维护工作量减少到最少,更进一步,如果不懂自动化编程的普通测试工程师能不需要了解测试工具和框架本身的知识就能维护控件对象和业务逻辑,这样就可以将自动化测试工程的工作量进行很好的分摊。具体实施就是将控件对象,动作,参数等等从框架或工具本身剥离出来放在普通Excel表格中,组织成如下形式:
Window |
Control |
Action |
Arguments |
Calculator |
Menu |
View, Standard |
|
Calculator |
Pushbutton |
Click |
1 |
Calculator |
Pushbutton |
Click |
+ |
Calculator |
Pushbutton |
Click |
3 |
Calculator |
Pushbutton |
Click |
= |
Calculator |
Verify Result |
4 |
|
Calculator |
Clear |
||
Calculator |
Pushbutton |
Click |
6 |
Calculator |
Pushbutton |
Click |
- |
Calculator |
Pushbutton |
Click |
3 |
Calculator |
Pushbutton |
Click |
= |
Calculator |
Verify Result |
3 |
框架本身所要做的就是识别Excel表格中的这些控件对象以及Action
注:以上表格中还可以将数据剥离出去,以单独的数据Excel表格进行维护
优点:
极大的减少了自动化开发工程师维护量,毕竟在测试团队中,自动化开发工程师占的比较少
普通测试工程师,可以很好的维护自身负责的模块中涉及的测试case和测试数据
缺点:
框架的抽象程度比较高,对自动化测试工程师的开发能力比较高
总结:个人认为以上的四种架构是存在递进关系的,至少前三个是肯定的,原文中最后总结的图认为还是需要多种框架特点组合在一起的,还是有很好的借鉴意义的,这里一并附上
四种常用的自动化测试框架相关推荐
- 【测试开发】几种常见的自动化测试框架
几种常见的自动化测试框架 在软件测试领域,自动化测试框架有很多,这里主要介绍几种常用的自动化测试框架. 1.pytest pytest 是 Python 的一种单元测试框架,与 Python 自带的 ...
- 几种常用深度学习框架简介
几种常用深度学习框架简介 一.TensorFlow 1.1 Tensorflow简介 1.2 使用文档 1.3 预训练模型 二.Pytorch 2.1 Pytorch简介 2.2 使用文档 2.3 预 ...
- 后台CS代码中创建四种常用的SL动画效果
http://www.cnblogs.com/chengxingliang/archive/2011/03/07/1974436.html后台CS代码中创建四种常用的动画效果[附带源码实例] 转载于: ...
- [转载] java实现四种常用排序算法
参考链接: 用Java排序 四种常用排序算法 ##注:从小到大排 ##冒泡排序## 特点:效率低,实现简单 思想:每一趟将待排序序列中最大元素移到最后,剩下的为新的待排序序列,重复上述步骤直到排完所有 ...
- htt【RiPro网盘链接检测插件】目前支持四种常用网盘
介绍: 目前支持百度网盘.蓝奏云.天翼云盘.坚果云盘,后续将支持更多网盘,如果你也想自己常用的网盘加入评论或联系站长告知,谢谢! 另外如使用过程中发现有链接状态已检测结果不匹配,请带上链接找站长修复! ...
- (42)FPGA四种常用逻辑门(同或门)
(42)FPGA四种常用逻辑门(同或门) 1 文章目录 1)文章目录 2)FPGA入门与提升课程介绍 3)FPGA简介 4)FPGA四种常用逻辑门(同或门) 5)技术交流 6)参考资料 2 FPGA入 ...
- (41)FPGA四种常用逻辑门(异或门)
(41)FPGA四种常用逻辑门(异或门) 1 文章目录 1)文章目录 2)FPGA入门与提升课程介绍 3)FPGA简介 4)FPGA四种常用逻辑门(异或门) 5)技术交流 6)参考资料 2 FPGA入 ...
- (40)FPGA四种常用逻辑门(或非门)
(40)FPGA四种常用逻辑门(或非门) 1 文章目录 1)文章目录 2)FPGA入门与提升课程介绍 3)FPGA简介 4)FPGA四种常用逻辑门(或非门) 5)技术交流 6)参考资料 2 FPGA入 ...
- (39)FPGA四种常用逻辑门(与非门)
(39)FPGA四种常用逻辑门(与非门) 1 文章目录 1)文章目录 2)FPGA入门与提升课程介绍 3)FPGA简介 4)FPGA四种常用逻辑门(与非门) 5)技术交流 6)参考资料 2 FPGA入 ...
最新文章
- Python外壳:代码结构!(IF WHILE FOR RANGE...)
- 《Linux命令行与shell脚本编程大全 第3版》Shell脚本编程基础---20
- accept函数_基础套接字函数入门1
- (课程学习笔记)Python基础学习
- 关于EXCEL数据导入到SQLServer中字段存在NULL的问题
- 使用SAP Analytics Cloud展示全球新冠肺炎确诊总人数的分布情况
- Console.Write(程序猿?开发?写代码?编程?移动、网页、桌面开发?Oh,我连菜鸟都不是!);...
- CentOS 6服务器简单安全配置
- ArcEngine二次开发API之Bug集(一 )
- Serlizable序列化接口
- java程序默认包含的包是,Java程序默认引用的包是 答案:java.lang包
- atitit.团队建设总结fx O622
- es对几十亿数据能达到秒级响应吗_十亿级数据,秒级响应 | 观远数据「极速分析引擎」这样实现...
- WM8960的音量控制测试程序
- INA226+STC89C52RC读取电流电压功率
- php怎么将农历转换成公历,php农历转公历怎么实现
- 使用PPT画图,取消自动选点(自动吸附点)解决方案
- MMKV 组件-快速丶读丶查丶写的sp
- 5、流程变量Variables
- FSCapture 录制视频没有声音的解决方法
热门文章
- user not exist mysql_php连接mysql出错 Table 'test.user' doesn't exist
- 长沙劳动保障局引进Broadview提升“金保”服务效率
- 一个人做两件事和两个人做一件事
- 锐龙r7 6800h和酷睿i7 1260p哪个好 r76800h和i71260p对比
- 写小米商城时遇到的bug和一些样式写法
- Python-从百度百科上查找对应人名信息并整合下载到本地
- JZOJ 3.2 A组总结
- 利用python+百度AI搞定一个文字识别功能同时转换成语音
- JS-绑定事件3种方法
- java datagrid控件_12款Javascript表格控件(DataGrid)