接口测试平台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格式,替换即可保证最真实的数据格式了。


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


相关文章
|
2月前
|
网络协议 开发工具 Android开发
应用研发平台EMAS产品常见问题之接入httpdns后 访问重定向的url访问有问题如何解决
应用研发平台EMAS(Enterprise Mobile Application Service)是阿里云提供的一个全栈移动应用开发平台,集成了应用开发、测试、部署、监控和运营服务;本合集旨在总结EMAS产品在应用开发和运维过程中的常见问题及解决方案,助力开发者和企业高效解决技术难题,加速移动应用的上线和稳定运行。
|
1天前
|
消息中间件 测试技术 Linux
linux实时操作系统xenomai x86平台基准测试(benchmark)
本文是关于Xenomai实时操作系统的基准测试,旨在评估其在低端x86平台上的性能。测试模仿了VxWorks的方法,关注CPU结构、指令集等因素对系统服务耗时的影响。测试项目包括信号量、互斥量、消息队列、任务切换等,通过比较操作前后的时戳来测量耗时,并排除中断和上下文切换的干扰。测试结果显示了各项操作的最小、平均和最大耗时,为程序优化提供参考。注意,所有数据基于特定硬件环境,测试用例使用Alchemy API编写。
8 0
linux实时操作系统xenomai x86平台基准测试(benchmark)
|
1天前
|
传感器 Linux 测试技术
xenomai 在X86平台下中断响应时间测试
该文讨论了实时操作系统中断响应时间的重要性,并介绍了x86中断机制和Xenomai的中断管理,包括硬件中断和虚拟中断的处理。Xenomai通过I-Pipe确保实时性,中断优先级高的Xenomai先处理中断。文中还提到了中断响应时间的测试设计,分别针对I-Pipe内核间虚拟中断和硬件中断进行了测试,并给出了在不同负载下的测试结果。
7 0
xenomai 在X86平台下中断响应时间测试
|
9天前
|
Linux 测试技术 数据安全/隐私保护
CentOS安装MeterSphere并实现无公网IP远程访问本地测试平台
CentOS安装MeterSphere并实现无公网IP远程访问本地测试平台
|
17天前
|
人工智能 监控 数据处理
【AI大模型应用开发】【LangSmith: 生产级AI应用维护平台】1. 快速上手数据集与测试评估过程
【AI大模型应用开发】【LangSmith: 生产级AI应用维护平台】1. 快速上手数据集与测试评估过程
38 0
|
2月前
|
缓存 运维 Serverless
应用研发平台EMAS产品常见问题之测试检查更新没有反应如何解决
应用研发平台EMAS(Enterprise Mobile Application Service)是阿里云提供的一个全栈移动应用开发平台,集成了应用开发、测试、部署、监控和运营服务;本合集旨在总结EMAS产品在应用开发和运维过程中的常见问题及解决方案,助力开发者和企业高效解决技术难题,加速移动应用的上线和稳定运行。
|
2月前
|
机器学习/深度学习 人工智能 监控
视觉智能平台常见问题之体验产品的美颜测试关掉如何解决
视觉智能平台是利用机器学习和图像处理技术,提供图像识别、视频分析等智能视觉服务的平台;本合集针对该平台在使用中遇到的常见问题进行了收集和解答,以帮助开发者和企业用户在整合和部署视觉智能解决方案时,能够更快地定位问题并找到有效的解决策略。
24 1
|
3月前
|
测试技术
Lim测试平台测试报告说明
Lim测试平台测试报告说明
34 2
|
1月前
uView queryParams 对象转URL参数
uView queryParams 对象转URL参数
16 0
|
1月前
|
JavaScript
vue截取URL中的参数
vue截取URL中的参数
17 0

热门文章

最新文章