Pytest 是什么

news2025/5/31 15:21:41

Pytest 是 Python 生态中最流行的 测试框架,用于编写、运行和组织单元测试、功能测试甚至复杂的集成测试。它以简洁的语法、强大的插件系统和高度可扩展性著称,广泛应用于 Python 项目的自动化测试中。以下是其核心特性和使用详解:


Pytest 的核心特点

  1. 极简语法

    • 无需继承类,使用普通函数和 assert 语句即可编写测试。
    • 示例:
      def test_add():
          assert 1 + 1 == 2  # 直接使用 assert,无需复杂断言方法
      
  2. 自动发现测试

    • 自动识别以 test_ 开头的函数或 Test 开头的类中的测试方法。
  3. 丰富的断言

    • 直接使用 Python 原生 assert,失败时输出详细上下文(如变量值)。
    • 对比 JUnit 的 assertEquals(expected, actual),Pytest 更直观:
      assert user.name == "Alice"  # 失败时会显示 user.name 的实际值
      
  4. Fixture 机制

    • 通过 @pytest.fixture 定义测试依赖(如数据库连接、临时文件),实现复用和依赖注入。
      @pytest.fixture
      def database():
          conn = create_db_connection()
          yield conn  # 测试结束后自动清理
          conn.close()
      
      def test_query(database):  # 自动注入 fixture
          result = database.execute("SELECT 1")
          assert result == 1
      
  5. 参数化测试

    • @pytest.mark.parametrize 轻松测试多组输入。
      @pytest.mark.parametrize("a, b, expected", [(1, 2, 3), (0, 0, 0)])
      def test_add(a, b, expected):
          assert a + b == expected
      
  6. 插件生态

    • 支持 1000+ 插件扩展功能,例如:
      • pytest-cov:生成代码覆盖率报告。
      • pytest-xdist:并行运行测试。
      • pytest-mock:集成 Mock 功能。

Pytest 的适用场景

  • 单元测试:验证函数或类的逻辑。
  • API 测试:结合 requests 库测试 HTTP 接口。
  • UI 自动化:与 Selenium 或 Playwright 搭配使用。
  • 数据库测试:通过 Fixture 管理测试数据。

Pytest vs. Unittest(Python 标准库)

