pytest框架 核心知识的系统复习

news2025/3/13 10:07:15

1. pytest 介绍

  • 是什么:Python 最流行的单元测试框架之一,支持复杂的功能测试和插件扩展。

  • 优点

    • 语法简洁(用 assert 替代 self.assertEqual)。

    • 自动发现测试用例。

    • 丰富的插件生态(如失败重试、并发执行、报告生成)。

    • 兼容unittest框架,比自带unittest框架更加简洁高效,在unittest框架迁移到pytest框架时不需要重写代码。

  • 适用场景:单元测试、接口测试、UI 自动化测试。


2. pytest 环境搭建

安装 pytest

bash

复制

pip install pytest

查看pytest是否安装成功

pip show pytest

常用扩展插件

bash

复制

pip install pytest-html         # HTML 报告
pip install pytest-xdist        # 并发执行
pip install pytest-rerunfailures # 失败重试
pip install allure-pytest       # Allure 报告集成

3. pytest 用例规则

  • 文件命名:以 test_ 开头或结尾(如 test_login.py 或 login_test.py)。

  • 函数/类命名

    • 测试函数:以 test_ 开头(如 test_login_success)。

    • 测试类:以 Test 开头(如 TestLogin),且类中不能有 __init__ 方法。

  • 断言:直接使用 assert(如 assert response.status_code == 200)。

  • setup和teardown:模块级,类级,方法级,函数级

        setup_module和teardown_module,在整个测试用例文件中所有方法运行前后,仅运行1次

        setup_class和teardown_class,在一个Class中所有用例前后运行1次

        setup_method和teardown_method,在Class下的每个方法前后运行

        setup_function和teardown_function,在非Class下的每个方法前后运行


4. pytest 用例编写

示例

python

复制

# 测试函数
def test_add():
    assert 1 + 1 == 2

# 测试类
class TestMath:
    def test_multiply(self):
        assert 2 * 3 == 6

5. pytest 用例执行顺序

  • 默认顺序:按文件名和测试函数/方法的 ASCII 码顺序执行。

  • 自定义顺序

    • 使用 pytest-ordering 插件:

      python

      复制

      @pytest.mark.run(order=1)
      def test_login():
          pass

6. pytest 用例重跑

  • 使用插件pytest-rerunfailures

  • 命令行参数

    bash

    复制

    pytest --reruns 3 --reruns-delay 2  # 失败后重试3次,间隔2秒

7. pytest 用例并发

  • 使用插件pytest-xdist

  • 命令行参数

    bash

    复制

    pytest -n 4  # 启动4个进程并发执行

8. pytest 用例跳过

  • 无条件跳过

    python

    复制

    @pytest.mark.skip(reason="功能未实现")
    def test_unimplemented():
        pass
  • 条件跳过

    python

    复制

    @pytest.mark.skipif(sys.platform == "win32", reason="Windows 不支持")
    def test_linux_only():
        pass

9. pytest 用例条件判断

  • 结合 pytest.mark.skipif 或自定义条件逻辑:

    python

    复制

    def test_feature():
        if not has_feature():
            pytest.skip("环境不支持此功能")
        # 正常测试逻辑

10. pytest 数据初始化与清除

fixture(scope='function', params=None, autouse=False, ids=None, name=None)

  • pytest提供的fixture实现unittest中setup和teardown功能,可以在每次case执行前初始化数据,不同点是,fixture可以只在执行特定case之前运行,使用更灵活
  • autouse参数:默认False须手动调用,只有True时才自动执行
  • scope参数: 有四个级别参数

        "function": 在conftest作用域下,每一个test开头的测试方法运行前都会执行一次

        "class": 在conftest作用域下,每一个Test开头的测试类运行前都会执行一次

        "module": 在conftest作用域下,每一个test开头的测试模块运行前都会执行一次

        "session": 在conftest作用域下,这个包运行前只会执行一次

fixture的使用方法:

  • 使用函数名直接调用,但没有返回值

        @pytest.mark.usefixtures('function_name')

  • 需要使用到fixture返回值:

        直接在对应的接口函数里,加入一个形参,参数名就是fixture函数名


