pytest日志显示
在 pytest 中,可以通过 钩子函数 和 配置文件 pytest.ini 配置日志的显示方式,实现对日志的灵活控制。以下是常用实现方式及配置说明。
方式一:使用 conftest.py 钩子函数自定义日志显示
通过 conftest.py 文件中的钩子函数,实现日志记录并自定义显示。
实现步骤
import pytest
import logging# 配置日志格式和输出
def pytest_configure(config):log_format = "%(asctime)s - %(levelname)s - %(message)s"logging.basicConfig(level=logging.INFO, # 设置日志级别format=log_format,filename="test.log", # 日志文件保存路径filemode="w" # 每次运行时重写日志文件)console = logging.StreamHandler() # 控制台输出console.setLevel(logging.INFO) # 控制台日志级别console.setFormatter(logging.Formatter(log_format))logging.getLogger("").addHandler(console)logging.info("Logging setup complete.")# 钩子函数:记录每个测试的开始和结束
@pytest.hookimpl(tryfirst=True, hookwrapper=True)
def pytest_runtest_protocol(item, nextitem):logging.info(f"Test started: {item.name}")outcome = yieldresult = "PASSED" if outcome.get_result().passed else "FAILED"logging.info(f"Test finished: {item.name} - {result}")
运行效果
运行测试时,日志会记录在 test.log 文件中,同时在控制台实时输出。
方式二:通过 pytest.ini 配置文件管理日志显示
使用 pytest.ini 文件设置全局日志配置,省去手动编写 logging 的代码。
配置示例
创建或编辑项目中的 pytest.ini 文件:
[pytest] log_cli = true # 启用控制台日志输出 log_cli_level = INFO # 设置日志级别 log_cli_format = %(asctime)s - %(levelname)s - %(message)s # 日志格式 log_cli_date_format = %Y-%m-%d %H:%M:%S # 日期格式log_file = test.log # 日志文件保存路径 log_file_level = INFO # 文件日志级别 log_file_format = %(asctime)s - %(levelname)s - %(message)s # 文件日志格式 log_file_date_format = %Y-%m-%d %H:%M:%S # 文件日期格式
运行效果
- 控制台输出的日志格式与级别按照配置显示。
- 所有日志信息保存到
test.log文件。
方式三:在测试代码中使用 caplog 捕获日志
使用 pytest 提供的内置 caplog 功能捕获日志,适用于验证日志输出的测试场景。
测试用例示例
import loggingdef test_logging_example(caplog):logging.info("This is an info log.")logging.error("This is an error log.")assert "info log" in caplog.text # 验证日志内容assert "error log" in caplog.text
运行效果
caplog捕获到的日志信息可以用于断言和分析。
常见日志配置说明
| 配置项 | 描述 | 示例值 |
|---|---|---|
log_cli | 启用控制台日志输出。 | true |
log_cli_level | 设置控制台日志输出的级别。 | INFO, DEBUG, ERROR |
log_cli_format | 控制台日志的格式。 | %(asctime)s - %(message)s |
log_cli_date_format | 控制台日志的日期格式。 | %Y-%m-%d %H:%M:%S |
log_file | 指定日志文件的路径。 | test.log |
log_file_level | 设置日志文件的输出级别。 | INFO, WARNING |
log_file_format | 文件日志的格式。 | %(levelname)s - %(message)s |
log_file_date_format | 文件日志的日期格式。 | %Y-%m-%d %H:%M:%S |
推荐组合方式
-
全局日志管理:
- 使用
pytest.ini配置,统一管理日志级别、格式和输出路径。 - 适用于简单、稳定的项目日志需求。
- 使用
-
细粒度控制:
- 在
conftest.py中结合钩子函数,针对用例或阶段添加特定的日志逻辑。 - 适用于复杂场景的动态日志需求。
- 在
-
日志验证:
- 使用
caplog在特定测试用例中捕获日志内容,便于断言和调试。
- 使用
通过以上方式,可以灵活、高效地在 pytest 项目中实现日志管理与显示。
相关文章:
pytest日志显示
在 pytest 中,可以通过 钩子函数 和 配置文件 pytest.ini 配置日志的显示方式,实现对日志的灵活控制。以下是常用实现方式及配置说明。 方式一:使用 conftest.py 钩子函数自定义日志显示 通过 conftest.py 文件中的钩子函数,实现…...
【信息系统项目管理师】第15章:项目风险管理过程详解
更多内容请见: 备考信息系统项目管理师-专栏介绍和目录 文章目录 一、规划风险管理1、输入2、工具与技术3、输出二、识别风险1、输入2、工具与技术3、输出三、实施定性风险分析1、输入2、工具与技术3、输出四、实施定量风险分析1、输入2、工具与技术3、输出五、规划风险应对1、…...
Diffusers 使用 LoRA
使用diffusers 加载 LoRA,实现文生图功能。摘自 diffusers文档。 模型可以根据名称去modelscope找对应资源下载。使用的时候需要替换成具体路径。虽然modelscope和diffusers都使用了模型id,但是并不能通用。 不同的LoRA对应了不同的“trigger” words&am…...
云安全博客阅读(二)
2024-05-30 Cloudflare acquires BastionZero to extend Zero Trust access to IT infrastructure IT 基础设施的零信任 不同于应用安全,基础设置的安全的防护紧急程度更高,基础设施的安全防护没有统一的方案IT基础设施安全的场景多样,如se…...
SpringCloud系列教程:微服务的未来(六)docker教程快速入门、常用命令
对于开发人员和运维工程师而言,掌握 Docker 的基本概念和常用命令是必不可少的。本篇文章将带你快速入门 Docker,并介绍一些最常用的命令,帮助你更高效地进行开发、测试和部署。 目录 前言 快速入门 docker安装 配置镜像加速 部署Mysql …...
Vue 快速入门:开启前端新征程
在当今的 Web 开发领域,Vue.js 作为一款极具人气的 JavaScript 前端框架,正被广泛应用于各类项目之中。它以简洁的语法、高效的数据绑定机制以及强大的组件化开发模式,为开发者们带来了前所未有的开发体验。如果你渴望踏入前端开发的精彩世界…...
UVM:uvm_component methods configure
topic UVM component base class uvm_config_db 建议使用uvm_config_db代替uvm_resource_db uvm factory sv interface 建议:uvm_config_db 以下了解 建议打印error...
LLM 训练中存储哪些矩阵:权重矩阵,梯度矩阵,优化器状态
LLM 训练中存储哪些矩阵 目录 LLM 训练中存储哪些矩阵深度学习中梯度和优化器是什么在 LLM 训练中通常会存储以下矩阵: 权重矩阵:这是模型的核心组成部分。例如在基于 Transformer 架构的 LLM 中,每一层的多头注意力机制和前馈神经网络都会有相应的权重矩阵。以 BERT 模型为…...
大模型思维链推理的进展、前沿和未来分析
大模型思维链推理的综述:进展、前沿和未来 "Chain of Thought Reasoning: A State-of-the-Art Analysis, Exploring New Horizons and Predicting Future Directions." 思维链推理的综述:进展、前沿和未来 摘要:思维链推理&#…...
NLP 技术的突破与未来:从词嵌入到 Transformer
在过去的十年中,自然语言处理(NLP)经历了深刻的技术变革。从早期的统计方法到深度学习的应用,再到如今Transformer架构的普及,NLP 的发展不仅提高了模型的性能,还扩展了其在不同领域中的应用边界。 1. 词嵌…...
嵌入式中QT实现文本与线程控制方法
第一:利用QT进行文件读写实现 利用QT进行读写文本的时候进行读写,读取MP3歌词的文本,对这个文件进行读写操作。 实例代码,利用Qfile,对文件进行读写。 //读取对应文件文件,头文件的实现。 #ifndef MAINWINDOW_H #define MAINWINDOW_H#include <QMainWindow> #incl…...
云备份项目--服务端编写
文章目录 7. 数据管理模块7.1 如何设计7.2 完整的类 8. 热点管理8.1 如何设计8.2 完整的类 9. 业务处理模块9.1 如何设计9.2 完整的类9.3 测试9.3.1 测试展示功能 完整的代码–gitee链接 7. 数据管理模块 TODO: 读写锁?普通锁? 7.1 如何设计 需要管理…...
Node.js——fs(文件系统)模块
个人简介 👀个人主页: 前端杂货铺 🙋♂️学习方向: 主攻前端方向,正逐渐往全干发展 📃个人状态: 研发工程师,现效力于中国工业软件事业 🚀人生格言: 积跬步…...
SAP BC 同服务器不同client之间的传输SCC1
源配置client不需要释放 登录目标client SCC1...
CentOS: RPM安装、YUM安装、编译安装(详细解释+实例分析!!!)
目录 1.什么是RPM 1.1 RPM软件包命名格式 1.2RPM功能 1.3查询已安装的软件:rpm -q 查询已安装软件的信息 1.4 挂载:使用硬件(光驱 硬盘 u盘等)的方法(重点!!!) 1…...
linux音视频采集技术: v4l2
简介 在 Linux 系统中,视频设备的支持和管理离不开 V4L2(Video for Linux 2)。作为 Linux 内核的一部分,V4L2 提供了一套统一的接口,允许开发者与视频设备(如摄像头、视频采集卡等)进行交互。无…...
MySQL使用navicat新增触发器
找到要新增触发器的表,然后点击设计,找到触发器标签。 根据实际需要,填写相关内容,操作完毕,点击保存按钮。 在右侧的预览界面,可以看到新生成的触发器脚本...
voice agent实现方案调研
前言 目前语音交互主要的实现大体有两种: 级联方案,指的是,大规模语言模型 (LLM)、文本转语音 (TTS) 和语音转文本 (STT),客户的话通过vad断句到STT的语音转文本,经过大模型进行生成文本,生成文本后通过TTS进行回复给用户。(主流方案)端到端的方案,开发者无需再…...
TCP通信原理学习
TCP三次握手和四次挥手以及为什么_哔哩哔哩_bilibili...
Three.js 基础概念:构建3D世界的核心要素
文章目录 前言一、场景(Scene)二、相机(Camera)三、渲染器(Renderer)四、物体(Object)五、材质(Material)六、几何体(Geometry)七、光…...
LSM303DLHC六轴传感器驱动与电子罗盘实现指南
1. LSM303DLHC 多模态传感器芯片深度解析:加速度计、磁力计与温度传感的嵌入式集成实践LSM303DLHC 是意法半导体(STMicroelectronics)推出的一款高集成度、低功耗的六轴环境感知传感器模块,内部集成了独立校准的三轴加速度计&…...
Win10家庭版用户必看:用傲梅分区助手克隆硬盘时如何避免RAW格式(附BitLocker解决方案)
Win10家庭版硬盘克隆避坑指南:傲梅分区助手与BitLocker加密的实战解决方案 最近帮朋友处理一台联想小新Air14的硬盘扩容需求时,遇到了一个颇具代表性的问题:使用傲梅分区助手克隆完硬盘后,目标盘突然变成了无法识别的RAW格式。这个…...
Windows右键菜单缺失Office新建选项的注册表修复指南
1. 问题现象与排查思路 最近帮同事处理电脑问题时,发现一个挺常见的现象:在桌面或文件夹右键点击时,本该出现的"新建Word/Excel/PPT"选项神秘消失了。这种情况通常发生在重装系统、Office异常卸载或某些优化软件清理注册表之后。我…...
别再让Halcon拉伸你的图像了!手把手教你用dev_set_part实现完美等比例显示
Halcon图像显示优化:用dev_set_part实现完美等比例适配 在机器视觉项目开发中,图像显示的准确性直接影响测量结果和判断效率。许多Halcon初学者都会遇到一个令人头疼的问题——当图像被加载到控件窗口时,系统默认的拉伸显示方式会破坏原始比例…...
WHAT - Shell 工具 warp 介绍(融合 AI)
文章目录Warp Terminal 是什么和传统 Terminal 最大区别可以“用人话操作终端”输入体验像代码编辑器Block(块)概念(非常关键)AI Agent团队协作(Warp Drive)UI 和体验完全现代化和 iTerm2 / Terminal 的本…...
OpenClaw+优云智算Coding Plan:从灵感到成文,再到发布的全流程AI自动化鄙
1.安装环境准备 1.1.查看物理内存 [rootaiserver ~]# free -m 1.2.操作系统版本 [rootaiserver ~]# cat /etc/redhat-release 1.3.操作系统内存 [rootaiserver ~]# df -h /dev/shm/ 1.4.磁盘空间 [rootaiserver ~]# df -TH [rootaiserver ~]# df -h /tmp/ [rootaiserver ~]# d…...
Spring_couplet_generation 技术社区分享:在CSDN撰写高质量技术博客指南
Spring_couplet_generation 技术社区分享:在CSDN撰写高质量技术博客指南 写技术博客,尤其是分享一个像 Spring_couplet_generation 这样有趣又有文化内涵的项目,是件挺有成就感的事。但怎么才能把文章写得既有干货,又能吸引人&am…...
[Linux][虚拟串口]x一个特殊的字节低
简介 langchain专门用于构建LLM大语言模型,其中提供了大量的prompt模板,和组件,通过chain(链)的方式将流程连接起来,操作简单,开发便捷。 环境配置 安装langchain框架 pip install langchain langchain-community 其中…...
保姆级教程:在Ubuntu 20.04上从零配置MoveIt!控制Franka Panda机械臂(含libfranka避坑指南)
保姆级教程:在Ubuntu 20.04上从零配置MoveIt!控制Franka Panda机械臂(含libfranka避坑指南) 当第一次看到Franka Panda机械臂优雅地完成抓取动作时,那种精密机械与智能算法完美融合的震撼感,至今记忆犹新。作为一款广泛…...
别再只会点‘Solve’了!Ansys Workbench 2022R1静力学分析完整避坑清单与高级技巧
Ansys Workbench静力学分析进阶指南:从避坑到高效求解 在工程仿真领域,Ansys Workbench作为行业标杆工具,其静力学分析模块的深度应用往往决定了仿真结果的可靠性与工程价值。本文针对已掌握基础操作但面临复杂工况挑战的工程师,系…...
