06-Httprunner-参数化

简介: 06-Httprunner-参数化

前言

  • 本篇来学习Httprunner中参数化–parameters关键字的使用

参数化

  • 实现参数化有如下三种方式:
  • 在 YAML/JSON/py 中直接指定参数列表:该种方式最为简单易用,适合参数列表比较小的情况
  • 通过内置的 parameterize(可简写为P)函数引用 CSV 文件:该种方式需要准备 CSV 数据文件,适合数据量比较大的情况
  • 调用 debugtalk.py 中自定义的函数生成参数列表:该种方式最为灵活,可通过自定义 Python 函数实现任意场景的数据驱动机制,当需要动态生成参数列表时也需要选择该种方式

直接指定参数列表

独立参数
  • 场景:不同测试账号,使用同一个密码

示例

config:
    name: login case
    base_url: "https://postman-echo.com"
    variables:
        user: test
        password: 123456
    parameters:
        user: ["test1", "test2", "test3", "test4"]   # 使用相同变量名user, parameters优先级> variables优先级
teststeps:
-
    name: step login
    variables:
            password: 123456
    request:
        url: /api/v1/login
        method: POST
        json:
            username: $user   # 引用变量 
            password: $password
    validate:
        - eq: [status_code, 200]
关联参数
  • 对于具有关联性的多个参数,比如username和password,那么可以按照如下方式进行配置
config:
  name: test suite demo
  base_url: "https://postman-echo.com"
testcases:
-
  name: test case 1
  parameters:
    username-password:
      - [ "user1", "111111" ]
      - [ "user2", "222222" ]
      - [ "user3", "333333" ]
  testcase: /path/to/testcase1
  • 进行该配置后,测试用例在运行时就会对username和password实现数据驱动,即分别使用 {“username”: “user1”, “password”: “111111”}、{“username”: “user2”, “password”: “222222”}、{“username”: “user3”, “password”: “333333”} 运行 3 次测试,并且保证参数值总是成对使用。
笛卡尔积组合
  • 测试账号有四种[“test1”, “test2”, “test3”, “test4”],密码也有四种[“123456”, “1234567”, “12345678”, “123456789”],用笛卡尔积组合的话,就是4*4=16种组合
config:
    name: login case
    base_url: "https://postman-echo.com"
    variables:
        user: test
        password: 123456
    parameters:
        user: ["test1", "test2", "test3", "test4"]  
        passwprd :  ["123456", "1234567", "12345678", "123456789"]
teststeps:
-
    name: step login
    variables:
            password: 123456
    request:
        url: /api/v1/login
        method: POST
        json:
            username: $user   # 引用变量 
            password: $password
    validate:
        - eq: [status_code, 200]

CSV文件实现参数化

独立参数
  • 假设项目的根目录下有 data 文件夹,user.csv 位于其中,那么 user.csv 的引用描述如下

user.csv

user
test1
test2
test3
test4

yaml

config:
  name: test suite demo
  base_url: "https://postman-echo.com"
testcases:
-
  name: test case 1
  parameters:
    user: ${P(data/user.csv)}  # 通过内置的 parameterize(可简写为 P)函数引用 CSV 文件
  testcase: /path/to/testcase1
关联参数
  • 对于具有关联性的多个参数,例如 username 和 password,那么就可以创建 account.csv

account.csv

username,password
test1,111111
test2,222222
test3,333333

yaml

config:
  name: test suite demo
  base_url: "https://postman-echo.com"
testcases:
-
  name: test case 1
  parameters:
    username-password: ${P(data/account.csv)}
  testcase: /path/to/testcase1

debugtalk函数实现参数化

独立参数
  • 在 debugtalk.py 中定义一个函数,返回参数列表
    ** debugtalk.py**
def get_user_id():
    return [
        {"user_id": 1001},
        {"user_id": 1002},
        {"user_id": 1003},
        {"user_id": 1004}
    ]

yaml

config:
  name: test suite demo
  base_url: "https://postman-echo.com"
testcases:
-
  name: test case 1
  parameters:
    user_id: ${get_user_id()}  # ${函数名} 方式引用debugtalk.py中的函数
  testcase: /path/to/testcase1
关联参数

** debugtalk.py**

def get_account(num):
    accounts = []
    for index in range(1, num+1):
        accounts.append(
            {"username": "user%s" % index, "password": str(index) * 6},
        )
    return accounts

yaml

config:
  name: test suite demo
  base_url: "https://postman-echo.com"
testcases:
-
  name: test case 1
  parameters:
    username-password: ${get_account(10)}  # 生成10组数据
  testcase: /path/to/testcase1

参数化运行

  • 完成以上参数定义和数据源准备工作之后,参数化运行与普通测试用例的运行完全一致。 采用hrun命令运行自动化测试:
hrun tests/data/demo_parameters.yml


相关文章
|
机器学习/深度学习 自然语言处理 PyTorch
Transformers入门指南:从零开始理解Transformer模型
【10月更文挑战第29天】作为一名机器学习爱好者,我深知在自然语言处理(NLP)领域,Transformer模型的重要性。自从2017年Google的研究团队提出Transformer以来,它迅速成为NLP领域的主流模型,广泛应用于机器翻译、文本生成、情感分析等多个任务。本文旨在为初学者提供一个全面的Transformers入门指南,介绍Transformer模型的基本概念、结构组成及其相对于传统RNN和CNN模型的优势。
11636 1
|
JSON JavaScript 测试技术
全网最全httpruner自动化测试教程 全是干货
全网最全httpruner自动化测试教程 全是干货
|
安全 Java
ConcurrentHashMap扩容的详细介绍以及多线程测试(基于JDK1.8)
ConcurrentHashMap扩容的详细介绍以及多线程测试(基于JDK1.8) ConcurrentHashMap是Java中线程安全的哈希表实现。它使用了锁分段技术,将哈希表分成多个Segment(默认为16),每个Segment都是一个独立的哈希表,每个Segment内部维护一个ReentrantLock锁,对于不同的Segment,它们可以被并发访问。当进行put、get等操作时,只需要获取对应Segment的锁即可,大大提高了并发访问的效率。
444 0
|
安全 Linux 测试技术
|
测试技术
04-Httprunner-变量优先级
04-Httprunner-变量优先级
|
Unix Linux 程序员
一文详解常见开源协议
日常从Github拷贝代码过程中,也要抽空了解一下,我们拷贝的代码在商用上是否存在风险。版权保护方面,虽然相关法规尚有待完善,但在研发商用软件过程中,作为软件开发者还是很有必要了解一下,我们平时使用的`开源组件/框架`都涉及到了哪些开源协议,以避免今后的法律风险。
1476 0
|
测试技术 网络安全 数据安全/隐私保护