0

0

Python pytest fixture 的生命周期

冷炫風刃

冷炫風刃

发布时间:2026-01-17 23:13:02

|

493人浏览过

|

来源于php中文网

原创

pytest fixture 的生命周期由作用域(scope)决定,包括 function、class、module、package、session 五种,scope 越大复用越广但资源占用越久;setup 在函数体或 yield 前执行,teardown 在 yield 后或 addfinalizer 注册的回调中执行;高 scope fixture 可被低 scope 测试使用,但反之不行;需避免状态污染与资源泄漏。

python pytest fixture 的生命周期

pytest fixture 的生命周期取决于它的 作用域(scope),它决定了 fixture 实例被创建、复用和销毁的时机。理解 scope 是控制资源初始化、共享和清理的关键。

scope 决定 fixture 的存在周期

fixture 的 scope 有五种:function(默认)、class、module、package、session。scope 越大,fixture 复用范围越广,但生命周期越长,资源占用时间也越久。

  • function:每个测试函数执行前创建,结束后立即销毁。适合轻量、隔离性强的资源,如临时文件、mock 对象。
  • class:同一个测试类中的所有测试函数共享一个实例。类开始前 setup,类结束后 teardown。
  • module:同一 Python 模块(.py 文件)内所有测试共享。模块导入后首次需要时创建,模块运行完毕后销毁。
  • package:整个包(含子模块)内所有测试共享。包内第一个测试需要时创建,整个包运行完后销毁。
  • session:整个 pytest 会话(即一次 pytest 命令执行)中只创建一次。常用于数据库连接、启动 Web 服务等开销大的全局资源。

setup 和 teardown 的执行时机

fixture 函数体本身是 setup 阶段;若使用 yield,yield 后的代码就是 teardown 阶段;若用 addfinalizer,注册的回调会在对应 scope 结束时执行。

Android四种Activity的加载模式 WORD版
Android四种Activity的加载模式 WORD版

本文档主要讲述的是Android四种Activity的加载模式;每个Activity的状态是由它在Activity栈(是一个后进先出LIFO,包含所有正在运行Activity的队列)中的位置决定的。Activty的生命周期的也就是它所在进程的生命周期。希望本文档会给有需要的朋友带来帮助;感兴趣的朋友可以过来看看

下载
  • yield 方式更直观:yield 前为 setup,yield 后为 teardown,且保证执行(即使测试异常也会运行 teardown)。
  • addfinalizer 更灵活:可多次调用,适合动态注册多个清理动作,但需确保在 fixture 函数返回前注册完成。
  • teardown 总是在对应 scope 的生命周期结束时触发,不是按测试函数顺序,而是按 scope 层级自然结束。

跨 scope 依赖时的生命周期规则

高 scope 的 fixture 可被低 scope 的测试使用,但反过来不行。pytest 会自动按需创建并缓存高 scope fixture,并在整个其作用域内复用。

立即学习Python免费学习笔记(深入)”;

  • 例如 module 级 fixture 被 function 级测试使用:该 fixture 在模块首次被访问时创建,之后所有同模块测试都复用它。
  • 若 function 级测试同时依赖 session 和 function 级 fixture,session 级只初始化一次,function 级每次新建 —— 它们互不干扰。
  • 注意:如果低 scope fixture 依赖高 scope fixture,pytest 仍按各自 scope 管理生命周期,不会提前销毁高 scope 实例。

常见误用与注意事项

生命周期管理不当容易引发状态污染、资源泄漏或并发问题(尤其在 pytest-xdist 并行运行时)。

  • 避免在 function 级 fixture 中缓存可变对象(如 list、dict)并直接返回,否则多个测试可能意外共享修改。
  • session 级 fixture 不要返回带内部状态的单例对象(如未重置的计数器),除非你明确控制其线程/进程安全性。
  • 使用 --setup-show 查看 fixture setup/teardown 的实际执行顺序,调试生命周期问题很有效。
  • 在 conftest.py 中定义高 scope fixture 时,注意其生效范围 —— session 级 fixture 放在项目根目录 conftest.py 才能覆盖全部测试。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
session失效的原因
session失效的原因

session失效的原因有会话超时、会话数量限制、会话完整性检查、服务器重启、浏览器或设备问题等等。详细介绍:1、会话超时:服务器为Session设置了一个默认的超时时间,当用户在一段时间内没有与服务器交互时,Session将自动失效;2、会话数量限制:服务器为每个用户的Session数量设置了一个限制,当用户创建的Session数量超过这个限制时,最新的会覆盖最早的等等。

334

2023.10.17

session失效解决方法
session失效解决方法

session失效通常是由于 session 的生存时间过期或者服务器关闭导致的。其解决办法:1、延长session的生存时间;2、使用持久化存储;3、使用cookie;4、异步更新session;5、使用会话管理中间件。

776

2023.10.18

cookie与session的区别
cookie与session的区别

本专题整合了cookie与session的区别和使用方法等相关内容,阅读专题下面的文章了解更详细的内容。

97

2025.08.19

class在c语言中的意思
class在c语言中的意思

在C语言中,"class" 是一个关键字,用于定义一个类。想了解更多class的相关内容,可以阅读本专题下面的文章。

870

2024.01.03

python中class的含义
python中class的含义

本专题整合了python中class的相关内容,阅读专题下面的文章了解更多详细内容。

30

2025.12.06

线程和进程的区别
线程和进程的区别

线程和进程的区别:线程是进程的一部分,用于实现并发和并行操作,而线程共享进程的资源,通信更方便快捷,切换开销较小。本专题为大家提供线程和进程区别相关的各种文章、以及下载和课程。

765

2023.08.10

function是什么
function是什么

function是函数的意思,是一段具有特定功能的可重复使用的代码块,是程序的基本组成单元之一,可以接受输入参数,执行特定的操作,并返回结果。本专题为大家提供function是什么的相关的文章、下载、课程内容,供大家免费下载体验。

499

2023.08.04

js函数function用法
js函数function用法

js函数function用法有:1、声明函数;2、调用函数;3、函数参数;4、函数返回值;5、匿名函数;6、函数作为参数;7、函数作用域;8、递归函数。本专题提供js函数function用法的相关文章内容,大家可以免费阅读。

166

2023.10.07

C# ASP.NET Core微服务架构与API网关实践
C# ASP.NET Core微服务架构与API网关实践

本专题围绕 C# 在现代后端架构中的微服务实践展开,系统讲解基于 ASP.NET Core 构建可扩展服务体系的核心方法。内容涵盖服务拆分策略、RESTful API 设计、服务间通信、API 网关统一入口管理以及服务治理机制。通过真实项目案例,帮助开发者掌握构建高可用微服务系统的关键技术,提高系统的可扩展性与维护效率。

3

2026.03.11

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
最新Python教程 从入门到精通
最新Python教程 从入门到精通

共4课时 | 22.5万人学习

Django 教程
Django 教程

共28课时 | 4.9万人学习

SciPy 教程
SciPy 教程

共10课时 | 1.9万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号