Skip to content

接口自动化测试概述与流程

接口测试概述

接口,又叫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安装