接口测试平台182:并发用例底层-临时变量替换 URL

简介: 接口测试平台182:并发用例底层-临时变量替换 URL

上节课我们梳理之后,本节课就要正式开发对url / header / body的三处替换,我仔细看了下之前我设计的规则,占位变量必须用 ##变量名## 来占位。


   在我们之前的开发中,是直接从run_case.py中复制过来旧逻辑的替换代码:

   

image.png


   仔细观察,虽然替换的逻辑没有发生变化,但是取值明显不对了。


   原来我们是用临时缓存的变量来传递,即 repr(str(eval(i))),也正是因为如此才造成了并发时候的bug。


   而现在我们现在是要从tmp_data中直接拿即可。

   这里我们需要注意,图中的四处取值,其中两处是需要进行repr的,也就是需要用到完整的表达式方法展示数值。

image.png


      这是因为url 和 普通文本参数 都是纯字符串替换。而json请求体和header的值有可能是任何格式,所以需要用到repr后才能替换。


   repr:

image.png


   所以我们用字典的话,也需要考虑一下这里。


   不过在此之前,让我们先简单的实现另外两处 str(eval(i))的变化吧:

   

image.png


   然后再考虑这俩个repr。

   

image.png


   注意,这里我们要实际的去考虑这些参数的值 是怎么提取出来的。


先来回顾这部分代码:

image.png


   如果是路径法提取出来的,那就肯定是原始格式,整形就是整形,列表就是列表....  而用正则法拿出来的一定是字符串。

   

   但是等到替换的时候,只能以字符串格式进行替换。


   那么为什么要用到repr?


   我们来看这个例子:


   

image.png


   如果我们按照上图这个例子中,直接进行替换。那么得到的结果,新的替换后的new_d 就是:

image.png


   请问,abc是什么? 应该是个字符串,但是双引号呢? 丢了吧? 这样当做header传输肯定会报错了

   我们的预期应该是 :   {"key":"abc" }


   所以需要进行repr处理:

image.png


   这样的结果就变成:

   

image.png

   

   这就算是实现了。


   当然,小伙伴在写的时候,可能还会遇到bug或者报错。


   其中有个可能的原因就是用户在设置的时候 设置成:


   占位符带了额外的引号。

image.png

那么结果就变成了:

   

image.png

显然,多了引号。


这里的问题就是一个哲学问题了。因为用户如果随心所欲的去设计。那么我们的系统永远不可能正确。


   比如 例子中的 header, 用户设置成 {"key": ##a## }

   此时,你猜用户是按照哪种规则呢? 我们最终的a 是按照字符串放进来,还是原始类型呢? 我们是给a 用repr加上引号还是不加使用原始忠实替换呢?


   如果我们确定给加引号,那万一a是个整形123,结果就变成了"123"

   如果我们不给加引号,那万一a是个字符串"abc" ,结果替换就变成了 abc


   所以最好的办法就是 规定!


   规定 用户设置的值,不要手动额外加任何引号括号等,保持原始变量放在那就行。

   然后我们的代码用repr拿到原始值的string格式,替换即可保证最真实的数据格式了。


    好了,本节课到此结束。下节课我们要去完善 实际的报告整合部分功能了,欢迎继续关注:测试开发干货


相关文章
|
8天前
|
监控 JavaScript 测试技术
postman接口测试工具详解
Postman是一个功能强大且易于使用的API测试工具。通过详细的介绍和实际示例,本文展示了Postman在API测试中的各种应用。无论是简单的请求发送,还是复杂的自动化测试和持续集成,Postman都提供了丰富的功能来满足用户的需求。希望本文能帮助您更好地理解和使用Postman,提高API测试的效率和质量。
45 11
|
1月前
|
人工智能 供应链 安全
AI辅助安全测试案例某电商-供应链平台平台安全漏洞
【11月更文挑战第13天】该案例介绍了一家电商供应链平台如何利用AI技术进行全面的安全测试,包括网络、应用和数据安全层面,发现了多个潜在漏洞,并采取了有效的修复措施,提升了平台的整体安全性。
|
1月前
|
JSON Java 测试技术
SpringCloud2023实战之接口服务测试工具SpringBootTest
SpringBootTest同时集成了JUnit Jupiter、AssertJ、Hamcrest测试辅助库,使得更容易编写但愿测试代码。
65 3
|
1月前
|
监控 安全 测试技术
构建高效的精准测试平台:设计与实现指南
在软件开发过程中,精准测试是确保产品质量和性能的关键环节。一个精准的测试平台能够自动化测试流程,提高测试效率,缩短测试周期,并提供准确的测试结果。本文将分享如何设计和实现一个精准测试平台,从需求分析到技术选型,再到具体的实现步骤。
142 1
|
2月前
|
人工智能 监控 测试技术
云应用开发平台测试
云应用开发平台测试
79 2
|
1月前
|
监控 安全 测试技术
构建高效精准测试平台:设计与实现全攻略
在软件开发过程中,精准测试是确保产品质量的关键环节。一个高效、精准的测试平台能够自动化测试流程,提高测试覆盖率,缩短测试周期。本文将分享如何设计和实现一个精准测试平台,从需求分析到技术选型,再到具体的实现步骤。
67 0
|
2月前
|
JSON 算法 数据可视化
测试专项笔记(一): 通过算法能力接口返回的检测结果完成相关指标的计算(目标检测)
这篇文章是关于如何通过算法接口返回的目标检测结果来计算性能指标的笔记。它涵盖了任务描述、指标分析(包括TP、FP、FN、TN、精准率和召回率),接口处理,数据集处理,以及如何使用实用工具进行文件操作和数据可视化。文章还提供了一些Python代码示例,用于处理图像文件、转换数据格式以及计算目标检测的性能指标。
79 0
测试专项笔记(一): 通过算法能力接口返回的检测结果完成相关指标的计算(目标检测)
|
3月前
|
移动开发 JSON Java
Jmeter实现WebSocket协议的接口测试方法
WebSocket协议是HTML5的一种新协议,实现了浏览器与服务器之间的全双工通信。通过简单的握手动作,双方可直接传输数据。其优势包括极小的头部开销和服务器推送功能。使用JMeter进行WebSocket接口和性能测试时,需安装特定插件并配置相关参数,如服务器地址、端口号等,还可通过CSV文件实现参数化,以满足不同测试需求。
268 7
Jmeter实现WebSocket协议的接口测试方法
|
3月前
|
JSON 移动开发 监控
快速上手|HTTP 接口功能自动化测试
HTTP接口功能测试对于确保Web应用和H5应用的数据正确性至关重要。这类测试主要针对后台HTTP接口,通过构造不同参数输入值并获取JSON格式的输出结果来进行验证。HTTP协议基于TCP连接,包括请求与响应模式。请求由请求行、消息报头和请求正文组成,响应则包含状态行、消息报头及响应正文。常用的请求方法有GET、POST等,而响应状态码如2xx代表成功。测试过程使用Python语言和pycurl模块调用接口,并通过断言机制比对实际与预期结果,确保功能正确性。
285 3
快速上手|HTTP 接口功能自动化测试
|
3月前
|
JavaScript 前端开发 测试技术
ChatGPT与接口测试
ChatGPT与接口测试,测试通过
58 5