浅谈Pytest中的warning处理
浅谈Pytest中的warning处理
没有处理warning
- 我们写一个简单的测试
import pytest
def test_demo():
import warnings
warnings.warn('test warn',DeprecationWarning)
assert True
if __name__ == '__main__':
pytest.main(['-sv',__file__])
- 你运行的话会有如下提示
============================= test session starts =============================
platform win32 -- Python 3.9.6, pytest-7.1.2, pluggy-1.0.0 -- D:\Python39\python.exe
cachedir: .pytest_cache
metadata: ...
rootdir: D:\pythonProject\AutoTest\PytestTemp, configfile: pytest.ini
plugins: ...
collecting ... collected 1 item
test_demo.py::test_demo PASSED
============================== warnings summary ===============================
testCases/test_demo.py::test_demo
test_demo.py:5: DeprecationWarning: test warn
warnings.warn('test warn',DeprecationWarning)
-- Docs: https://docs.pytest.org/en/stable/how-to/capture-warnings.html
======================== 1 passed, 1 warning in 0.05s =========================
进程已结束,退出代码为 0
- warning在pytest3.1之后会在执行期间捕获,初学者多见于mark漏了标记,可以参考浅谈Pytest中的marker
-W 命令行及处理
pytest提供了一个命令行参数-W
-W PYTHONWARNINGS, --pythonwarnings=PYTHONWARNINGS
含义: set which warnings to report, see -W option of python itself.
python的-W
-W arg : warning control; arg is action:message:category:module:lineno also PYTHONWARNINGS=arg
https://docs.python.org/3/library/warnings.html#warning-filter
关于格式说明
action is one of the following strings:
Value Disposition "default"print the first occurrence of matching warnings for each location (module + line number) where the warning is issued "error"turn matching warnings into exceptions "ignore"never print matching warnings "always"always print matching warnings "module"print the first occurrence of matching warnings for each module where the warning is issued (regardless of line number) "once"print only the first occurrence of matching warnings, regardless of location message is a string containing a regular expression that the start of the warning message must match, case-insensitively. In
-WandPYTHONWARNINGS, message is a literal string that the start of the warning message must contain (case-insensitively), ignoring any whitespace at the start or end of message.category is a class (a subclass of
Warning) of which the warning category must be a subclass in order to match.module is a string containing a regular expression that the start of the fully qualified module name must match, case-sensitively. In
-WandPYTHONWARNINGS, module is a literal string that the fully qualified module name must be equal to (case-sensitively), ignoring any whitespace at the start or end of module.lineno is an integer that the line number where the warning occurred must match, or
0to match all line numbers.
增加命令行处理
# action:message:category:module:lineno # 注意格式
-W error::DeprecationWarning # 意思是看到DeprecationWarning就把它当做是一个error
================================== FAILURES ===================================
__________________________________ test_demo __________________________________ def test_demo():
import warnings
> warnings.warn('test warn',DeprecationWarning)
E DeprecationWarning: test warn test_demo.py:5: DeprecationWarning
=========================== short test summary info ===========================
FAILED test_demo.py::test_demo - DeprecationWarning: test warn
============================== 1 failed in 0.09s ==============================可以看到case变成了failed
换一下,改为ignore,case就PASSED了
pytest.main(['-sv','-W ignore::DeprecationWarning',__file__])
============================== 1 passed in 0.07s ==============================
等价的装饰器pytest.mark.filterwarnings
命令行的做法也可以等价到装饰器的写法,跟大多数的插件类似,命令行是针对所有的,装饰器是针对某个case的
@pytest.mark.filterwarnings('ignore::DeprecationWarning') # 装饰在被测函数上即可 @pytest.mark.filterwarnings('error::DeprecationWarning')
等价的pytest.ini中的filterwarnings
你也可以这样写一个pytest.ini
[pytest]
filterwarnings:
ignore::DeprecationWarning或者这样
[pytest]
filterwarnings:
error::DeprecationWarning
还可以这样
[pytest]
filterwarnings:
error
ignore::DeprecationWarning这个意思是,所有的warning都被处理成error,但忽略DeprecationWarning。
注意:当警告与列表中的多个选项匹配时,将执行最后一个匹配选项的操作。
关于warning的其他
--disable-warnings命令行选项可以禁用warning summary
============================== warnings summary ===============================
testCases/test_demo.py::test_demo
test_demo.py:5: DeprecationWarning: test warn
warnings.warn('test warn',DeprecationWarning) -- Docs: https://docs.pytest.org/en/stable/how-to/capture-warnings.html上面的warning加了命令行之后就没了
命令行的解释
--disable-warnings, --disable-pytest-warnings : disable warnings summary
还有一个命令行-pno:warnings,完全禁用警告捕获
pytest.main(['-sv','-pno:warnings',__file__])实测-pno:warnings的pno要挨在一起,这有点...
命令行的解释
-p name early-load given plugin module name or
entry point (multi-allowed).
To avoid loading of plugins, use the
`no:` prefix, e.g. `no:doctest`.如果你放在pytest.ini中的pno就可分可合(离谱)
[pytest]
addopts = -p no:warnings # -pno:warnings
浅谈Pytest中的warning处理的更多相关文章
- 浅谈Java中的equals和==(转)
浅谈Java中的equals和== 在初学Java时,可能会经常碰到下面的代码: 1 String str1 = new String("hello"); 2 String str ...
- 浅谈Linux中的信号处理机制(二)
首先谢谢 @小尧弟 这位朋友对我昨天夜里写的一篇<浅谈Linux中的信号处理机制(一)>的指正,之前的题目我用的“浅析”一词,给人一种要剖析内核的感觉.本人自知功力不够,尚且不能对着Lin ...
- 浅谈Java中的对象和引用
浅谈Java中的对象和对象引用 在Java中,有一组名词经常一起出现,它们就是“对象和对象引用”,很多朋友在初学Java的时候可能经常会混淆这2个概念,觉得它们是一回事,事实上则不然.今天我们就来一起 ...
- 浅谈Java中的equals和==
浅谈Java中的equals和== 在初学Java时,可能会经常碰到下面的代码: String str1 = new String("hello"); String str2 = ...
- 转【】浅谈sql中的in与not in,exists与not exists的区别_
浅谈sql中的in与not in,exists与not exists的区别 1.in和exists in是把外表和内表作hash连接,而exists是对外表作loop循环,每次loop循环再对内表 ...
- 浅谈iOS中的userAgent
浅谈iOS中的userAgent User-Agent(用户代理)字符串是Web浏览器用于声明自身型号版本并随HTTP请求发送给Web服务器的字符串,在Web服务器上可以获取到该字符串. 在公司产 ...
- 浅谈JavaScript中的闭包
浅谈JavaScript中的闭包 在JavaScript中,闭包是指这样一个函数:它有权访问另一个函数作用域中的变量. 创建一个闭包的常用的方式:在一个函数内部创建另一个函数. 比如: functio ...
- 浅谈sql中的in与not in,exists与not exists的区别
转 浅谈sql中的in与not in,exists与not exists的区别 12月12日北京OSC源创会 —— 开源技术的年终盛典 » sql exists in 1.in和exists ...
- 浅谈Java中的深拷贝和浅拷贝(转载)
浅谈Java中的深拷贝和浅拷贝(转载) 原文链接: http://blog.csdn.net/tounaobun/article/details/8491392 假如说你想复制一个简单变量.很简单: ...
- 浅谈Java中的深拷贝和浅拷贝
转载: 浅谈Java中的深拷贝和浅拷贝 假如说你想复制一个简单变量.很简单: int apples = 5; int pears = apples; 不仅仅是int类型,其它七种原始数据类型(bool ...
随机推荐
- 图扑软件 3D 组态编辑器,低代码零代码构建数字孪生工厂
行业背景 随着中国制造 2025 计划的提出,新一轮的工业改革拉开序幕.大数据积累的指数级增长为智能商业爆发奠定了良好的基础,传统制造业高污染.高能耗.低效率的生产模式已不符合现代工业要求. 图扑拖拽 ...
- 嵌入式-C语言基础:二维数组的地址写法
二维数组a的有关指针: 表示形式 含义 ...
- ROSIntegration ROSIntegrationVision与虚幻引擎4(Unreal Engine 4)的配置
ROSIntegration ROSIntegrationVision与虚幻引擎4(Unreal Engine 4)的配置 操作系统:Ubuntu 18.04 虚幻引擎:4.26.2 目录 ROSIn ...
- Go语言核心36讲49
我们在上一篇文章中简单地讨论了网络编程和socket,并由此提及了Go语言标准库中的syscall代码包和net代码包. 我还重点讲述了net.Dial函数和syscall.Socket函数的参数含义 ...
- 本地GoLand编辑与调试远端服务器上的代码
Goland是专为Go开发人员构建的跨平台IDE,功能非常强大,拥有强大的代码洞察力,帮助所有Go开发人员即时错误检测和修复建议,快速和安全的重构,一步撤销,智能代码完成,死代码检测和文档提示,让您创 ...
- Java—猜数字
package cn.day03.demo01; import java.util.Random; import java.util.Scanner; public class RandomGame ...
- 基于python的数学建模---scipy库
instance1: 求解下列线性规划问题 s.t. 代码: from scipy import optimizeimport numpy as npc = np.array([2,3,-5])A ...
- 数据结构初阶--顺序表(讲解+C++类模板实现)
顺序的概念与结构 顺序表是用一段物理地址连续的存储单元依次存储数据元素的线性结构,一般情况下采用数组存储.在数组上完成数据的增删查改. 一般分为两种:静态顺序表和动态顺序表 静态顺序表 #define ...
- AI赋能音乐创作,人人都是音视频创作者
华为HMS Core音频编辑服务(Audio Editor Kit)依托自身AI技术的研发优势,上线全新的歌声合成音色及伴奏,给音视频创作者提供更多的创作可能.在短视频场景中,用户自定义歌词的歌声结合 ...
- python调用程序路径中包空格,及包含特殊字符问题
解决办法 import os s = r'"C:\Program Files\Google\Chrome\Application\chrome.exe"' print(s) os. ...