Pytest 测试用例并行运行与分布式运行

简介

Pytest 支持测试用例的并行运行和分布式运行,这可以加速测试执行,特别是在大型测试套件中。


使用场景

  • 场景一

测试用例 1000 条,一个用例执行 1 分钟,一个测试人员执行需要 1000 分钟。
通常我们会用人力成本换取时间成本,加几个人一起执行,时间就会缩短。
如果 10 人一起执行只需要 100 分钟,这就是一种分布式场景。

  • 场景二

假设有个报名系统,对报名总数统计,数据同时进行修改操作的时候有可能出现问题,需要模拟这个场景,需要多用户并发请求数据。
解决方案:使用分布式并发执行测试用例。


使用步骤

  • 分布式插件pytest-xdist

  • 安装及运行pip install pytest-xdist

    • 注意:用例多的时候效果明显,多进程并发执行,同时支持allure。

      • 代码示例

        python 复制代码
        from time import sleep
        
        def test_foo():
            sleep(1)
            assert True
        
        def test_bar():
            sleep(1)
            assert True
        
        def test_bar1():
            sleep(1)
            assert True
        • 执行 pytest -n auto 启用并行测试,它会自动检测计算机的 CPU 核心数量,并根据可用的核心数来并行运行测试用例,以加快测试执行速度。
          • 运行结果

深入了解

  • pytest 的并行 / 分布式,不是 pytest 本体功能,而是靠pytest-xdist插件:
  • 主进程(master):只负责「收集用例 + 分发」
  • worker:真正执行测试
    📌 pytest 本身:单进程、单线程
    📌 并行 / 分布式:进程级隔离

并且需要注意:

❌ pytest 并行 ≠ 多线程

✅ pytest 并行 = 多进程

相关推荐
KmSH8umpK12 小时前
Redis分布式锁从原生手写到Redisson高阶落地,附线上死锁复盘优化方案进阶第三篇
redis·分布式·wpf
nbwenren15 小时前
2026实测:Gemini 3.1 Pro 从需求文档到 pytest 测试用例一条龙教程
测试用例·pytest
KmSH8umpK16 小时前
SpringBoot 分布式锁实战:从单机锁到Redis分布式锁全覆盖,解决超卖、重复下单、幂等并发问题
spring boot·redis·分布式
其实防守也摸鱼16 小时前
CSDN博客写什么?从0到1打造你的技术影响力
笔记·测试用例·博客·教程·ai写作·ai辅助·高质量
KmSH8umpK19 小时前
Redis分布式锁从原生手写到Redisson高阶落地,附线上死锁复盘优化方案
redis·分布式·wpf
长河20 小时前
XXL-JOB 从本地快速上手到核心架构深度解析
分布式
juniperhan20 小时前
Flink 系列第22篇:Flink SQL 参数配置与性能调优指南:从 Checkpoint 到聚合优化
大数据·数据仓库·分布式·sql·flink
我的xiaodoujiao1 天前
API 接口自动化测试详细图文教程学习系列16--项目实战演练3
python·学习·测试工具·pytest
juniperhan1 天前
Flink 系列第21篇:Flink SQL 函数与 UDF 全解读:类型推导、开发要点与 Module 扩展
java·大数据·数据仓库·分布式·sql·flink
我的xiaodoujiao1 天前
API 接口自动化测试详细图文教程学习系列15--项目实战演练2
python·学习·测试工具·pytest