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

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

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

01

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

 

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


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

 

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

 

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


 

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

02

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

 

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

 

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

 

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

 

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

03

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

 

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

 

共勉。


相关文章
|
1月前
|
数据可视化 前端开发 测试技术
接口测试新选择:Postman替代方案全解析
在软件开发中,接口测试工具至关重要。Postman长期占据主导地位,但随着国产工具的崛起,越来越多开发者转向更适合中国市场的替代方案——Apifox。它不仅支持中英文切换、完全免费不限人数,还具备强大的可视化操作、自动生成文档和API调试功能,极大简化了开发流程。
|
5天前
|
JSON 前端开发 测试技术
大前端之前端开发接口测试工具postman的使用方法-简单get接口请求测试的使用方法-简单教学一看就会-以实际例子来说明-优雅草卓伊凡
大前端之前端开发接口测试工具postman的使用方法-简单get接口请求测试的使用方法-简单教学一看就会-以实际例子来说明-优雅草卓伊凡
43 10
大前端之前端开发接口测试工具postman的使用方法-简单get接口请求测试的使用方法-简单教学一看就会-以实际例子来说明-优雅草卓伊凡
|
3天前
|
JSON 前端开发 API
以项目登录接口为例-大前端之开发postman请求接口带token的请求测试-前端开发必学之一-如果要学会联调接口而不是纯写静态前端页面-这个是必学-本文以优雅草蜻蜓Q系统API为实践来演示我们如何带token请求接口-优雅草卓伊凡
以项目登录接口为例-大前端之开发postman请求接口带token的请求测试-前端开发必学之一-如果要学会联调接口而不是纯写静态前端页面-这个是必学-本文以优雅草蜻蜓Q系统API为实践来演示我们如何带token请求接口-优雅草卓伊凡
24 5
以项目登录接口为例-大前端之开发postman请求接口带token的请求测试-前端开发必学之一-如果要学会联调接口而不是纯写静态前端页面-这个是必学-本文以优雅草蜻蜓Q系统API为实践来演示我们如何带token请求接口-优雅草卓伊凡
|
1月前
|
存储 测试技术 数据库
接口测试工具攻略:轻松掌握测试技巧
在互联网快速发展的今天,软件系统的复杂性不断增加,接口测试工具成为确保系统稳定性的关键。它如同“翻译官”,模拟请求、解析响应、验证结果、测试性能并支持自动化测试,确保不同系统间信息传递的准确性和完整性。通过Apifox等工具,设计和执行测试用例更加便捷高效。接口测试是保障系统稳定运行的第一道防线。
|
1月前
|
Web App开发 JSON 测试技术
API测试工具集合:让接口测试更简单高效
在当今软件开发领域,接口测试工具如Postman、Apifox、Swagger等成为确保API正确性、性能和可靠性的关键。Postman全球闻名但高级功能需付费,Apifox则集成了API文档、调试、Mock与自动化测试,简化工作流并提高团队协作效率,特别适合国内用户。Swagger自动生成文档,YApi开源但功能逐渐落后,Insomnia界面简洁却缺乏团队协作支持,Paw仅限Mac系统。综合来看,Apifox是国内用户的理想选择,提供中文界面和免费高效的功能。
|
2月前
|
监控 JavaScript 测试技术
postman接口测试工具详解
Postman是一个功能强大且易于使用的API测试工具。通过详细的介绍和实际示例,本文展示了Postman在API测试中的各种应用。无论是简单的请求发送,还是复杂的自动化测试和持续集成,Postman都提供了丰富的功能来满足用户的需求。希望本文能帮助您更好地理解和使用Postman,提高API测试的效率和质量。
135 11
|
3月前
|
JSON Java 测试技术
SpringCloud2023实战之接口服务测试工具SpringBootTest
SpringBootTest同时集成了JUnit Jupiter、AssertJ、Hamcrest测试辅助库,使得更容易编写但愿测试代码。
92 3
|
4月前
|
自然语言处理 机器人 Python
ChatGPT使用学习:ChatPaper安装到测试详细教程(一文包会)
ChatPaper是一个基于文本生成技术的智能研究论文工具,能够根据用户输入进行智能回复和互动。它支持快速下载、阅读论文,并通过分析论文的关键信息帮助用户判断是否需要深入了解。用户可以通过命令行或网页界面操作,进行论文搜索、下载、总结等。
108 1
ChatGPT使用学习:ChatPaper安装到测试详细教程(一文包会)
|
4月前
|
JSON 算法 数据可视化
测试专项笔记(一): 通过算法能力接口返回的检测结果完成相关指标的计算(目标检测)
这篇文章是关于如何通过算法接口返回的目标检测结果来计算性能指标的笔记。它涵盖了任务描述、指标分析(包括TP、FP、FN、TN、精准率和召回率),接口处理,数据集处理,以及如何使用实用工具进行文件操作和数据可视化。文章还提供了一些Python代码示例,用于处理图像文件、转换数据格式以及计算目标检测的性能指标。
109 0
测试专项笔记(一): 通过算法能力接口返回的检测结果完成相关指标的计算(目标检测)
|
5月前
|
JavaScript 前端开发 测试技术
ChatGPT与接口测试
ChatGPT与接口测试,测试通过
82 5