浅谈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 -W and PYTHONWARNINGS, 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 -W and PYTHONWARNINGS, 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 0 to 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处理的更多相关文章

  1. 浅谈Java中的equals和==(转)

    浅谈Java中的equals和== 在初学Java时,可能会经常碰到下面的代码: 1 String str1 = new String("hello"); 2 String str ...

  2. 浅谈Linux中的信号处理机制(二)

    首先谢谢 @小尧弟 这位朋友对我昨天夜里写的一篇<浅谈Linux中的信号处理机制(一)>的指正,之前的题目我用的“浅析”一词,给人一种要剖析内核的感觉.本人自知功力不够,尚且不能对着Lin ...

  3. 浅谈Java中的对象和引用

    浅谈Java中的对象和对象引用 在Java中,有一组名词经常一起出现,它们就是“对象和对象引用”,很多朋友在初学Java的时候可能经常会混淆这2个概念,觉得它们是一回事,事实上则不然.今天我们就来一起 ...

  4. 浅谈Java中的equals和==

    浅谈Java中的equals和== 在初学Java时,可能会经常碰到下面的代码: String str1 = new String("hello"); String str2 = ...

  5. 转【】浅谈sql中的in与not in,exists与not exists的区别_

    浅谈sql中的in与not in,exists与not exists的区别   1.in和exists in是把外表和内表作hash连接,而exists是对外表作loop循环,每次loop循环再对内表 ...

  6. 浅谈iOS中的userAgent

    浅谈iOS中的userAgent   User-Agent(用户代理)字符串是Web浏览器用于声明自身型号版本并随HTTP请求发送给Web服务器的字符串,在Web服务器上可以获取到该字符串. 在公司产 ...

  7. 浅谈JavaScript中的闭包

    浅谈JavaScript中的闭包 在JavaScript中,闭包是指这样一个函数:它有权访问另一个函数作用域中的变量. 创建一个闭包的常用的方式:在一个函数内部创建另一个函数. 比如: functio ...

  8. 浅谈sql中的in与not in,exists与not exists的区别

    转 浅谈sql中的in与not in,exists与not exists的区别   12月12日北京OSC源创会 —— 开源技术的年终盛典 »   sql exists in 1.in和exists ...

  9. 浅谈Java中的深拷贝和浅拷贝(转载)

    浅谈Java中的深拷贝和浅拷贝(转载) 原文链接: http://blog.csdn.net/tounaobun/article/details/8491392 假如说你想复制一个简单变量.很简单: ...

  10. 浅谈Java中的深拷贝和浅拷贝

    转载: 浅谈Java中的深拷贝和浅拷贝 假如说你想复制一个简单变量.很简单: int apples = 5; int pears = apples; 不仅仅是int类型,其它七种原始数据类型(bool ...

随机推荐

  1. EasyPoi 导出Excel(ExcelExportEntity生成表头)

    [引入依赖] <!--easypoi--> <dependency> <groupId>cn.afterturn</groupId> <artif ...

  2. 12、求Sn = a + aa + aaa + aaaa + ....其中a为一个数字,一共有n项。a和n由用户键盘输入。

    /* 求Sn = a + aa + aaa + aaaa + ....其中a为一个数字,一共有n项.a和n由用户键盘输入. */ #include <stdio.h> #include & ...

  3. centos8 telnet安装

    1. 装包 yum -y install telnet telnet-server 2. 启服务 systemctl enable telnet.socket --now 3. 防火墙开放端口 fir ...

  4. Python-OpenCV的安装及学习资料

    Conda环境安装 OpenCV pip install opencv-python opencv-contrib-python -i https://mirrors.aliyun.com/pypi/ ...

  5. 漫谈计算机网络:应用层 ----- 从DNS域名解析到WWW万维网再到P2P应用

    2022-12-04 18:31:01 纪念一下博主的<漫谈计算机网络>连载博客 浏览量破500了! 今天更新完结篇! 面试答不上?计网很枯燥? 听说你学习 计网 每次记了都会忘? 不妨抽 ...

  6. MyBatis02:流程分析、注解、代理dao实现CRUD、参数深入、传统DAO、配置

    今日内容 回顾 mybatis的自定义.分析和环境搭建 完善基于注解的mybatis mybatis的curd(基于代理dao的方式)※ mybatis的参数深入及结果集的深入 mybatis中基于传 ...

  7. JAVA里Map的一些常用方法

    Map的常用方法 案例1 场景:一张建行用户体验金信息大表(百万级别),里面存在一个字段对多条数据,需要统计某个字段的多条数据累加值以供于别的服务调用. 优化前解决:直接查出来一个大list给到另一个 ...

  8. python 异步写入文件

    # -*- coding:utf-8 -*-import asyncioimport aiofilesimport time#异步操作时,函数名前必须加上asyncasync def func1(): ...

  9. Flutter和Rust如何优雅的交互

    前言 文章的图片链接都是在github上,可能需要...你懂得:本文含有大量关键步骤配置图片,强烈建议在合适环境下阅读 Flutter直接调用C层还是蛮有魅力,想想你练习C++,然后直接能用flutt ...

  10. placeholder属性作用

    placeholder属性作用 1.介绍 该提示会在输入字段为空时显示,并会在字段获得焦点时消失. 注释:placeholder 属性适用于以下的 <input> 类型:text, sea ...