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 并行 = 多进程

相关推荐
念越2 小时前
第十七届蓝桥杯软件测试模拟赛1期题目及解析
蓝桥杯·测试用例·测试
姚青&2 小时前
Pytest 第三方插件与 Hook
pytest
twc8293 小时前
需求条目化与RAG:让大模型生成测试用例真正可用的两把钥匙
软件测试·大模型·测试用例·rag
小罗和阿泽16 小时前
接口测试系列 接口自动化测试 pytest框架(一)
pytest
若水不如远方17 小时前
分布式一致性(六):拥抱可用性 —— 最终一致性与 Gossip 协议
分布式·后端·算法
睡醒的土豆20 小时前
解决 Kafka 管理工具中文乱码问题
分布式·kafka
SuniaWang1 天前
《Spring AI + 大模型全栈实战》学习手册系列· 专题二:《Milvus 向量数据库:从零开始搭建 RAG 系统的核心组件》
java·人工智能·分布式·后端·spring·架构·typescript
Hui Baby1 天前
TIDB分布式数据库提交设想
数据库·分布式·tidb