news 2026/4/23 16:11:40

【Pytest】结构介绍

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
【Pytest】结构介绍

目录结构介绍

  1. project_root/

  2. ├── tests/ # 测试用例存放目录

  3. │ ├── __init__.py

  4. │ ├── test_module1.py

  5. ├── module1.py # 被测试的模块

  6. ├── conftest.py # pytest配置文件,可定义fixture和钩子函数

  7. ├── pytest.ini # pytest全局配置文件

  8. └── run.py # 运行测试的脚本

pytest.ini

pytest.ini 是 pytest 测试框架的配置文件,它允许你对 pytest 的行为进行全局或项目级别的定制。

作用:

  • 全局配置:借助 pytest.ini 文件,你可以为整个项目设定通用的配置选项,从而避免在每次运行 pytest 时都要在命令行输入相同的参数。

  • 提高可维护性:把配置信息集中存放在一个文件里,能让项目的配置更加清晰,便于维护和管理。

  • 定制测试行为:可以自定义测试发现规则、指定插件、设置日志级别等,以满足不同项目的特定需求。

addopts

此配置项用于添加额外的命令行选项,这些选项会在每次运行 pytest 时自动生效。

  1. [pytest]

  2. addopts = -v -s

-v:表示以详细模式运行测试,会输出更多的测试信息。
-s:表示捕获标准输出,允许测试用例中的 print 语句正常输出。

testpaths

该配置项用于指定 pytest 搜索测试文件的路径。

  1. [pytest]

  2. testpaths = tests

这意味着 pytest 只会在 tests 目录及其子目录下查找测试文件。

norecursedirs

此配置项用于指定 pytest 不进行递归搜索的目录。

  1. [pytest]

  2. norecursedirs = .git venv

这表明 pytest 不会在 .git 和 venv 目录及其子目录下查找测试文件。

conftest.py

conftest.py 是 pytest 里一个非常重要的文件,它能对 pytest 的测试行为进行灵活配置与扩展。

共享 Fixture 函数

Fixture 是 pytest 里用于提供测试数据、初始化测试环境等的可复用函数。在 conftest.py 里定义的 Fixture 函数能够被同目录及其子目录下的所有测试文件使用,无需在每个测试文件中重复定义。

Fixture 函数可以有参数,并且可以设置作用域(如 function、class、module、session)​​​​​​​

  1. # conftest.py

  2. import pytest

  3. @pytest.fixture(scope="module")

  4. def db_connection():

  5. # 模拟数据库连接

  6. print("建立数据库连接")

  7. yield # 在此处执行测试用例

  8. print("关闭数据库连接")

自定义钩子函数

钩子函数是 pytest 提供的一些特殊函数,能在测试执行的不同阶段插入自定义逻辑。在 conftest.py 里定义钩子函数可对 pytest 的默认行为进行修改。​​​​​​​

  1. # conftest.py

  2. import pytest

  3. def pytest_sessionstart(session):

  4. """在测试会话开始时执行"""

  5. print("测试会话开始")

  6. def pytest_sessionfinish(session, exitstatus):

  7. """在测试会话结束时执行"""

  8. print("测试会话结束")

也可以 在这里,全局配置和初始化

可在 conftest.py 中进行一些全局配置和初始化操作,例如设置日志、加载配置文件等,让所有测试文件都能使用这些配置。

注意事项

  • conftest.py 文件不需要手动导入,pytest 会自动发现并加载它。

  • 不同目录下的 conftest.py 文件有不同的作用范围,子目录下的 conftest.py 文件会覆盖父目录中同名的配置。

  • 合理使用 Fixture 的作用域,避免不必要的资源浪费。

run.py

1、统一测试入口

在大型项目里,测试用例可能分布在多个不同的目录和文件中。借助 run.py 文件,你可以把所有测试的启动逻辑集中起来,让测试的执行更加统一和便捷。开发人员或测试人员只需运行这个文件,就能启动整个项目的测试流程。

