Pytest用例自定义 - 重复、并行、串行

简介:面对快速迭代和持续交付的需求,提高测试效率变得至关重要。并行测试因其显著的时间节省优势而备受青睐。然而,并非所有测试都适合并行执行。在某些情况下,串行执行是必要的,以确保测试的正确性和稳定性。本文将探讨在自动化测试中部分串行、部分并行执行的必要性和实践方法,帮助测试开发者在提高测试效率的同时,确保测试结果的可靠性和准确性。

历史攻略:

pytest运行结果解析及其改造

pytest+allure安装和使用

pytest:并行和并发运行用例

python:消息推送 - 企业微信机器人推送

让你的pytest日志更有序:配置和使用技巧

Python配置与测试利器:Hydra + pytest的完美结合

Playwright - 04:pytest并行、并发、运行浏览器兼容性测试

安装:

yaml 复制代码
pip install pytest-xdist
pip install pytest-repeat

使用案例:main.py

yaml 复制代码
# -*- coding: utf-8 -*-
# time: 2024/03/24 10:30
# file: main.py
# 公众号: 玩转测试开发
import os
import pytest

if __name__ == "__main__":
    # step-1:use pytest run test_case
    pytest.main(["-s", "test_case", '-n', 'auto', "--alluredir", "./report"])

    # step-2:auto report json data,zip to allure-html
    os.system("allure serve report")

test_case/test_demo.py

yaml 复制代码
# -*- coding: utf-8 -*-
# time: 2024/3/22 0:34
# file: test_demo.py
# 公众号: 玩转测试开发
import time
import unittest


class TestDemo(unittest.TestCase):
    def test_01(self):
        time.sleep(5)
        print('测试用例1执行')

    def test_02(self):
        time.sleep(5)
        print('测试用例2执行')

    def test_03(self):
        time.sleep(5)
        print('测试用例3执行')

test_case/test_parallel.py

yaml 复制代码
# -*- coding: utf-8 -*-
# time: 2024/3/24 12:16
# file: test_parallel.py
# 公众号: 玩转测试开发
import time
import pytest


class TestParallel:
    @pytest.mark.repeat(2)
    def test_parallel_1(self):
        time.sleep(5)
        print("Parallel Test 1")

    @pytest.mark.repeat(3)
    def test_parallel_2(self):
        time.sleep(5)
        print("Parallel Test 2")

    @pytest.mark.repeat(1)
    def test_parallel_3(self):
        time.sleep(5)
        print("Parallel Test 3")

    @pytest.mark.repeat(3)
    def test_parallel_4(self):
        time.sleep(5)
        print("Parallel Test 4")

test_case/test_serial.py

yaml 复制代码
# -*- coding: utf-8 -*-
# time: 2024/3/24 12:16
# file: test_serial.py
# 公众号: 玩转测试开发
import time
import pytest


@pytest.mark.serial
class TestSerial:
    def test_serial_1(self):
        time.sleep(5)
        print("Serial Test 1")

    def test_serial_2(self):
        time.sleep(5)
        print("Serial Test 2")

配置文件:pytest.ini

yaml 复制代码
# pytest.ini
[pytest]
markers =
    serial: mark test to run serially

运行结果:

注意事项:

1、同一文件中混合串行和并行测试,并且需要更精细的控制,可能需要编写更复杂的自定义逻辑或查找是否有现成的插件能满足这种特定的需求。

2、不关心执行顺序,简单地将 -n 参数设置为 auto,让 pytest-xdist 插件自动管理并行执行,通常是最简单也是最有效的方法。

结论:适当拆分错开并行和串行的测试类,通过pytest-xdist auto参数,可以便捷有效的大幅度提升运行测试用例的效率。

相关推荐
BD_Marathon2 小时前
【Flink】部署模式
java·数据库·flink
csudata3 小时前
十年磨一剑,中启乘数CData数据库一体机重新定义企业级数据库解决方案
数据库·数据库开发
TDengine (老段)4 小时前
TDengine IDMP 应用场景:工业锅炉监控
大数据·数据库·物联网·信息可视化·时序数据库·tdengine
dreams_dream6 小时前
Django的Settings 配置文件详解
数据库·django·sqlite
遇见你的雩风7 小时前
【MySQL】CRUD基础详解
数据库·mysql
晓梦.8 小时前
IPSec 安全基础
服务器·网络·安全
夜雨听萧瑟9 小时前
sqlite创建数据库,创建表,插入数据,查询数据的C++ demo
数据库·sqlite
.Shu.10 小时前
Mysql InnoDB 底层架构设计、功能、原理、源码系列合集【四、事务引擎核心 - MVCC与锁机制】
数据库·mysql
多工坊10 小时前
【DataGrip】连接达梦数据库后,能查询数据但是看不到表的几种情况分析,达梦数据库驱动包下载DmJdbcDriver18.jar
java·数据库·jar
小李独爱秋10 小时前
UNIX发展历史与核心技术解析
服务器·操作系统·unix