Merge pull request #4501 from s0undt3ch/master
Test case for #4500 and respective fix #4487
This commit is contained in:
		
						commit
						99d3fe22dc
					
				|  | @ -1 +0,0 @@ | |||
| During teardown of the python process, and on rare occasions, capture attributes can be ``None`` while trying to resume global capture. | ||||
|  | @ -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``. | ||||
|  | @ -302,14 +302,14 @@ class TestLoggingInteraction(object): | |||
|             """\ | ||||
|             import logging | ||||
|             def setup_function(function): | ||||
|                 logging.warn("hello1") | ||||
|                 logging.warning("hello1") | ||||
| 
 | ||||
|             def test_logging(): | ||||
|                 logging.warn("hello2") | ||||
|                 logging.warning("hello2") | ||||
|                 assert 0 | ||||
| 
 | ||||
|             def teardown_function(function): | ||||
|                 logging.warn("hello3") | ||||
|                 logging.warning("hello3") | ||||
|                 assert 0 | ||||
|             """ | ||||
|         ) | ||||
|  | @ -328,14 +328,14 @@ class TestLoggingInteraction(object): | |||
|             """\ | ||||
|             import logging | ||||
|             def setup_module(function): | ||||
|                 logging.warn("hello1") | ||||
|                 logging.warning("hello1") | ||||
| 
 | ||||
|             def test_logging(): | ||||
|                 logging.warn("hello2") | ||||
|                 logging.warning("hello2") | ||||
|                 assert 0 | ||||
| 
 | ||||
|             def teardown_module(function): | ||||
|                 logging.warn("hello3") | ||||
|                 logging.warning("hello3") | ||||
|                 assert 0 | ||||
|             """ | ||||
|         ) | ||||
|  | @ -354,7 +354,7 @@ class TestLoggingInteraction(object): | |||
|             """\ | ||||
|                 import logging | ||||
|                 logging.basicConfig() | ||||
|                 logging.warn("hello435") | ||||
|                 logging.warning("hello435") | ||||
|             """ | ||||
|         ) | ||||
|         # make sure that logging is still captured in tests | ||||
|  | @ -375,7 +375,7 @@ class TestLoggingInteraction(object): | |||
|             """\ | ||||
|             def test_hello(): | ||||
|                 import logging | ||||
|                 logging.warn("hello433") | ||||
|                 logging.warning("hello433") | ||||
|                 assert 0 | ||||
|             """ | ||||
|         ) | ||||
|  | @ -385,6 +385,40 @@ class TestLoggingInteraction(object): | |||
|         assert "something" 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): | ||||
|     @pytest.mark.parametrize("opt", [[], ["-s"]]) | ||||
|  | @ -1300,13 +1334,13 @@ def test_capturing_and_logging_fundamentals(testdir, method): | |||
|                                      Capture=capture.%s) | ||||
|         cap.start_capturing() | ||||
| 
 | ||||
|         logging.warn("hello1") | ||||
|         logging.warning("hello1") | ||||
|         outerr = cap.readouterr() | ||||
|         print("suspend, captured %%s" %%(outerr,)) | ||||
|         logging.warn("hello2") | ||||
|         logging.warning("hello2") | ||||
| 
 | ||||
|         cap.pop_outerr_to_orig() | ||||
|         logging.warn("hello3") | ||||
|         logging.warning("hello3") | ||||
| 
 | ||||
|         outerr = cap.readouterr() | ||||
|         print("suspend2, captured %%s" %% (outerr,)) | ||||
|  |  | |||
		Loading…
	
		Reference in New Issue