接口测试平台插播: ( Postman 的小bug)

简介: 接口测试平台插播: ( Postman 的小bug)

  不知道大家知不知道一个事情:就是我们在进行测试post请求的时候,见到过字段名是相同的情况,比如:

微信图片_20220704230845.png

这个postman请求体,三个字段都一样,都是a这种情况,我们来看下postman的请求代码生成:

微信图片_20220704230855.png

微信图片_20220704230901.png

postman中,只是忠实的把这个请求体转换成了字典,然后在地下直接通过data=payload的方式传递了出去。

那么这种写法是正确的么?

答案是:

在没有同名字段的时候,是可以的。

但是一旦有同名字段,就不对了。


我们把这段代码复制到pycharm中来详细验证一下:

微信图片_20220704230908.png

注意,还没开始运行,pycharm已经在警告了。我们运行一下看看:

微信图片_20220704230914.png

结果正常显示,但是这是因为本接口是作者随便找的例子,并没有真正的需要字段a,甚至3遍!所以大多数情况下,我们很难去注意到这个细节bug。


   那我们要怎么来验证下呢?答案很简单,我们通过response,来输出它真实的请求体:

微信图片_20220704230920.png

输出:

微信图片_20220704230925.png

可以看到,它的请求体只有一个a,而且等于最后的值3,前面的1 和 2都被抛弃掉了。


我们再来修改请求体测试下:

微信图片_20220704230931.png

再看看结果:

微信图片_20220704230937.png

可以看到,b成功显示来了,但是a仍然只留一个最新的值。

所以这个写法是错误的。

大家不用怀疑了,因为博主今天测试接口,检查数据库的时候发现的这个情况,数据库中只保留了同名字段的最后一次值,所以排查出此问题,源头就是postman的请求代码的bug。


那这里我们要怎么修改,才能让这个a=1 a=2 a=3 b=5 同时当作请求发出去呢?


其实很简单,这里要弄明白,postman为什么会出现这个bug,原因是:很多人平时都会简单的把python中的字典,看作是 json格式。

而postman的开发者显然也这么认为,甚至我们在所有的python-requests的教程中,请求体都是这样字典的格式存在。


但是,这不行! 原因很简单, json允许 同名字段存在!而字典不允许!


所以我们在程序中加上这样一句打印:

微信图片_20220704230942.png

然后就看到了问题所在:

微信图片_20220704230948.png

在这个字典刚写完的时候,实际上已经自动去重了...... a=1 和a=2已经被丢弃了。


那这里我们要怎么修改呢?其实只要找一个新的格式来代替字典即可,它要具备俩种特性:

1.允许同名字段

2.可以被requests成功发出

3.可以让服务器成功解析


那么这种格式是什么?就是多元元组。


说的太多大家也不好理解,直接看代码吧,把格式改成这样:

微信图片_20220704230953.png

怎么样,看着是不是怪怪的,圆圆滚滚的还有点可爱~

直接请求:

微信图片_20220704230958.png

可以看到结果,成功的保存了同名字段a的所有值,并且被requests所认可,因为这是通过response.request.body打印出来的哦~

相关文章
|
2月前
|
关系型数据库 MySQL 测试技术
【分享】AgileTC测试用例管理平台使用分享
AgileTC 是一个脑图样式测试用例管理平台,支持用例设计、执行与团队协作,帮助测试人员高效管理测试流程。
201 116
【分享】AgileTC测试用例管理平台使用分享
|
2月前
|
测试技术 开发者 Python
Python单元测试入门:3个核心断言方法,帮你快速定位代码bug
本文介绍Python单元测试基础,详解`unittest`框架中的三大核心断言方法:`assertEqual`验证值相等,`assertTrue`和`assertFalse`判断条件真假。通过实例演示其用法,帮助开发者自动化检测代码逻辑,提升测试效率与可靠性。
235 1
|
2月前
|
人工智能 数据可视化 测试技术
AI测试平台自动遍历:低代码也能玩转全链路测试
AI测试平台的自动遍历功能,通过低代码配置实现Web和App的自动化测试。用户只需提供入口链接或安装包及简单配置,即可自动完成页面结构识别、操作验证,并生成可视化报告,大幅提升测试效率,特别适用于高频迭代项目。
|
2月前
|
人工智能 测试技术 调度
写用例写到怀疑人生?AI 智能测试平台帮你一键生成!
霍格沃兹测试开发学社推出AI智能测试用例生成功能,结合需求文档一键生成高质量测试用例,大幅提升效率,减少重复劳动。支持自定义提示词、多文档分析与批量管理,助力测试人员高效完成测试设计,释放更多时间投入核心分析工作。平台已开放内测,欢迎体验!
|
2月前
|
人工智能 测试技术 项目管理
测试不再碎片化:AI智能体平台「项目资料套件」功能上线!
在实际项目中,需求文档分散、整理费时、测试遗漏等问题常困扰测试工作。霍格沃兹推出AI智能体测试平台全新功能——项目资料套件,可将多个关联文档打包管理,并一键生成测试用例,提升测试完整性与效率。支持套件创建、文档关联、编辑删除及用例生成,适用于复杂项目、版本迭代等场景,助力实现智能化测试协作,让测试更高效、更专业。
|
3月前
|
存储 人工智能 算法
AI测试平台实战:深入解析自动化评分和多模型对比评测
在AI技术迅猛发展的今天,测试工程师面临着如何高效评估大模型性能的全新挑战。本文将深入探讨AI测试平台中自动化评分与多模型对比评测的关键技术与实践方法,为测试工程师提供可落地的解决方案。
|
5月前
|
存储 测试技术 虚拟化
VMmark 4.0.3 - 虚拟化平台基准测试
VMmark 4.0.3 - 虚拟化平台基准测试
123 0
VMmark 4.0.3 - 虚拟化平台基准测试
|
2月前
|
人工智能 数据可视化 测试技术
AI 时代 API 自动化测试实战:Postman 断言的核心技巧与实战应用
AI 时代 API 自动化测试实战:Postman 断言的核心技巧与实战应用
399 11
|
2月前
|
人工智能 自然语言处理 测试技术
AI测试平台的用例管理实践:写得清晰,管得高效,执行更智能
在测试过程中,用例分散、步骤模糊、回归测试效率低等问题常困扰团队。霍格沃兹测试开发学社推出的AI测试平台,打通“用例编写—集中管理—智能执行”全流程,提升测试效率与覆盖率。平台支持标准化用例编写、统一管理操作及智能执行,助力测试团队高效协作,释放更多精力优化测试策略。目前平台已开放内测,欢迎试用体验!
|
3月前
|
存储 人工智能 文字识别
从零开始打造AI测试平台:文档解析与知识库构建详解
AI时代构建高效测试平台面临新挑战。本文聚焦AI问答系统知识库建设,重点解析文档解析关键环节,为测试工程师提供实用技术指导和测试方法论