基于WEB UI接口的轻量级软件自动化测试框架及实施方案
作者:网络转载 发布时间:[ 2014/7/18 10:08:23 ] 推荐标签:自动化测试框架
1 背景介绍
1.1 接口
web ui接口是服务器与客户端交互的方式,即浏览器或者其他客户端工具与web服务UI层交互的协议.常见的有两大类,一是浏览器与服务器交互的 HTTP,HTTPS协议的接口,另一类web service接口如soap,rmi,rpc等协议。这些接口的共通特征都是作为Server对外的UI提供通信服务。
1.2 接口测试
web ui接口测试即站在web服务程序UI层之上自动化测试的一种手段,是站在用户的角度上测试web服务程序业务逻辑的正确性。测试的重点是围绕web服务 暴露的接口检查接口数据的正确性,这个过程是将web服务程序当做黑盒,通过自动化测试技术提高测试执行效率降低人工回归的成本。
1.3 可测性分析
1.3.1 为什么做接口测试
在业务模块的分层测试中,各种测试方式的比重如下图所示,实践中我们从系统级测试发现的bug数目多,所以系统级测试占比比较大;除此之外,由于现在敏 捷的尝试以及普遍开展的项目迭代,面向模块提前介入测试的方式也越来越频繁,而此时并不具备系统级可测性,因此模块的接口成为测试自动化的好入口。
在业务系统常用测试方案中,有以下说明:
(1. 单测在不同的团队和模块有不同的作法,如果QA太多的介入,则对QA coding能力要求较高,case的传承性也受到挑战
(2. 业务模块接口测试主要关注接口请求参数与返回数据的正确性,以参数覆盖为测试等价类
(3. 系统级case对web业务模块来说都是基于浏览器用户行为的,目前有selenium自动化,大部分是手工测试。
从分层测试的特征,业务系统的结构出发,我们认为,接口测试的必要性包括:
(1. 迭代开发模式中,接口测试可先于系统级测试提前进行,属于测试前置
(2. 相比于基于浏览器客户端的系统级测试,接口测试更专注接口数据正确性,稳定性与可靠性的性价比高
1.3.2 接口可测性
接口在业务模块中的类型为典型的HTTP接口(Ajax,Dwr,Action…),也有Java类型的一些接口(RPC,RMI,SOAP),在可测性上具有一些共通特征:
(1. 可自动化率高:接口总能通过相应的client来发送请求
(2. 脱离RD代码依赖,只针对接口:属于黑盒测试范畴,难度较白盒低
(3. 执行速度介于系统级与单测之间:对于业务模块来讲,脱离浏览器后的接口测试稳定性与效率都是大幅提升
(4. 容易实现数据分离与数据驱动,容易抽取公共的框架性内容,降低case编写维护人员对coding的依赖
2 轻量级测试框架itest
itest是interface test接口测试框架的简称:支持基于网络通信的WEB UI接口自动化测试,支持HTTP,SOAP,RPC等几种常见协议,支持多种验证结果的模式,支持数据分离,主要的特征还是通过数据文件驱动测试执行,不需要编码实现测试用例。
2.1 架构设计
itest功能组成与基本处理流程如下图,以主要协议HTTP为例:
相关推荐
更新发布
功能测试和接口测试的区别
2023/3/23 14:23:39如何写好测试用例文档
2023/3/22 16:17:39常用的选择回归测试的方式有哪些?
2022/6/14 16:14:27测试流程中需要重点把关几个过程?
2021/10/18 15:37:44性能测试的七种方法
2021/9/17 15:19:29全链路压测优化思路
2021/9/14 15:42:25性能测试流程浅谈
2021/5/28 17:25:47常见的APP性能测试指标
2021/5/8 17:01:11