pytest中的assert断言

pytest 中,虽然底层仍使用 Python 原生的 assert 语句,但框架通过重写断言机制提供了"两种"不同层次的断言体验,通常被概括为:

1. 普通断言(Plain assert)

直接写 Python 原生的 assert <表达式>,pytest 会在失败时自动重写断言信息,给出详细的左值、右值、中间变量等上下文。

示例:

python 复制代码
def test_plain():
    a = 1
    b = 2
    assert a + b == 4          # 失败时 pytest 会打印出 3 != 4

2. 辅助断言(Assertion helpers)

利用 pytest 自带的辅助函数(或第三方插件如 pytest-check)把多个断言打包、延迟报告,或提供领域专用的比较语义。

常见内置辅助:

  • pytest.raises(ExpectedException) ------ 断言代码块抛指定异常
  • pytest.warns(UserWarning) ------ 断言代码块发出指定警告
  • pytest.approx(value, rel=1e-6, abs=1e-12) ------ 浮点近似比较
    示例:
python 复制代码
import pytest

def test_helpers():
    with pytest.raises(ZeroDivisionError):
        1 / 0

    assert 3.1415 == pytest.approx(3.14, rel=1e-2)

总结:

"两种断言方式"并不是语法上两种关键字,而是指

a) 直接用 assert + pytest 的自动重写;

b) 借助 pytest 提供的上下文管理器/辅助函数来完成更复杂的断言需求。

assert断言失败

在 pytest 里写 assert 时,一旦条件为 False,pytest 会立即:

​ (1)抛出 AssertionError(测试因此失败)。

​ (2)把失败的断言语句做"重写",在终端里给出非常详细的上下文,例如

复制代码
assert a + b == 4

失败时会看到

复制代码
>       assert a + b == 4
E       assert 3 == 4
E        +  where 3 = 1 + 2

变量值、中间表达式、列表/字典 diff 都会列出来。

​ (1)该测试函数终止 ,后续代码不再执行;pytest 把它标记为 FAILED (一个 F)。

​ (2)继续跑其余测试,最终报告里会统计失败条数,并给出失败用例的 traceback、stdout、stderr 等。

总结:assert 失败 → 测试当场失败,pytest 打印详细诊断,函数中断,但整个会话继续。

相关推荐
MOMO陌染34 分钟前
Python 饼图入门:3 行代码展示数据占比
后端·python
vvoennvv1 小时前
【Python TensorFlow】 TCN-GRU时间序列卷积门控循环神经网络时序预测算法(附代码)
python·rnn·神经网络·机器学习·gru·tensorflow·tcn
自学互联网2 小时前
使用Python构建钢铁行业生产监控系统:从理论到实践
开发语言·python
无心水2 小时前
【Python实战进阶】7、Python条件与循环实战详解:从基础语法到高级技巧
android·java·python·python列表推导式·python条件语句·python循环语句·python实战案例
xwill*2 小时前
RDT-1B: A DIFFUSION FOUNDATION MODEL FOR BIMANUAL MANIPULATION
人工智能·pytorch·python·深度学习
陈奕昆2 小时前
n8n实战营Day2课时2:Loop+Merge节点进阶·Excel批量校验实操
人工智能·python·excel·n8n
Mr_Xuhhh2 小时前
pytest -- ⽇志与测试报告
pytest
程序猿追2 小时前
PyTorch算子模板库技术解读:无缝衔接PyTorch模型与Ascend硬件的桥梁
人工智能·pytorch·python·深度学习·机器学习
秋邱3 小时前
高等教育 AI 智能体的 “导学诊践” 闭环
开发语言·网络·数据库·人工智能·python·docker
组合缺一3 小时前
Solon AI 开发学习6 - chat - 两种 http 流式输入输出
python·学习·http