123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215 |
- from pybind11_tests import iostream as m
- import sys
- from contextlib import contextmanager
- try:
- # Python 3
- from io import StringIO
- except ImportError:
- # Python 2
- try:
- from cStringIO import StringIO
- except ImportError:
- from StringIO import StringIO
- try:
- # Python 3.4
- from contextlib import redirect_stdout
- except ImportError:
- @contextmanager
- def redirect_stdout(target):
- original = sys.stdout
- sys.stdout = target
- yield
- sys.stdout = original
- try:
- # Python 3.5
- from contextlib import redirect_stderr
- except ImportError:
- @contextmanager
- def redirect_stderr(target):
- original = sys.stderr
- sys.stderr = target
- yield
- sys.stderr = original
- def test_captured(capsys):
- msg = "I've been redirected to Python, I hope!"
- m.captured_output(msg)
- stdout, stderr = capsys.readouterr()
- assert stdout == msg
- assert stderr == ''
- m.captured_output_default(msg)
- stdout, stderr = capsys.readouterr()
- assert stdout == msg
- assert stderr == ''
- m.captured_err(msg)
- stdout, stderr = capsys.readouterr()
- assert stdout == ''
- assert stderr == msg
- def test_captured_large_string(capsys):
- # Make this bigger than the buffer used on the C++ side: 1024 chars
- msg = "I've been redirected to Python, I hope!"
- msg = msg * (1024 // len(msg) + 1)
- m.captured_output_default(msg)
- stdout, stderr = capsys.readouterr()
- assert stdout == msg
- assert stderr == ''
- def test_guard_capture(capsys):
- msg = "I've been redirected to Python, I hope!"
- m.guard_output(msg)
- stdout, stderr = capsys.readouterr()
- assert stdout == msg
- assert stderr == ''
- def test_series_captured(capture):
- with capture:
- m.captured_output("a")
- m.captured_output("b")
- assert capture == "ab"
- def test_flush(capfd):
- msg = "(not flushed)"
- msg2 = "(flushed)"
- with m.ostream_redirect():
- m.noisy_function(msg, flush=False)
- stdout, stderr = capfd.readouterr()
- assert stdout == ''
- m.noisy_function(msg2, flush=True)
- stdout, stderr = capfd.readouterr()
- assert stdout == msg + msg2
- m.noisy_function(msg, flush=False)
- stdout, stderr = capfd.readouterr()
- assert stdout == msg
- def test_not_captured(capfd):
- msg = "Something that should not show up in log"
- stream = StringIO()
- with redirect_stdout(stream):
- m.raw_output(msg)
- stdout, stderr = capfd.readouterr()
- assert stdout == msg
- assert stderr == ''
- assert stream.getvalue() == ''
- stream = StringIO()
- with redirect_stdout(stream):
- m.captured_output(msg)
- stdout, stderr = capfd.readouterr()
- assert stdout == ''
- assert stderr == ''
- assert stream.getvalue() == msg
- def test_err(capfd):
- msg = "Something that should not show up in log"
- stream = StringIO()
- with redirect_stderr(stream):
- m.raw_err(msg)
- stdout, stderr = capfd.readouterr()
- assert stdout == ''
- assert stderr == msg
- assert stream.getvalue() == ''
- stream = StringIO()
- with redirect_stderr(stream):
- m.captured_err(msg)
- stdout, stderr = capfd.readouterr()
- assert stdout == ''
- assert stderr == ''
- assert stream.getvalue() == msg
- def test_multi_captured(capfd):
- stream = StringIO()
- with redirect_stdout(stream):
- m.captured_output("a")
- m.raw_output("b")
- m.captured_output("c")
- m.raw_output("d")
- stdout, stderr = capfd.readouterr()
- assert stdout == 'bd'
- assert stream.getvalue() == 'ac'
- def test_dual(capsys):
- m.captured_dual("a", "b")
- stdout, stderr = capsys.readouterr()
- assert stdout == "a"
- assert stderr == "b"
- def test_redirect(capfd):
- msg = "Should not be in log!"
- stream = StringIO()
- with redirect_stdout(stream):
- m.raw_output(msg)
- stdout, stderr = capfd.readouterr()
- assert stdout == msg
- assert stream.getvalue() == ''
- stream = StringIO()
- with redirect_stdout(stream):
- with m.ostream_redirect():
- m.raw_output(msg)
- stdout, stderr = capfd.readouterr()
- assert stdout == ''
- assert stream.getvalue() == msg
- stream = StringIO()
- with redirect_stdout(stream):
- m.raw_output(msg)
- stdout, stderr = capfd.readouterr()
- assert stdout == msg
- assert stream.getvalue() == ''
- def test_redirect_err(capfd):
- msg = "StdOut"
- msg2 = "StdErr"
- stream = StringIO()
- with redirect_stderr(stream):
- with m.ostream_redirect(stdout=False):
- m.raw_output(msg)
- m.raw_err(msg2)
- stdout, stderr = capfd.readouterr()
- assert stdout == msg
- assert stderr == ''
- assert stream.getvalue() == msg2
- def test_redirect_both(capfd):
- msg = "StdOut"
- msg2 = "StdErr"
- stream = StringIO()
- stream2 = StringIO()
- with redirect_stdout(stream):
- with redirect_stderr(stream2):
- with m.ostream_redirect():
- m.raw_output(msg)
- m.raw_err(msg2)
- stdout, stderr = capfd.readouterr()
- assert stdout == ''
- assert stderr == ''
- assert stream.getvalue() == msg
- assert stream2.getvalue() == msg2
|