【pytest官方文档】解读fixtures - 5. fixtures的autouse

现在我们已经知道了,fixtures是一个非常强大的功能。

那么有的时候,我们可能会写一个fixture,而这个fixture所有的测试函数都会用到它。那这个时候,就可以用
autouse自动让所有的测试函数都请求它,不需要在每个测试函数里显示的请求一遍。

具体用法就是,将autouse=True传递给fixture的装饰器即可。

import pytest


@pytest.fixture
def first_entry():
    return "a"


@pytest.fixture
def order(first_entry):
    return []


@pytest.fixture(autouse=True)
def append_first(order, first_entry):
    return order.append(first_entry)


def test_string_only(order, first_entry):
    assert order == [first_entry]


def test_string_and_int(order, first_entry):
    order.append(2)
    assert order == [first_entry, 2]

先来看第一个测试函数test_string_only(order, first_entry)的执行情况:

  1. 虽然在测试函数里请求了2个fixture函数,但是order拿到的并不是[]first_entry拿到的也并不是"a"
  2. 因为存在了一个autouse=True的fixture函数,所以append_first先会被调用执行。
  3. 在执行append_first过程中,又分别请求了order、 first_entry这2和fixture函数。
  4. 接着,append_first对分别拿到的[]"a"进行append处理,最终返回了["a"]
    所以,断言assert order == [first_entry]是成功的。

同理,第二个测试函数test_string_and_int(order, first_entry)的执行过程亦是如此。

posted @   把苹果咬哭的测试笔记  阅读(182)  评论(0编辑  收藏  举报
编辑推荐:
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
阅读排行:
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
· 园子的第一款AI主题卫衣上架——"HELLO! HOW CAN I ASSIST YOU TODAY
点击右上角即可分享
微信分享提示