2、定制测试运行参数

run.py 文件允许你根据不同的需求定制 pytest 的运行参数,例如指定测试文件、设置测试报告路径、控制测试的详细程度等。​​​​​​​

  1. import pytest

  2. if __name__ == "__main__":

  3. # 只运行 tests 目录下的测试用例,并生成 HTML 报告

  4. pytest.main(['-v', '-s', '--html=report.html', 'tests'])

在上述代码中:

  • -v 表示以详细模式运行测试,会输出更多的测试信息。

  • -s 表示捕获标准输出,允许测试用例中的 print 语句正常输出。

  • –html=report.html 表示生成一个名为 report.html 的 HTML 测试报告。

  • tests 表示只运行 tests 目录下的测试用例。

执行测试前的预处理操作

在 run.py 文件中,你可以添加一些测试前的预处理操作,比如初始化测试环境、加载配置文件、启动服务等。类似于conftest.py作用

执行测试后的清理操作

同样,你也可以在 run.py 文件中添加测试后的清理操作,如关闭服务、删除临时文件等,确保测试环境恢复到初始状态。

感谢每一个认真阅读我文章的人,礼尚往来总是要有的,虽然不是什么很值钱的东西,如果你用得到的话可以直接拿走:

这些资料,对于【软件测试】的朋友来说应该是最全面最完整的备战仓库,这个仓库也陪伴上万个测试工程师们走过最艰难的路程,希望也能帮助到你!有需要的小伙伴可以点击下方小卡片领取

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/23 16:05:57

探索国产 224XP IE 带网络方案:功能升级与技术亮点

国产224XP IE带网络方案,在224XP功能基础上增加了网功能,多级运放设计,模拟量稳定不跳动,全兼容版本。最近在研究自动化控制相关技术时,发现了一款很有意思的产品——国产 224XP IE 带网络方案。这玩意儿可不简单&…

作者头像 李华
网站建设 2026/4/23 3:30:18

量子开发崛起:软件工程师必学的3个入门技能

量子时代的测试新挑战 量子计算正从实验室走向产业化,IBM和Google等公司已实现超千量子比特系统,为软件开发奠定硬件基础。对软件测试从业者而言,量子软件的特性(如叠加态和纠缠)带来了前所未有的测试难题&#xff1a…

作者头像 李华
网站建设 2026/4/23 12:46:55

昇腾芯片模型性能优化深度指南

一、昇腾芯片架构特性理解 1.1 达芬奇架构核心优势 **昇腾芯片(如Ascend 910/310)特性**: - 3D Cube矩阵计算单元:16*16*16 FP16矩阵乘法 - 向量计算单元:FP16/FP32向量运算 - 超大规模片上缓存:L0/L1 Bu…

作者头像 李华
网站建设 2026/4/20 10:15:03

类似谷歌搜索文献:高效文献检索与获取方案探讨

做科研的第一道坎,往往不是做实验,也不是写论文,而是——找文献。 很多新手科研小白会陷入一个怪圈:在知网、Google Scholar 上不断换关键词,结果要么信息过载,要么完全抓不到重点。今天分享几个长期使用的…

作者头像 李华
网站建设 2026/4/23 12:54:46

查询域名信息前,先搞清楚这几个核心数据

在进行域名交易、投资或代购之前,很多人都会先查询域名信息。但现实中,不少人查是查了,却不知道哪些数据才是真正有价值的,结果依然判断失误。其实,域名信息查询并不是看得越多越好,而是要抓住几个核心数据…

作者头像 李华
网站建设 2026/4/22 15:54:09

AI诗歌创作能力深度测评报告

在自动化测试、单元覆盖、边界值分析与缺陷预测模型横行的今天,我们习惯于用可量化、可复现、可断言的逻辑去衡量系统行为。但当一个AI生成了一首诗,而我们却无法用“通过/失败”来判定它是否“原创”时——我们是否正站在软件测试哲学的悬崖边&#xff…

作者头像 李华