特性PytestUnittest
语法简洁(assert冗长(self.assertEqual()
Fixture支持(@pytest.fixture需手动实现 setUp()/tearDown()
参数化原生支持(@parametrize需依赖 subTest 或第三方库
插件生态丰富有限
报告输出彩色输出,详细信息基础格式

快速开始

  1. 安装 Pytest
    pip install pytest
    
  2. 编写测试文件(如 test_sample.py):
    def func(x):
        return x + 1
    
    def test_answer():
        assert func(3) == 4  # 测试通过
        assert func(5) == 6  # 测试通过
    
  3. 运行测试
    pytest test_sample.py  # 运行指定文件
    pytest               # 自动发现并运行所有测试
    
    输出示例
    ================ test session starts =================
    collected 2 items
    test_sample.py ..                                [100%]
    ================ 2 passed in 0.01s ==================
    

高级功能示例

1. Mock 对象测试
from unittest.mock import Mock

def test_mock():
    mock = Mock(return_value=42)
    assert mock() == 42  # 模拟函数调用
2. 跳过测试
@pytest.mark.skip(reason="尚未实现")
def test_skip():
    assert False
3. 异常断言
def test_exception():
    with pytest.raises(ValueError):
        int("invalid")  # 预期抛出 ValueError

为什么选择 Pytest?

  • 减少样板代码:更少的代码,更多的测试。
  • 调试友好:失败时自动输出局部变量和调用栈。
  • 社区支持:广泛用于开源项目(如 Django、NumPy)。
  • 与 CI/CD 集成:无缝对接 GitHub Actions、Jenkins。

总结:Pytest 是 Python 测试的“瑞士军刀”,适合从简单单元测试到复杂系统验证的所有场景。若项目已使用 unittest,也可通过 pytest 直接运行旧测试,逐步迁移。

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

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

相关文章

ElasticSearch简介及常用操作指南

一. ElasticSearch简介 ElasticSearch 是一个基于 Lucene 构建的开源、分布式、RESTful 风格的搜索和分析引擎。 1. 核心功能 强大的搜索能力 它能够提供全文检索功能。例如,在海量的文档数据中,可以快速准确地查找到包含特定关键词的文档。这在处理诸如…

纤维组织效应偏斜如何影响您的高速设计

随着比特率继续飙升,光纤编织效应 (FWE) 偏移,也称为玻璃编织偏移 (GWS),正变得越来越成为一个问题。今天的 56GB/s 是高速路由器中最先进的,而 112 GB/s 指日可待。而用于个人计算机…

Rust使用Cargo构建项目

文章目录 你好,Cargo!验证Cargo安装使用Cargo创建项目新建项目配置文件解析默认代码结构 Cargo工作流常用命令速查表详细使用说明1. 编译项目2. 运行程序3.快速检查4. 发布版本构建 Cargo的设计哲学约定优于配置工程化优势 开发建议1. 新项目初始化​2. …

Python训练营打卡Day39

DAY 39 图像数据与显存 知识点回顾 1.图像数据的格式:灰度和彩色数据 2.模型的定义 3.显存占用的4种地方 a.模型参数梯度参数 b.优化器参数 c.数据批量所占显存 d.神经元输出中间状态 4.batchisize和训练的关系 作业:今日代码较少,理解内容…

UE5蓝图中播放背景音乐和使用代码播放声音

UE5蓝图中播放背景音乐 1.创建背景音乐Cube 2.勾选looping 循环播放背景音乐 3.在关卡蓝图中 Event BeginPlay-PlaySound2D Sound选择自己创建的Bgm_Cube 蓝图播放声音方法二: 使用代码播放声音方法一 .h文件中 头文件引用 #include "Kismet/GameplayS…

AI 赋能数据可视化:漏斗图制作的创新攻略

在数据可视化的广阔天地里,漏斗图以其独特的形状和强大的功能,成为展示流程转化、分析数据变化的得力助手。传统绘制漏斗图的方式往往需要耗费大量时间和精力,对使用者的绘图技能和软件操作熟练度要求颇高。但随着技术的蓬勃发展,…

用 Python 模拟下雨效果

用 Python 模拟下雨效果 雨天别有一番浪漫情怀:淅淅沥沥的雨滴、湿润的空气、朦胧的光影……在屏幕上也能感受下雨的美妙。本文将带你用一份简单的 Python 脚本,手把手实现「下雨效果」动画。文章深入浅出,零基础也能快速上手,完…

C#对象集合去重的一种方式

前言 现在AI越来越强大了,有很多问题其实不需要在去各个网站上查了,直接问AI就好了,但是呢,AI给的代码可能能用,也可能需要调整,但是自己肯定是要会的,所以还是总结一下吧。 问题 如果有一个…

在ROS2(humble)+Gazebo+rqt下,实时显示仿真无人机的相机图像

文章目录 前言一、版本检查检查ROS2版本 二、步骤1.下载对应版本的PX4(1)检查PX4版本(2)修改文件名(3)下载正确的PX4版本 2.下载对应版本的Gazebo(1)检查Gazebo版本(2)卸载不正确的Gazebo版本(3)下载正确的Gazebo版本 3.安装bridge包4.启动 总结 前言 在ROS2的环境下&#xff…

github双重认证怎么做

引言 好久没登陆github了, 今天登陆github后,提醒进行2FA认证。 查看了github通知,自 2023 年 3 月起,GitHub 要求所有在 GitHub.com 上贡献代码的用户启用一种或多种形式的双重身份验证 (2FA)。 假如你也遇到这个问题&#xf…

数据的类型——认识你的数据

第02篇:数据的类型——认识你的数据 写在前面:嗨,大家好!我是蓝皮怪。在上一篇文章中,我们聊了统计学的基本概念,今天我们来深入了解一个非常重要的话题——数据的类型。你可能会想:"数据就…

第五十二节:增强现实基础-简单 AR 应用实现

引言 增强现实(Augmented Reality, AR)是一种将虚拟信息叠加到真实世界的技术,广泛应用于游戏、教育、工业维护等领域。与传统虚拟现实(VR)不同,AR强调虚实结合,用户无需完全沉浸到虚拟环境中。本文将通过Python和OpenCV库,从零开始实现一个基础的AR应用:在检测到特定…

LLaMaFactory 微调QwenCoder模型

步骤一:准备LLamaFactory环境 首先,让我们尝试使用github的方式克隆仓库: git config --global http.sslVerify false && git clone --depth 1 https://github.com/hiyouga/LLaMA-Factory.git # 创建新环境,指定 Python 版本(以 3.…

【最新版】Arduino IDE的安装入门Demo

1、背景说明 1、本教程编写日期为2025-5-24 2、Arduino IDE的版本为:Arduino IDE 2.3.6 3、使用的Arduino为Arduino Uno 1、ArduinoIDE的安装 1、下载。网址如下:官网 2、然后一路安装即可。 期间会默认安装相关驱动,默认安装即可。 3、安…

不起火,不爆炸,高速摄像机、数字图像相关DIC技术在动力电池新国标安全性能测试中的应用

2026年7月1日,我国将正式实施GB38031-2025《电动汽车用动力蓄电池安全要求》——这项被称为“史上最严电池安全令”的新国标,首次将“热失控不蔓延、不起火、不爆炸”从企业技术储备上升为强制性要求,标志着电池安全进入“零容忍”时代&#…

thinkadmin中使用layui日期选择器,数据库存储时间戳

form.html <div class="layui-form-item label-required-prev" id="jiezhi_time-div">

WSL中ubuntu通过Windows带代理访问github

WSL中ubuntu通过Windows带代理访问github 前言: WSL是Windows下的ubuntu访问工具&#xff0c;目前无法访问外网&#xff0c;因此需要配置一下。 步骤一 代理中进行如下设置: 步骤二 ubuntu22.04中修改配置 使用如下命令获取IP地址&#xff1a; ip route | grep default | aw…

RISC-V特权模式及切换

1 RISC-V特权模式基本概念 1.1 RISC-V特权模式介绍 RISC-V 指令集架构&#xff08;ISA&#xff09;采用多特权级别设计作为其核心安全机制&#xff0c;通过层次化的权限管理实现系统资源的隔离与保护。该架构明确定义了四个层次化的特权模式&#xff0c;按照权限等级由高至低…

【深度学习】11. Transformer解析: Self-Attention、ELMo、Bert、GPT

Transformer 神经网络 Self-Attention 的提出动机 传统的循环神经网络&#xff08;RNN&#xff09;处理序列信息依赖时间步的先后顺序&#xff0c;无法并行&#xff0c;而且在捕捉长距离依赖关系时存在明显困难。为了解决这些问题&#xff0c;Transformer 引入了 Self-Attent…

4060显卡什么水平 4060显卡参数介绍

NVIDIA的GeForce RTX 40系列显卡基于最新的Ada Lovelace架构&#xff0c;提供了前所未有的图形处理能力和效率。其中&#xff0c;RTX 4060定位中高端市场&#xff0c;针对那些寻求卓越性能同时又注重成本效益的用户群体。那么&#xff0c;4060显卡什么水平呢&#xff1f;本文将…