11. pytest 用例定制化执行

添加mark标签,可筛选出对应业务模块的部分接口:

  • 对于Pytest,每一个模块,类,方法和用例前都加上mark,那样在pytest运行的时候就可以只运行带有该mark标签的模块,类或用例:
  • 在配置文件pytest.ini里注册标签:
  • 在类名/方法名前打标签:
@pytest.mark.标签名
  • 在类中/方法中打标签:
pytestmark = pytest.mark.标签名

执行时可根据标签名来执行想要的用例,例如,运行所有标记为login的测试:

pytest -m login

其他运行参数:

  • '-m','user_add',
  • '-m','user_add or user_list',
  • '-m','not user_add',
  • '-m', 'not (user_add or user_list)'
  • '-k',匹配用例文件名,非接口名称,可全部匹配,可模糊匹配
  • '-v',节点 --多层化
  • '-s' 详细输出打印 '-q' 简化打印

12. pytest 参数化

  • 核心装饰器@pytest.mark.parametrize

  • 示例

    python

    复制

    @pytest.mark.parametrize("a, b, expected", [
        (1, 2, 3),
        (0, 0, 0),
        (-1, 1, 0),
    ])
    def test_add(a, b, expected):
        assert a + b == expected

13. pytest 插件介绍

  • 常用插件

    • pytest-html:生成 HTML 测试报告。

    • pytest-cov:生成代码覆盖率报告。

    • pytest-mock:集成 Mock 功能。

    • pytest-django:Django 项目测试支持。


14. pytest 插件执行

安装与使用

bash

复制

# 安装插件
pip install pytest-html

# 执行并生成 HTML 报告
pytest --html=report.html

15. pytest 集成 Allure

步骤

  1. 安装 Allure 命令行工具(需 Java 环境):

  • 下载allure.zip

  • 解压allure.zip到一个文件目录中

    把解压路径添加到环境变量Path中

    pip isntall pytest-allure

    验证安装完成

方法一

                执行pytest单元测试,生成Allure报告需要的数据存在的目录
                pytest -sq --alluredir = ../report/tmp

                执行命令生成测试报告
                allure generate ../report/tmp -o ../report/report --clean

方法二

  1. 生成 Allure 结果数据:

    bash

    复制

    pytest --alluredir=./allure-results
  2. 生成可视化报告:

    bash

    复制

    allure serve ./allure-results  # 本地查看
    allure generate ./allure-results -o ./report --clean  # 生成静态报告

16. pytest 生成测试报告

多种报告形式

  • Python主流自动化测试报告插件:HTMLTestRunner,BeautifulReport,Allure
  • Allure是一款轻量级开源自动化测试报告生成框架,支持绝大部分测试框架,包括TestNG,Junit,pytest,unittest等
  • pytest框架结合Allure可生成格式统一,美观的测试报告
  1. 简单文本报告

    bash

    复制

    pytest -v  # 输出详细结果
  2. HTML 报告

    bash

    复制

    pytest --html=report.html
  3. Allure 报告(需集成):

    bash

    复制

    pytest --alluredir=./results && allure serve ./results

总结

  • 核心优势:简洁语法 + 插件生态 + 高度可定制化。

  • 最佳实践

    • 使用参数化减少重复代码。

    • 结合 CI/CD(如 Jenkins、GitHub Actions)自动化测试。

    • 通过 Allure 或 HTML 报告直观分析结果。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2311515.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

【人工智能】实现【DeepSeek】使用【Anything LLM】并使用本地知识库回答!本地部署告别服务器崩溃的烦恼!

本地知识库回答不准确(Anything LLM + Ollama ) 很多动手能力强的人根据网上的教程,部署了自己的本地知识库。但是发现知识库回答的不准确,甚至答非所问。 先看部署知识库的对比效果,本地大模型为deepseek1.5b 配置为 Anything LLM + Ollama,知识库内容为两篇手机公司文…

RV1126+FFMPEG多路码流监控项目

