通过抓包能否做好接口测试

简介: 通过抓包能否做好接口测试

很多朋友在开始接触接口测试时,都会通过各类工具进行抓包,分析接口请求并开展接口测试。这是个不错的尝试,从个人的角度而言也没什么问题。但是如果是在实际的业务团队中,测试人员仅仅依赖抓包来开展接口测试,其实是非常不友好的。

01

从局限性的角度来看,没有接口文档,只通过抓包来做接口测试,会存在以下几个问题。

 

接口的完整性:通过页面操作,进行抓包,获取到的接口信息会有遗漏,最典型的就是登录接口的302重定向跳转,出于保护的目的,一些重要的核心接口,通常都会做重定向,导致通过抓包是无法获取到有效的接口信息,从而遗漏到部分接口。


如果直接请求/oauth/login,是无法实现登录的。

 

动态参数的识别:由于接口抓包抓到的请求信息都是处理好的静态数据,无法有效分辨哪些是动态参数(根据业务动态生成,比如订单号、密码、价格等),哪些是静态参数(下拉项、用户名、产地等),会导致接口重复发起时,由于数据问题引起失败。

 

参数名的可阅读性:对于有同样业务意义的参数,参数名可能不一样,比如用户账号,有时用userId,有时用username,有时用userName,有时用nickName,有时用userNo,甚至每一个接口内都没统一。或者用一些不是很好理解的方式来命名,会对接口测试产生严重的影响。可参考:你是这么写接口的么


 

解决方案:在开展接口自动化测试前,需要和研发约定好必要的接口文档输出(最常见的就是引入Swagger框架,对接口文档进行实时维护),并做好相关的参数命名规范,这样才有可能让接口测试落到实处并产生价值。

02

从可维护性的角度来看,没有接口文档,只通过抓包来做接口测试,会存在以下几个问题。

 

接口覆盖率的统计:没有相关的接口文档,通过抓包,无法有效地得知接口的覆盖范围,也就无法针对性地作补充,容易引发接口测试遗漏。

 

接口变更的维护:如果接口发生变更,仅从抓包是无法感知到的。这样会引发接口失败的误报,让排查问题的工作大大增加,也会让测试人员慢慢失去信心。

 

标准化内容的复用:通过抓包获取到的接口信息,导入到接口测试工具后(如此PostMan或者Jmeter),修改参数直接回放,那么就无法抽取共性的接口,也无法根据业务场景重新编排接口,从而导致接口用例无法复用。

 

解决方案:在有了接口文档的前提下,我们需要从接口文档中提取有用的信息,从而更好的设计接口用例,比如哪些值需要参数化,哪些返回值可以用于断言的验证等,同时,通过接口文档的定期Diff,可以尽早地发现接口变更,针对性地做验证。

03

在实际的团队落地中,接口测试要想做得好,标准化的接口文档是必备之物,只有标准化后,才有可能自动化,很多测试负责人仅从测试的角度发出,通过一些取巧的方式来实现接口自动化(比如通过Curl或者录制har文件,来实现接口测试),虽然能在短期内看似落地了接口自动化,但是缺乏对接口的理解,是无法长期执行并产生效果的。可参考:接口测试这么玩才明白

 

技术的落地都需要有前置条件,特别是测试作为研发链路的后期活动,不论是业务测试还是自动化测试,都需要依赖前面活动的规范化和标准化。才有可能事半功倍。尝试去推动上游的标准化,是测试负责人必备的能力,否则,很多测试活动都会受阻。

 

共勉。


