Appearance
接口自动化测试概述与流程
接口测试概述
接口,又叫API(Application Programming Interface,应用程序编程接口),用于系统与系统或代码模块与模块之间的交互和数据传输。
代码内部模块与模块之间的接口,叫程序接口。
系统与系统之间,通过网络数据的传递进行交互,叫做协议接口。
接口测试,即对接口之间交互和数据传输的稳定性、正确性等方面进行测试。一般指协议接口。
为什么要做(自动化)接口测试?
1、由于现在各个系统的复杂度不断上升,导致传统的测试方法成本上升且测试效率大幅下降,而接口测试相对于UI测试更加稳定,且相对容易实现自动化持续集成,可以减少人工回归测试的时间成本,缩短测试周期。
2、接口测试可以更早的介入到项目开发中,一般只要接口定义好了,就可以写代码了。而功能测试必须要等系统提供可测的界面后才能进行。
3、相对于UI测试(某些测试环境搞起来贼麻烦)来说,接口测试可以更简单全面地覆盖到底层的代码逻辑,从而发现一些隐藏bug。
4、从安全层面来说,现在大部分系统前后端框架是分离的,只依赖前端进行限制已经不能满足系统的安全要求,需要后端同步进行控制,所以测试也需要从接口层面进行验证。
5.越来越多的团队开始接收DevOps所倡导的高度协同,研发、测试、运维及交付一体化的思维,对测试效能提出了更高的要求。
接口测试原理
- 业务功能(包括正常、异常场景是否实现)
- 业务规则(覆盖度是否全面)
- 参数验证(边界、业务规则是否达到要求)
- 异常场景(重复提交、并发提交、事务中断、多机环境、大数据量测试)
- 性能测试(响应时间、吞吐量、并发数、资源要求)
- 安全测试(权限验证、SQL注入等)
接口自动化测试流程
1、熟悉业务和需求,评估可行性和测试范围
并不是所有的业务都适合自动化,需要评估可行性、性价比、可持续性等等。比如一个项目,只做1.0版本,做完就结束了,还做什么自动化?
2、确定方案
具体业务具体分析,与团队完成最适合的工具选型。
常用的方案有:
①现成的开源工具:postman/jmeter 等
②一些第三方平台(收费的)
③自己公司开发自动化测试平台(少,且平台质量很难把控)
④代码编辑自动化框架,pytest等
3、设计自动化测试执行框架搭建
什么是框架?就是让接口测试脚本运行的一整套环境,包括脚本语言、工具、测试用例、执行策略、测试报告、日志收集、数据分析、报告可视化等。
4、执行测试
通过我们设计的框架执行测试用例,在过程中需要持续关注整个框架可优化的点。主要流程为:发送请求--获取结果--解析结果
5、输出测试报告
同样通过测试框架输出测试报告,报告应该注意要结果明确、结构清晰
6、持续集成
对接口测试而言,持续集成是自动化的关键。在初步实现接口自动化测试之后,还需要持续的加强自动化程度。
①流程方面:在过程中不断加强接口异常场景覆盖度,并逐步向系统测试、冒烟测试方面延伸,最终达到全流程自动化
②结果展示:更加丰富的结果展示、数据统计、质量分析等。
③问题定位:通过报错信息、日志、截图等手段,降低开发定位问题的难度。
④结果校验:不断提高结果的自动化校验能力,如数据库信息校验。
⑤拓展:向性能测试/安全测试等方向拓展,通过自动化手段监控接口性能指标是否正常。
说明
开始系统学习前需要准备一些环境。
- python环境
- 安装pytest、requests库
- 了解一款抓包工具,例如fiddler,charles
- postman/jmeter安装