一.项目介绍: 本项目采用的是易百纳RV1126开发板和CMOS摄像头,使用的推流框架是FFMPEG开源项目。这个项目的工作流程如下(如上图):通过采集摄像头的VI模块,再通过硬件编码VENC模块进行H264/H265的编码压缩,并把压缩后的…

人工智能之数学基础:对线性代数中逆矩阵的思考?

本文重点 逆矩阵是线性代数中的一个重要概念,它在线性方程组、矩阵方程、动态系统、密码学、经济学和金融学以及计算机图形学等领域都有广泛的应用。通过了解逆矩阵的定义、性质、计算方法和应用,我们可以更好地理解和应用线性代数知识,解决各种实际问题。 关于逆矩阵的思…

计算机网络(1) 网络通信基础,协议介绍,通信框架

网络结构模式 C/S-----客户端和服务器 B/S -----浏览器服务器 MAC地址 每一个网卡都拥有独一无二的48位串行号,也即MAC地址,也叫做物理地址、硬件地址或者是局域网地址 MAC地址表示为12个16进制数 如00-16-EA-AE-3C-40 (每一个数可以用四个…

【音视频】ffplay常用命令

一、 ffplay常用命令 -x width:强制显示宽度-y height:强制显示高度 强制以 640*360的宽高显示 ffplay 2.mp4 -x 640 -y 360 效果如下 -fs 全屏显示 ffplay -fs 2.mp4效果如下: -an 禁用音频(不播放声音)-vn 禁…

使用 AIStor、MLflow 和 KServe 将模型部署到 Kubernetes

在之前几篇关于 MLOps 工具的文章中,我展示了有多少流行的 MLOps 工具跟踪与模型训练实验相关的指标。我还展示了他们如何使用 MinIO 来存储作为模型训练管道一部分的非结构化数据。但是,一个好的 MLOps 工具应该做的不仅仅是管理您的实验、数据集和模型…

NO.26十六届蓝桥杯备战|字符数组七道练习|islower|isupper|tolower|toupper|strstr(C++)

P5733 【深基6.例1】自动修正 - 洛谷 小写字母 - 32 大写字母 大写字母 32 小写字母 #include <bits/stdc.h> using namespace std;const int N 110; char a[N] { 0 };int main() {ios::sync_with_stdio(false);cin.tie(nullptr);cin >> a;int i 0;while (a…

数据安全VS创作自由:ChatGPT与国产AI工具隐私管理对比——论文党程序员必看的避坑指南

文章目录 数据安全VS创作自由&#xff1a;ChatGPT与国产AI工具隐私管理对比——论文党程序员必看的避坑指南ChatGPTKimi腾讯元宝DeepSeek 数据安全VS创作自由&#xff1a;ChatGPT与国产AI工具隐私管理对比——论文党程序员必看的避坑指南 产品隐私设置操作路径隐私协议ChatGPT…

乐鑫打造全球首款 PSA Certified Level 2 RISC-V 芯片

乐鑫科技 (688018.SH) 荣幸宣布 ESP32-C6 于 2025 年 2 月 20 日获得 PSA Certified Level 2 认证。这一重要突破使 ESP32-C6 成为全球首款基于 RISC-V 架构获此认证的芯片&#xff0c;体现了乐鑫致力于为全球客户提供安全可靠、性能卓越的物联网解决方案的坚定承诺。 PSA 安全…

Flink深入浅出之03:状态、窗口、checkpoint、两阶段提交

Flink是一个有状态的流&#xff0c;&#x1f445;一起深入了解这个有状态的流 3️⃣ 目标 掌握State知识掌握Flink三种State Backend掌握Flink checkpoint和savepoint原理了解Flink的重启策略checkpointtwo phase commit保证E-O语义 4️⃣ 要点 &#x1f4d6; 1. Flink的St…

DeepSeek 助力 Vue3 开发:打造丝滑的表格(Table)示例3: 行选择

前言&#xff1a;哈喽&#xff0c;大家好&#xff0c;今天给大家分享一篇文章&#xff01;并提供具体代码帮助大家深入理解&#xff0c;彻底掌握&#xff01;创作不易&#xff0c;如果能帮助到大家或者给大家一些灵感和启发&#xff0c;欢迎收藏关注哦 &#x1f495; 目录 Deep…

Django下防御Race Condition

目录 漏洞原因 环境搭建 复现 A.无锁无事务时的竞争攻击 B.无锁有事务时的竞争攻击 防御 A.悲观锁加事务防御 B.乐观锁加事务防御 总结 漏洞原因 Race Condition 发生在多个执行实体&#xff08;如线程、进程&#xff09;同时访问共享资源时&#xff0c;由于执行顺序…

失踪人口回归,最近接了一个私活,提升了很多。

上图是本项目用到的所有技术栈 这个项目分为四端(前端) App(只做安卓不上架) 技术栈ReactNative TS Socket.io scss桌面端(只做Win) 技术栈 Electron TS Vue3 Socket.ioweb端技术栈 Vue3 TS ElementPlus Day.js Unocss Vite Axios Pinia Md5 Echarts less小程序技术栈 Uniapp…

HarmonyOS 应用程序包结构 (编译态)

不同类型的Module编译后会生成对应的HAP、HAR、HSP等文件&#xff0c;开发态视图与编译态视图的对照关系如下&#xff1a; 从开发态到编译态&#xff0c;Module中的文件会发生如下变更&#xff1a; ets目录&#xff1a;ArkTS源码编译生成.abc文件。resources目录&#xff1a;A…

原生iOS集成react-native (react-native 0.65+)

由于官方文档比较老&#xff0c;很多配置都不能用&#xff0c;集成的时候遇到很多坑&#xff0c;简单的整理一下 时间节点:2021年9月1日 本文主要提供一些配置信息以及错误信息解决方案&#xff0c;具体步骤可以参照官方文档 原版文档&#xff1a;https://reactnative.dev/docs…

Doris vs ClickHouse 企业级实时分析引擎怎么选?

Apache Doris 与 ClickHouse 同作为OLAP领域的佼佼者&#xff0c;在企业级实时分析引擎该如何选择呢。本文将详细介绍 Doris 的优势&#xff0c;并通过直观对比展示两者的关键差异&#xff0c;同时分享一个企业成功用 Doris 替换 ClickHouse 的实践案例&#xff0c;帮助您做出明…

【Multipath】使用(FC)访问远程存储设备

文章目录 一、硬件与环境准备二、扫描设备1.宽幅扫描2.窄幅扫描&#xff1a;根据HCTL去扫3.查看远程端口&#xff08;第一次扫描后会出现&#xff09;4.查看FC远程存储设备软链接&#xff08;块设备&#xff09;5.根据HCTL查看FC块设备6.根据块设备wwn查找多路径设备 一、硬件与…

豆包大模型 MarsCode AI 刷题专栏 001

001.找单独的数 难度&#xff1a;易 问题描述 在一个班级中&#xff0c;每位同学都拿到了一张卡片&#xff0c;上面有一个整数。有趣的是&#xff0c;除了一个数字之外&#xff0c;所有的数字都恰好出现了两次。现在需要你帮助班长小C快速找到那个拿了独特数字卡片的同学手上…

用Ruby的Faraday库来进行网络请求抓取数据

在 Ruby 中&#xff0c;Faraday 是一个非常强大的 HTTP 客户端库&#xff0c;它可以用于发送 HTTP 请求并处理响应。你可以使用 Faraday 来抓取网页数据&#xff0c;处理 API 请求等任务。下面我将向你展示如何使用 Faraday 库进行网络请求&#xff0c;抓取数据并处理响应。 1.…

计算机视觉深度学习入门(2)

卷积运算 Dense层与卷积层的根本区别在于&#xff0c;Dense层从输入特征空间中学到的是全局模式&#xff08;比如对于MNIST数字&#xff0c;全局模式就是涉及所有像素的模式&#xff09;​&#xff0c;而卷积层学到的是局部模式&#xff08;对于图像来说**&#xff0c;局部模式…