相关文章
|
23天前
|
移动开发 JSON Java
Jmeter实现WebSocket协议的接口测试方法
WebSocket协议是HTML5的一种新协议,实现了浏览器与服务器之间的全双工通信。通过简单的握手动作,双方可直接传输数据。其优势包括极小的头部开销和服务器推送功能。使用JMeter进行WebSocket接口和性能测试时,需安装特定插件并配置相关参数,如服务器地址、端口号等,还可通过CSV文件实现参数化,以满足不同测试需求。
106 7
Jmeter实现WebSocket协议的接口测试方法
|
23天前
|
JSON 移动开发 监控
快速上手|HTTP 接口功能自动化测试
HTTP接口功能测试对于确保Web应用和H5应用的数据正确性至关重要。这类测试主要针对后台HTTP接口,通过构造不同参数输入值并获取JSON格式的输出结果来进行验证。HTTP协议基于TCP连接,包括请求与响应模式。请求由请求行、消息报头和请求正文组成,响应则包含状态行、消息报头及响应正文。常用的请求方法有GET、POST等,而响应状态码如2xx代表成功。测试过程使用Python语言和pycurl模块调用接口,并通过断言机制比对实际与预期结果,确保功能正确性。
101 3
快速上手|HTTP 接口功能自动化测试
|
23天前
|
JavaScript 前端开发 测试技术
ChatGPT与接口测试
ChatGPT与接口测试,测试通过
31 5
|
2月前
|
网络协议 测试技术 网络安全
Python进行Socket接口测试的实现
在现代软件开发中,网络通信是不可或缺的一部分。无论是传输数据、获取信息还是实现实时通讯,都离不开可靠的网络连接和有效的数据交换机制。而在网络编程的基础中,Socket(套接字)技术扮演了重要角色。 Socket 允许计算机上的程序通过网络进行通信,它是网络通信的基础。Python 提供了强大且易于使用的 socket 模块,使开发者能够轻松地创建客户端和服务器应用,实现数据传输和交互。 本文将深入探讨如何利用 Python 编程语言来进行 Socket 接口测试。我们将从基础概念开始介绍,逐步引导大家掌握创建、测试和优化 socket 接口的关键技能。希望本文可以给大家的工作带来一些帮助~
|
2月前
|
网络协议 测试技术 网络安全
Python进行Socket接口测试的实现
在现代软件开发中,网络通信是不可或缺的一部分。无论是传输数据、获取信息还是实现实时通讯,都离不开可靠的网络连接和有效的数据交换机制。而在网络编程的基础中,Socket(套接字)技术扮演了重要角色。 Socket 允许计算机上的程序通过网络进行通信,它是网络通信的基础。Python 提供了强大且易于使用的 socket 模块,使开发者能够轻松地创建客户端和服务器应用,实现数据传输和交互。 本文将深入探讨如何利用 Python 编程语言来进行 Socket 接口测试。我们将从基础概念开始介绍,逐步引导大家掌握创建、测试和优化 socket 接口的关键技能。希望本文可以给大家的工作带来一些帮助~
|
2月前
|
SQL Java 测试技术
SpringBoot单元测试快速写法问题之PorkService 接口中的 getPork 方法的作用如何解决
SpringBoot单元测试快速写法问题之PorkService 接口中的 getPork 方法的作用如何解决
|
2月前
|
XML Web App开发 数据挖掘
Postman接口测试工具全解析:功能、脚本编写及优缺点探讨
文章详细分析了Postman接口测试工具的功能、脚本编写、使用场景以及优缺点,强调了其在接口自动化测试中的强大能力,同时指出了其在性能分析方面的不足,并建议根据项目需求和个人偏好选择合适的接口测试工具。
55 1
|
2月前
|
Web App开发 JSON 测试技术
精通Postman接口测试:关联技术与自动化实践指南
这篇文章详细介绍了如何使用Postman进行接口测试,包括关联技术、自动化实践,以及如何通过环境变量和全局变量解决接口之间的关联性问题。
41 0
精通Postman接口测试:关联技术与自动化实践指南
|
2月前
|
SQL 安全 测试技术
[go 面试] 接口测试的方法与技巧
[go 面试] 接口测试的方法与技巧
|
2月前
|
测试技术 开发工具 Python
在Jetson Nano上编译 pyrealsense2库包,并在Intel的tof相机上进行测试
在Jetson Nano上编译 pyrealsense2库包,并在Intel的tof相机上进行测试
28 0
下一篇
无影云桌面