我试图使用py.tests capsys
fixture来捕获标准错误流.但是,这似乎不像宣传的那样有效.鉴于这个简单的测试:
from sys import stderr
def test_capsys(capsys):
print('foo')
print('bar', file=stderr)
out, err = capsys.readouterr()
assert out == 'foo\n'
assert err == 'bar\n'
在Python 3.4.3上使用py.test 2.7.0运行时产生以下输出:
def test_capsys(capsys):
print('foo')
print('bar', file=stderr)
out, err = capsys.readouterr()
assert out == 'foo\n'
> assert err == 'bar\n'
E assert '' == 'bar\n'
E + bar
test_capsys.py:10: AssertionError
----------------------------- Captured stderr call -----------------------------
bar
奇怪的是py.test报告错误流的正确内容,但是capsys似乎没有捕获它.难道我做错了什么?这是一个错误吗?
解决方法:
capsys fixture通过将sys.stderr替换为它自己的虚拟文件对象来工作.在上面给出的代码中,只有在测试导入sys.stderr之后才会发生这种替换,这使得它无用.要解决此问题,可以在测试中导入sys.stderr.
def test_capsys(capsys):
from sys import stderr
print('foo')
print('bar', file=stderr)
out, err = capsys.readouterr()
assert out == 'foo\n'
assert err == 'bar\n'
这个问题在documentation of the unittest.mock
module中有更好的描述.
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。