微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

python – 使用py.tests capys捕获stderr

我试图使用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] 举报,一经查实,本站将立刻删除。

相关推荐