4.httprunner-参数化和数据驱动
前言
- 参数化在config中使用parameters关键字
- httprunner2.x 是在testsuite中实现参数化
- httprunner3.x 是在testcase中的config实现参数化
什么场景适合参数化
举例:
- 测试搜索功能,只有一个输入框,但是有十种不同的搜索关键字
- 测试账号登录功能,需要输入账号密码,然后按照等价类划分后有20种组合情况
参数基本分为两种
- 单个独立参数:举例的第一个场景,只需要变化搜索关键字这一个参数
- 多个具有关联性的参数:举例的第二个场景,需要变化账号密码两个参数,并且两个参数关联组合
实现场景
- 对于参数而言,我们可能具有一个参数列表,运行时按照不同的规则去取值
- 例如顺序取值、随机取值、循环取值等
- 这就是典型的参数化和数据驱动
单参数化实现
- 假设我们用4个账号登录,密码都是123456
- 我们通过parameters设置key为user,value为4个账号的列表
- 那么运行的时候,user依次循环取列表的值,供下方引用变量请求
- 列表有多少个参数,接口就会对应执行请求多少次,会有多少个用例
- 设置参数化的value必须是list
config: name: 登录用例 base_url: ${ENV(base_url)} # 设置变量 variables: password: 123456 #设置参数化 parameters: user:[test1,test2,test3,test4] teststeps: - name: step-登录 request: url: /v1/login/ method: POST params: user: $user #引用参数化命令 password: $password
多个参数一一对应参数化
- 场景:我们需要每个账号对应一个单独的密码来实现场景
- 我们继续parameters设置参数化,而多个不同的参数,我们用-隔开
- 每个账号对应一个单独的密码,我们需要两个参数,user和password
- 这两个参数,我们用-隔开定义两个key,然后一一对应下面的参数
- 执行的时候,两个key依次循环取对应值供下方引用
config:
name: 登录用例
base_url: ${ENV(base_url)}
parameters:
# 设置user和password两个key,用-隔开
# 每次按顺序循环取对应的值
user-password:
-[test1,123456]
-[test2,654321]
-[test3,987544]
-[test4,678910]
teststeps:
-
name: step-登录
request:
url: /v1/login/
method: POST
params:
user: $user
password: $password
笛卡尔积组合参数
- 比如测试账号有4种,[test1,test2,test3,test4]
- 密码也有4种,[123456,654321,56789,98765]
- 用笛卡尔积组合的话,就是4*4=16种组合用例
- 我们可以在parameters下单独设置两个key,user和password
- 将用户名和密码进行全组合,即每个用户名的取值都与每个密码的取值成对进行组合应
config: name: 登录用例 base_url: ${ENV(base_url)} parameters: user: [test1,test2,test3,test4] password: [123456,654321,56789,98765] teststeps: - name: step-登录 request: url: /v1/login/ method: POST params: user: $user password: $password
参数化引用CSV文件
- httprunner参数化数据源指定支持三种方式
- 在YAML/JSON中直接指定参数列表:该种方式最为简单易用,适合参数列表比较小的情况
- 通过内置的parameterize(可简写为P)函数引用CSV文件:该方式需要准备CSV数据文件,适合数据量比较大的情况
- 调用debugtalk.py中自定义的函数生成参数列表:该方式最为灵活,可通过自定义python函数实现任意场景的数据驱动机制,当需要动态生成参数列表时也需要选择该方法
parameterize(可简写为P)函数
#csv文件格式
#每列的第一行编写key,下面编写对应的值
#直接pycharm编辑每行用逗号隔开
user,password
test,1234
test2,1234
也可以值接csv文件编辑
引用文件
引用格式: ${P(文件路径/文件名.csv)}
config:
name: 登录用例
base_url: ${ENV(base_url)}
parameters:
# 引用
user-password: ${P(data/user.csv)}
teststeps:
-
name: step-登录
request:
url: /v1/login/
method: POST
params:
user: $user
password: $password
extract:
uid: body.uid
validate:
- eq: [status_code,200]
debugtalk函数
debugtalk文件建在项目根目录下,debugtalk.py
单参数引用
假设我们测试5个账号登录,在debugtalk里面编写一个函数,返回列表字典
#debugtalk.py
def get_user():
return [
{'user': 'test1'},
{'user': 'test2'},
{'user': 'test3'},
{'user': 'test4'},
{'user': 'test5'},
]
#yaml引用函数,引用格式:${函数名}
#返回的列表有多少个参数,就依次循环取值执行多少次用例
config:
name: 登录用例
base_url: ${ENV(base_url)}
variables:
password: 123456
parameters:#引用函数
user: ${get_user()}
teststeps:
-
name: step-登录
request:
url: /v1/login/
method: POST
params:
user: $user
password: $password
extract:
uid: body.uid
validate:
- eq: [status_code,200]
多参数引用
假设我们需要根据特定规则,生成任意数量的账号密码
#debugtalk
def get_user_password(n):
#n是要生成的数量
account = []
for i in range(1, n+1):
account.append({'user': 'test' + f'{i}', 'password': '123456'})
return account
#yaml文件引用
config:
name: 登录用例
base_url: ${ENV(base_url)}
parameters:
#两个key用-分隔
user-password: ${get_user_password(4)}
teststeps:
-
name: step-登录
request:
url: /v1/login/
method: POST
params:
user: $user
password: $password
extract:
uid: body.uid
validate:
- eq: [status_code,200]
风月都好看,人间也浪漫.
分类:
Httprunner接口自动化
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· winform 绘制太阳,地球,月球 运作规律
· AI与.NET技术实操系列(五):向量存储与相似性搜索在 .NET 中的实现
· 超详细:普通电脑也行Windows部署deepseek R1训练数据并当服务器共享给他人
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· 上周热点回顾(3.3-3.9)