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

相关推荐
huohuopro8 小时前
Hbase伪分布式远程访问配置
数据库·分布式·hbase
Francek Chen9 小时前
【大数据存储与管理】NoSQL数据库:01 NoSQL简介
大数据·数据库·分布式·nosql
zncxCOS10 小时前
【ETestDEV5教程30】ICD操作之信号组操作
python·测试工具·测试用例·集成测试
北岛三生11 小时前
MTK平台调试介绍(一)
图像处理·测试工具·测试用例
qq_2975746711 小时前
【Kafka 系列・入门第六篇】Kafka 集群部署(3 节点)+ 负载均衡配置
分布式·kafka·负载均衡
不懂的浪漫12 小时前
mqtt-plus 架构解析(一):分层架构与设计哲学
spring boot·分布式·物联网·mqtt·架构
渔民小镇13 小时前
一次编写到处对接 —— 为 Godot/Unity/React 生成统一交互接口
java·分布式·游戏·unity·godot
愈努力俞幸运13 小时前
docker入门,容器,镜像
java·分布式·docker
珠海西格电力14 小时前
红区光伏与零碳园区:管理系统如何破解分布式光伏并网困局
大数据·人工智能·分布式·物联网·能源