当前位置: 首页 > article >正文

Pytest --capture 参数详解:如何控制测试执行过程中的输出行为

--capture 选项用于控制测试用例执行过程中标准输出(stdout)和标准错误输出(stderr)的捕获行为。


--capture 的选项值:
fd(默认)
捕获文件描述符级别的输出(stdout 和 stderr)。
使用此模式,所有的标准输出和标准错误都会被捕获,即使它们来自 C 扩展模块。
sys
捕获 Python 层级的 sys.stdout 和 sys.stderr。
no
不捕获输出,标准输出和错误直接显示在终端中。
tee-sys
将 sys.stdout 和 sys.stderr 的输出同时捕获并输出到终端(类似于实时查看日志的效果)。此选项在调试时非常有用。
使用方式:
可以在运行 pytest 时通过命令行指定:

pytest --capture=fd          # 默认行为
pytest --capture=sys         # 仅捕获 Python 层级输出
pytest --capture=no          # 不捕获输出,实时打印
pytest --capture=tee-sys     # 同时捕获并输出到终端

示例:
假设有一个测试文件 test_example.py:

import sys

def test_print():
    print("This is a test for stdout.")
    sys.stderr.write("This is a test for stderr.\n")
    assert True

1. 默认模式 (fd):
运行命令:

pytest --capture=fd

输出:标准输出和错误不会直接显示在终端中,而是只在失败时打印或保存在日志中。
2. 不捕获模式 (no):
运行命令:

pytest --capture=no

输出:标准输出和标准错误会实时显示在终端中。
3. tee-sys 模式:
运行命令: 

pytest --capture=tee-sys

输出:标准输出和标准错误会实时显示在终端中,同时也会被捕获。


配置到 pytest.ini:
如果想始终使用某种捕获行为,可以将其添加到 pytest.ini 文件:

[pytest]
addopts = --capture=tee-sys

以下是我本地在执行过程中指定tee-sys时终端的输出:

---Captured log call--- 下面是网络请求的日志和执行的日志,即使用logging记录的日志。 

总结:
--capture 是一个灵活的选项,用于控制标准输出和错误的捕获方式。
在调试时,--capture=no 或 --capture=tee-sys 通常更方便,能实时看到日志输出。


http://www.kler.cn/a/420762.html

相关文章:

  • C++:特殊类设计及类型转换
  • 浏览器渲染原理
  • 【网络】协议与网络传输
  • UICollectionView在xcode16编译闪退问题
  • 5.1 MySQL 锁机制
  • conda手动初始化
  • 【ONE·基础算法 || 动态规划(三)】
  • 基于Java Springboot成人教育APP且微信小程序
  • Web实时通信@microsoft/signalr
  • C语言第十四周课——课堂练习
  • pip更换国内源,加速Python包下载(附2024年12月最新国内镜像源列表)
  • Unity3D 设置图片拉伸四角不变形
  • PhPMyadmin-漏洞复现
  • 工业公辅车间数智化节能头部企业,蘑菇物联选择 TDengine 升级 AI 云智控
  • [在线实验]-RabbitMQ镜像的下载与部署
  • android 阻止返回退出
  • 【笔记总结】华为云:应用上云后的安全规划及设计
  • form表单阻止默认事件及获取值
  • PH热榜 | 2024-12-02
  • Milvus Cloud 2.5:向量数据库的新里程碑与全文检索的革新
  • 大数据治理:解锁数据价值,引领未来创新
  • windows C#-测试引用相等性
  • 人机交互中的状态交互、趋势交互
  • vue 3中使用复制功能
  • C++【PCL】利用矩阵对点云进行刚体变换
  • golang的wails框架在macos下的问题