news 2026/4/22 18:26:36

【接口测试】5_代码实现 _pytest参数化

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
【接口测试】5_代码实现 _pytest参数化

文章目录

  • 一、参数化
  • 二、回顾pytest参数化
    • 2.1 加法原始案例 review_parameterize.py
    • 2.2 参数化实现(重点)
    • 2.3 参数化实现-进阶
      • 2.3.1 add_data.json
      • 2.3.2 从json文件读取 add_data.py
  • 三、参数化步骤
    • 3.1 接口参数化步骤
    • 3.2 编写参数化文件

一、参数化

参数化的核心:数据驱动(用数据驱动测试用例执行)

  • 数据驱动:针对一个接口,只写一个测试方法。用一份测试数据文件,管理各个测试用例的测试数据。
  • 如:登录接口,共 15 条测试用例。但,只需要一个 测试方法,对应 有 15 组数据的 json数据文件,进行测试。

二、回顾pytest参数化

2.1 加法原始案例 review_parameterize.py

# 待测 函数defadd(x,y):returnx+y# 结合 pytest 定义测试类classTestAddFunc(object):# 定义测试方法deftest01_add(self):res=add(10,20)# 调用 待测函数,得实际结果assert30==res# 断言deftest02_add(self):res=add(100,200)assert300==resdeftest03_add(self):res=add(1000,2000)assert3000==res

结果:

wangfei@afei_Mac parameterizeReviewSH27 % pytest -s review_parameterize.py review_parameterize.py...==================3passedin0.01s==================================================

2.2 参数化实现(重点)

importpytest# 待测 函数defadd(x,y):returnx+y data=[(10,20,30),(100,200,300),(1000,2000,3000)]# 结合 pytest 定义测试类classTestAddFunc(object):# 2个参数,第1个参数是一个字符串,对应每一组数据所对应的key;第2个参数是[(),(),()] 这种格式的数据,称作元祖列表# @pytest.mark.parametrize("",[(),(),()])@pytest.mark.parametrize("x, y, expect",data)# 参2 要求必须是 [(),(),()] 格式的数据deftest_add(self,x,y,expect):# 通用测试方法res=add(x,y)# 调用 待测函数,得实际结果assertexpect==res# 断言

2.3 参数化实现-进阶

2.3.1 add_data.json

[{"x":10,"y":20,"expect":30},{"x":100,"y":200,"expect":300},{"x":1000,"y":2000,"expect":3000}]

2.3.2 从json文件读取 add_data.py

importpytestimportjson# 待测 函数defadd(x,y):returnx+y# 封装函数,读取json文件,将 [{},{},{}] 数据 转换为 [(),(),()] 格式的数据defread_json_data(filename):withopen(filename,"r",encoding="utf8")asf:json_data=json.load(f)# 读取json文件data_list=[]fordatainjson_data:val=data.values()tmp=tuple(val)# 转换成元祖data_list.append(tmp)# 把元祖追加到空列表当中# 必须返回,不能在 for 内returndata_list# 返回 [(10, 20, 30), (100, 200, 300), (1000, 2000, 3000)]# 结合 pytest 定义测试类classTestAddFunc(object):@pytest.mark.parametrize("x, y, expect",read_json_data("add_data.json"))# 参2 要求必须是 [(),(),()] 格式的数据deftest_add(self,x,y,expect):# 通用测试方法res=add(x,y)# 调用 待测函数,得实际结果assertexpect==res# 断言

三、参数化步骤

  1. 将 测试数据,按 [{},{},{}] 格式 组织到 json文件中。
  2. 读取 json文件,将数据转换为 [(),(),()]
  3. 在通用测试方法上一行,添加 @pytest.mark.parameterize()
  4. 给 parameterize() 传参。参1:字符串类型,内容为 json文件中一组数据的 key。参2:[(),(),()]格式数据。
  5. 给 通用测试方法添加形参,与 parameterize() 参1 字符串的内容一致。
  6. 修改 通用测试方法 内部实现,使用形参。

3.1 接口参数化步骤

1、编写数据存储文件json2、编写读取工具方法read_json()3、使用参数化组件进行引用parametrize

3.2 编写参数化文件

心得:1、根据模块来新建json文件(1个模块1个json文件)2、最外侧使用{},模块下几个接口,编写几个key,值为列表3、列表值中,单接口有几组数据,就写几个[}.4、每个{}中,组成格式:说明+要进行参数的参数+预期结果
// 有几个接口,写几个key,值为列表。 在api_register_login.py中有5个接口 //[]中有几组数据,就有几个{}
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/21 0:03:03

完整开源表情包解决方案:Noto Emoji让跨平台沟通更生动

在现代数字交流中,你是否曾经遇到过表情符号显示为"豆腐块"的尴尬情况?Noto Emoji正是为了解决这一问题而生的终极开源表情库。这个由Google主导的项目不仅提供了全面的Unicode表情支持,更让跨平台的表情显示变得一致而美观。 【免…

作者头像 李华
网站建设 2026/4/18 6:40:15

移动端时间选择器深度实战指南:从集成到定制化开发

移动端时间选择器深度实战指南:从集成到定制化开发 【免费下载链接】uniapp-datetime-picker 项目地址: https://gitcode.com/gh_mirrors/un/uniapp-datetime-picker 在移动应用开发中,时间选择功能是用户交互的核心环节。无论是预约系统、数据筛…

作者头像 李华
网站建设 2026/4/21 12:53:20

GPT-SoVITS能否模拟权威/亲切的不同语气?

GPT-SoVITS能否模拟权威/亲切的不同语气? 在智能语音助手越来越频繁地出现在我们生活中的今天,一个明显的变化正在发生:人们不再满足于“机器说话”,而是期待它能像真人一样,懂得何时该严肃、何时该温柔。你希望家里的…

作者头像 李华
网站建设 2026/4/18 10:48:18

抗干扰设计在I2C工业传感器系统中的实践:实战案例

一次失败的I2C通信,教会我如何打造工业级传感器系统 几个月前,我在调试一个部署在化工厂的温湿度监测项目时,差点被自己设计的电路“打脸”。 系统结构看起来再简单不过:STM32主控通过I2C总线连接多个SHT35传感器,走的…

作者头像 李华
网站建设 2026/4/18 8:35:55

只需1分钟语音样本!GPT-SoVITS实现高精度音色克隆

只需1分钟语音样本!GPT-SoVITS实现高精度音色克隆 在虚拟主播、AI配音和数字人技术迅速普及的今天,一个现实问题始终困扰着开发者与内容创作者:如何用最少的数据,让机器“说出”某个人的真实声音?过去,要训…

作者头像 李华
网站建设 2026/4/21 11:29:27

TegraRcmGUI:从命令行到图形界面的Nintendo Switch定制革命

TegraRcmGUI:从命令行到图形界面的Nintendo Switch定制革命 【免费下载链接】TegraRcmGUI C GUI for TegraRcmSmash (Fuse Gele exploit for Nintendo Switch) 项目地址: https://gitcode.com/gh_mirrors/te/TegraRcmGUI 痛点分析:为什么传统方法…

作者头像 李华