Also capture warnings during setup/teardown

This commit is contained in:
Bruno Oliveira 2017-03-04 16:07:37 -03:00
parent e24081bf76
commit de09023e45
2 changed files with 57 additions and 3 deletions

View File

@ -1,4 +1,6 @@
import os import os
from contextlib import contextmanager
import pytest import pytest
import warnings import warnings
@ -38,8 +40,13 @@ def pytest_addoption(parser):
"to warnings.filterwarnings. Process after -W and --pythonwarnings.") "to warnings.filterwarnings. Process after -W and --pythonwarnings.")
@pytest.hookimpl(hookwrapper=True) @contextmanager
def pytest_runtest_call(item): def catch_warnings_for_item(item):
"""
catches the warnings generated during setup/call/teardown execution
of the given item and after it is done posts them as warnings to this
item.
"""
args = item.config.getoption('pythonwarnings') or [] args = item.config.getoption('pythonwarnings') or []
inifilters = item.config.getini("filterwarnings") inifilters = item.config.getini("filterwarnings")
with warnings.catch_warnings(record=True) as log: with warnings.catch_warnings(record=True) as log:
@ -56,4 +63,23 @@ def pytest_runtest_call(item):
msg = warnings.formatwarning( msg = warnings.formatwarning(
warning.message, warning.category, warning.message, warning.category,
warning.filename, warning.lineno, warning.line) warning.filename, warning.lineno, warning.line)
item.config.warn("W0", msg, fslocation=None) item.config.warn("unused", msg, fslocation=None)
@pytest.hookimpl(hookwrapper=True)
def pytest_runtest_call(item):
with catch_warnings_for_item(item):
yield
@pytest.hookimpl(hookwrapper=True)
def pytest_runtest_setup(item):
with catch_warnings_for_item(item):
yield
@pytest.hookimpl(hookwrapper=True)
def pytest_runtest_teardown(item):
with catch_warnings_for_item(item):
yield

View File

@ -27,6 +27,34 @@ def test_normal_flow(testdir, pyfile_with_warnings):
]) ])
def test_setup_teardown_warnings(testdir, pyfile_with_warnings):
testdir.makepyfile('''
import warnings
import pytest
@pytest.fixture
def fix():
warnings.warn(UserWarning("warning during setup"))
yield
warnings.warn(UserWarning("warning during teardown"))
def test_func(fix):
pass
''')
result = testdir.runpytest()
result.stdout.fnmatch_lines([
'*== %s ==*' % WARNINGS_SUMMARY_HEADER,
'*test_setup_teardown_warnings.py:6: UserWarning: warning during setup',
' warnings.warn(UserWarning("warning during setup"))',
'*test_setup_teardown_warnings.py:8: UserWarning: warning during teardown',
' warnings.warn(UserWarning("warning during teardown"))',
'* 1 passed, 2 warnings*',
])
@pytest.mark.parametrize('method', ['cmdline', 'ini']) @pytest.mark.parametrize('method', ['cmdline', 'ini'])
def test_as_errors(testdir, pyfile_with_warnings, method): def test_as_errors(testdir, pyfile_with_warnings, method):
args = ('-W', 'error') if method == 'cmdline' else () args = ('-W', 'error') if method == 'cmdline' else ()