当前位置: 首页 > news >正文

pytest的装饰器`pytest.mark.parametrize` 和 `@pytest.mark.smoke`区别

pytest.mark.parametrize@pytest.mark.smoke 都是 Pytest 中常用的装饰器,但它们的目的、功能和应用场景完全不同

1. pytest.mark.parametrize (参数化测试)

  • 目的: 数据驱动测试。用于对同一个测试函数或方法,使用多组不同的输入参数和预期结果来运行多次,避免重复编写结构相同的测试用例。
  • 功能:
    • 接收两个主要参数:argnames(字符串或字符串列表,指定参数名)和 argvalues(可迭代对象,通常是列表/元组组成的列表,提供每组参数值)。
    • 它会根据 argvalues 中提供的参数组合数量,动态生成并运行多个独立的测试用例
    • 每个生成的测试用例在报告中都是独立显示的。
  • 应用场景:
    • 验证函数/方法在不同输入下的行为: 例如测试一个计算器函数对多组数字的加减乘除结果。
    • 测试边界值和特殊情况: 输入为空、最大值、最小值、非法字符等。
    • 组合测试: 测试不同配置或状态组合下的功能。
    • 避免重复代码: 当测试逻辑相同,只有输入数据和预期输出不同时。
  • 示例:
    import pytest@pytest.mark.parametrize("test_input, expected", [("3+5", 8),("2+4", 6),("6*9", 54),("10-3", 7),
    ])
    def test_eval(test_input, expected):assert eval(test_input) == expected
    
    运行结果: Pytest 会生成并运行 4 个独立的测试项。

2. @pytest.mark.smoke (自定义标记 - 以 smoke 为例)

  • 目的: 对测试用例进行分类、分组和选择执行smoke 只是一个常见的自定义标记名称(表示“冒烟测试”),你可以创建任何名称的标记(如 @pytest.mark.login, @pytest.mark.api, @pytest.mark.slow)。
  • 功能:
    • 它本身不改变测试函数的逻辑,也不生成新的测试用例。
    • 它给测试函数附加一个元数据(metadata)标签
    • 这个标签的主要作用是在运行测试时,通过 Pytest 的命令行选项(-m选择性地运行具有特定标记的测试用例,或者排除具有特定标记的测试用例
    • 也可以用于在测试报告中过滤或分类测试用例。
  • 应用场景:
    • 标记冒烟测试: 快速验证核心功能是否正常(@pytest.mark.smoke)。
    • 按功能模块分组: 标记属于登录模块的测试 (@pytest.mark.login)、支付模块的测试 (@pytest.mark.payment)。
    • 按测试类型分组: 标记集成测试 (@pytest.mark.integration)、端到端测试 (@pytest.mark.e2e)。
    • 按执行速度分组: 标记运行缓慢的测试 (@pytest.mark.slow),以便在快速迭代时跳过它们。
    • 按环境要求分组: 标记需要特定环境(如数据库、外部 API)的测试 (@pytest.mark.db, @pytest.mark.external_api)。
    • 按优先级分组: 标记高优先级 (@pytest.mark.high) 或低优先级 (@pytest.mark.low) 的测试。
  • 示例:
    import pytest@pytest.mark.smoke
    def test_login_success():# 测试核心登录成功流程assert login("valid_user", "valid_pass") is True@pytest.mark.login
    def test_login_failure_invalid_password():# 测试登录失败(密码错误)assert login("valid_user", "wrong_pass") is False@pytest.mark.slow
    def test_large_file_upload():# 测试上传大文件,耗时较长...
    
    运行命令:
    • pytest -m smoke: 只运行标记了 smoke 的测试用例 (如 test_login_success)。
    • pytest -m "login and not slow": 运行标记了 login 且没有标记 slow 的测试用例 (如 test_login_failure_invalid_password)。
    • pytest -m "not slow": 运行所有没有标记 slow 的测试用例。

核心区别总结

特性pytest.mark.parametrize@pytest.mark.smoke (或任何自定义标记)
主要目的数据驱动 - 用多组数据运行同一测试逻辑多次分类/分组/筛选 - 给测试用例打标签
是否生成新测试用例 - 根据参数组合动态生成多个测试项 - 只是给现有测试函数附加元数据标签
改变测试逻辑/次数 - 一个函数变成多个测试执行 - 测试函数本身逻辑和执行次数不变
核心参数argnames, argvalues (定义参数名和值组合) (标记名称本身是自定义的字符串)
主要应用场景覆盖不同输入数据、边界条件、组合场景;减少重复代码选择性运行(冒烟、模块、类型、优先级);测试分类
Pytest 命令行使用不直接通过命令行选项控制参数化本身通过 -m <marker_expression> 筛选测试用例
报告中的表现参数化的测试显示为多个独立的测试项测试项带有标记信息,可用于报告过滤
本质一个强大的测试生成器一个简单的元数据标签

结合使用

它们经常一起使用,以达到更精细的控制:

import pytest# 参数化一个被标记为冒烟测试的核心功能
@pytest.mark.smoke
@pytest.mark.parametrize("username, password, expected", [("admin", "secret", True),   # 有效凭证("admin", "wrong", False),  # 无效密码 (也属于核心流程)
])
def test_admin_login(username, password, expected):result = login(username, password)assert result == expected
  • 这个测试既是冒烟测试@pytest.mark.smoke),因为它测试了核心的登录流程(包括成功和预期的失败)。
  • 它也是参数化的(@pytest.mark.parametrize),用两组数据覆盖了管理员登录的成功和失败场景。
  • 运行 pytest -m smoke 会执行这个参数化测试生成的两个测试项。

总结

  • pytest.mark.parametrize 当你需要用不同的输入数据多次执行相同的测试逻辑,以扩大测试覆盖范围。
  • @pytest.mark.<your_marker> (如 smoke) 当你需要对测试用例进行分类、分组,并在运行测试时根据这些分类进行选择或排除smoke 只是一个常用标记名称的示例,你可以定义任何有意义的标记。

理解它们的区别能帮助你更有效地利用 Pytest 组织和管理你的测试套件。

相关文章:

  • 【C++】模拟实现map和set
  • JNDI注入入门
  • 互联网大厂Java求职面试:AI大模型应用实践中的架构挑战与实战
  • 探索niri:让你的Linux桌面布局无拘无束
  • 中年迷航,正念掌舵:在失业与转型中,找回内心的“定盘星”
  • 使用STM32设置GPIO中断
  • NLP学习路线图(四十六):可解释性
  • 华为云Flexus+DeepSeek征文 | 基于华为云Dify-LLM应用开发平台构建写作助手
  • 流程规划进阶——59页 15.流程的梳理方法【附全文阅读】
  • 标准库转hal库
  • JUC核心解析系列(一)——原子类深度解析
  • [C++] STL大家族之<map>(字典)容器(附洛谷)
  • 双重特征c++
  • 用于生成式新颖视图合成的密集 3D 场景完成
  • 字节FlowGram:AI时代可视化工作流的新范式
  • 项目会议过多如何优化沟通效率
  • 大模型——Dify 与 Browser-use 结合使用
  • 【Golang面试题】什么是 sync.Once
  • 薛定谔的猫思想实验如何推演到量子计算
  • mysql 创建大写字母的表名失败
  • 国内哪些网站是php做的/市场营销主要学什么
  • 1688开山网一起做网站/软文怎么写比较吸引人
  • 电子商务网站建设主要内容/广告招商
  • 网站制作最流行软件/企业网站开发公司
  • 做app还是做网站合适6/游戏推广是什么工作
  • 入境美国前做登记叫啥网站/深圳龙华区大浪社区