Merge pull request #4501 from s0undt3ch/master

Test case for #4500 and respective fix #4487
This commit is contained in:
Anthony Sottile 2018-12-03 09:11:00 -08:00 committed by GitHub
commit 99d3fe22dc
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
3 changed files with 46 additions and 12 deletions

View File

@ -1 +0,0 @@
During teardown of the python process, and on rare occasions, capture attributes can be ``None`` while trying to resume global capture.

View File

@ -0,0 +1 @@
When a fixture yields and a log call is made after the test runs, and, if the test is interrupted, capture attributes are ``None``.

View File

@ -302,14 +302,14 @@ class TestLoggingInteraction(object):
"""\ """\
import logging import logging
def setup_function(function): def setup_function(function):
logging.warn("hello1") logging.warning("hello1")
def test_logging(): def test_logging():
logging.warn("hello2") logging.warning("hello2")
assert 0 assert 0
def teardown_function(function): def teardown_function(function):
logging.warn("hello3") logging.warning("hello3")
assert 0 assert 0
""" """
) )
@ -328,14 +328,14 @@ class TestLoggingInteraction(object):
"""\ """\
import logging import logging
def setup_module(function): def setup_module(function):
logging.warn("hello1") logging.warning("hello1")
def test_logging(): def test_logging():
logging.warn("hello2") logging.warning("hello2")
assert 0 assert 0
def teardown_module(function): def teardown_module(function):
logging.warn("hello3") logging.warning("hello3")
assert 0 assert 0
""" """
) )
@ -354,7 +354,7 @@ class TestLoggingInteraction(object):
"""\ """\
import logging import logging
logging.basicConfig() logging.basicConfig()
logging.warn("hello435") logging.warning("hello435")
""" """
) )
# make sure that logging is still captured in tests # make sure that logging is still captured in tests
@ -375,7 +375,7 @@ class TestLoggingInteraction(object):
"""\ """\
def test_hello(): def test_hello():
import logging import logging
logging.warn("hello433") logging.warning("hello433")
assert 0 assert 0
""" """
) )
@ -385,6 +385,40 @@ class TestLoggingInteraction(object):
assert "something" not in result.stderr.str() assert "something" not in result.stderr.str()
assert "operation on closed file" not in result.stderr.str() assert "operation on closed file" not in result.stderr.str()
def test_logging_after_cap_stopped(self, testdir):
testdir.makeconftest(
"""\
import pytest
import logging
log = logging.getLogger(__name__)
@pytest.fixture
def log_on_teardown():
yield
log.warning('Logging on teardown')
"""
)
# make sure that logging is still captured in tests
p = testdir.makepyfile(
"""\
def test_hello(log_on_teardown):
import logging
logging.warning("hello433")
assert 1
raise KeyboardInterrupt()
"""
)
result = testdir.runpytest_subprocess(p, "--log-cli-level", "info")
assert result.ret != 0
result.stdout.fnmatch_lines(
["*WARNING*hello433*", "*WARNING*Logging on teardown*"]
)
assert (
"AttributeError: 'NoneType' object has no attribute 'resume_capturing'"
not in result.stderr.str()
)
class TestCaptureFixture(object): class TestCaptureFixture(object):
@pytest.mark.parametrize("opt", [[], ["-s"]]) @pytest.mark.parametrize("opt", [[], ["-s"]])
@ -1300,13 +1334,13 @@ def test_capturing_and_logging_fundamentals(testdir, method):
Capture=capture.%s) Capture=capture.%s)
cap.start_capturing() cap.start_capturing()
logging.warn("hello1") logging.warning("hello1")
outerr = cap.readouterr() outerr = cap.readouterr()
print("suspend, captured %%s" %%(outerr,)) print("suspend, captured %%s" %%(outerr,))
logging.warn("hello2") logging.warning("hello2")
cap.pop_outerr_to_orig() cap.pop_outerr_to_orig()
logging.warn("hello3") logging.warning("hello3")
outerr = cap.readouterr() outerr = cap.readouterr()
print("suspend2, captured %%s" %% (outerr,)) print("suspend2, captured %%s" %% (outerr,))