news 2026/5/30 2:35:38

接口自动化框架设计必备利器之参数传递

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
接口自动化框架设计必备利器之参数传递

🍅点击文末小卡片,免费获取软件测试全套资料,资料在手,涨薪更快

在我们设计自动化测试框架的时候,我们会经常将测试数据保存在外部的文件(如Excel、YAML)中,实现测试脚本与测试数据解耦,方便后期维护。

当涉及到业务场景接口用例时,由于接口与接口存在关联关系,需要从上游接口取出来相关字段传递给下游接口作为入参使用,比如在Excel中我们会这样做:

在excel中新增一列【提取响应】,将上游接口的响应字段提取出来,在下游接口当中通过标记符进行使${XXX}

在YAML中我们也会有类似的用法:

- casename: 修改用户信息 teststeps: - name: 登录成功 request: method: POST url: /login json: principal: lemon_auto credentials: lemon123456 appType: 3 loginType: 0 headers: Content-Type: application/json extract: token: $.access_token tokentype: $.token_type validate: - eq: [status_code, 200] - eq: [$.nickName, "lemon_auto"] - name: 进入到个人中心 request: method: GET url: /p/user/userInfo queryparam: null headers: Authorization: ${tokentype}${token} validate: - eq: [status_code, 200] - eq: [$.nickName, "lemon_auto"]

【extract】代表要提取的响应字段信息,在下游接口中同样通过${XXX}用法进行引用

参数传递替换实现

在框架中关键实现是需要识别到标记符并且进行参数的替换,一般的思路我们采用正则表达式识别标记符,并且配合环境变量取出对应的字段值再使用replace进行替换,整个的操作封装相比复杂性会比较高。

在python中提供了Template类,它能够非常简单的通过模块替换你想要的字符串。Template类中默认的替换模板就是${XXX}标记符,具体用法如下:

将要替换的原始字符串作为参数初始化Template对象

使用substitute方法,传递需要替换的内容from string import Template

# 原始数据 data = ''' { "address": "青海省西宁市城东区格兰小镇", "communityName": "八家湾小区", "nearbyLandmarks": "${mark}", "userId": ${userId} } ''' # 这里是需要替换的内容,字典类型 dict = {'userId':123456,'mark':"王府井"} print(Template(data).substitute(dict))

替换之后的结果为:

{ "address": "青海省西宁市城东区格兰小镇", "communityName": "八家湾小区", "nearbyLandmarks": "王府井", "userId": 123456 }

可以看到使用非常简单,通过substitute即可将字典中的数据替换到原始数据中。

那如果原始数据中的标记符和替换的内容不对应会有什么情况?

比如这里我的替换内容只有userId:

from string import Template data = ''' { "address": "青海省西宁市城东区格兰小镇", "communityName": "八家湾小区", "nearbyLandmarks": "${mark}", "userId": ${userId} } ''' dict = {'userId':123456} print(Template(data).substitute(dict))

此时会报KeyError的错误,找不到mark这个key,如果不想要报错你可以使用safe_substitutefrom string import Template

data = ''' { "address": "青海省西宁市城东区格兰小镇", "communityName": "八家湾小区", "nearbyLandmarks": "${mark}", "userId": ${userId} } ''' dict = {'userId':123456} print(Template(data).safe_substitute(dict) )

此时的输出结果为:

{ "address": "青海省西宁市城东区格兰小镇", "communityName": "八家湾小区", "nearbyLandmarks": "${mark}", "userId": 123456 }

我们可以看到safe_substitute不会报错,并且只会替换和标记符匹配的数据,不匹配的则保持原样。

最后感谢每一个认真阅读我文章的人,礼尚往来总是要有的,虽然不是什么很值钱的东西,如果你用得到的话可以直接拿走:

这些资料,对于做【软件测试】的朋友来说应该是最全面最完整的备战仓库,这个仓库也陪伴我走过了最艰难的路程,希望也能帮助到你!凡事要趁早,特别是技术行业,一定要提升技术功底。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/20 16:50:06

编程马拉松指定工具:LobeChat助力Hackathon选手

编程马拉松指定工具:LobeChat助力Hackathon选手 在编程马拉松(Hackathon)的赛场上,时间就是生命。一支三人小队挤在会议室角落,距离提交截止只剩六小时,需求文档还没读完,前端页面空空如也&…

作者头像 李华
网站建设 2026/5/27 10:17:17

整理25道SpringBoot面试题,请查收!!!

一、 什么是Spring Boot? 答:SpringBoot 是 Spring 开源组织下的子项目,是 Spring 组件一站式解决方案,主要是简化了使用 Spring 的难度,简省了繁重XML的配置,提供了各种启动器,在运行过程中自…

作者头像 李华
网站建设 2026/5/24 9:37:34

GraphRAG:从向量检索到知识图谱,大模型推理能力的革命性突破

GraphRAG通过引入知识图谱解决传统RAG的技术瓶颈,实现了从"搜索数据"到"推理洞察"的质变。它能处理多跳推理、全局性总结并提供可解释性,但面临构建成本高、图谱质量维护等挑战。未来将采用向量图谱的混合检索模式,针对不…

作者头像 李华
网站建设 2026/5/29 16:34:23

提示词工程:6大原则+实战案例,小白也能玩转大模型

提示词工程是解锁大模型能力的核心,通过科学设计Prompt,无需修改模型权重即可适配不同场景。文章系统介绍了大模型理解指令的底层逻辑,提出明确目标、补充上下文、提供示例、设定角色、规范格式、控制语气等六大核心原则,并结合分…

作者头像 李华
网站建设 2026/5/26 14:20:57

基于单片机出租车计价系统设计

基于单片机的出租车计价系统设计 第一章 绪论 传统出租车计价器多采用机械或早期电子电路设计,存在计价精度低、功能单一、易被篡改等问题,难以满足现代交通管理对计费透明化、智能化的需求。随着嵌入式技术的发展,基于单片机的计价系统凭借成…

作者头像 李华
网站建设 2026/5/29 22:43:33

AI之 n8n

关注AI圈的小伙伴应该注意到了,最近有个叫做『N8N』的AI项目突然火了起来,目前在GitHub上的start已经突破100K,成为当前开源AI工具类的No.1,非常的牛批! N8N之所以能这么受欢迎,是因为它被称之为史上最强AI…

作者头像 李华