gpt4 book ai didi

python - 如何让 PyC​​harm 显示来自 pytest 的整个错误差异?

转载 作者:IT老高 更新时间:2023-10-28 20:48:13 27 4
gpt4 key购买 nike

我正在使用 Pycharm运行我的pytest单元测试。我正在测试一个 REST API,所以我经常需要验证 JSON block 。当测试失败时,我会看到如下内容:

FAILED
test_document_api.py:0 (test_create_documents)
{'items': [{'i...ages': 1, ...} != {'items': [{'...ages': 1, ...}

Expected :{'items': [{'...ages': 1, ...}
Actual :{'items': [{'i...ages': 1, ...}
<Click to see difference>

当我点击“点击查看差异”链接时,大部分差异都会转换为椭圆的点,就像这样

Pycharm comparison with differences elided

这是没用的,因为它没有告诉我有什么不同。对于大于单个字符串或数字的任何差异,我都会得到这种行为。

我假设 Pycharm 和/或 pytest 试图省略大输出差异的无信息部分。但是,这里太激进了,什么都忽略了。

如何让 Pycharm 和/或 pytest 向我展示全部差异?

我尝试将 -vvv 添加到 pytest 的附加参数中,但没有效果。


自从原始帖子以来,我验证了当我从命令行运行单元测试时,我看到了相同的行为。所以这是 pytest 而不是 Pycharm 的问题。

查看到目前为止我得到的答案后,我想我真正要问的是“在 pytest 中是否可以在不更改测试源代码的情况下设置 maxDiff=None ? "我从阅读 pytest 中得到的印象是 -vv 开关控制着这个设置,但事实并非如此。

最佳答案

If you look closely into PyCharm sources , 来自整个 pytest输出,PyCharm 使用单行解析数据以显示在 Click to see difference对话。这是AssertionError: <message>行:

def test_spam():
> assert v1 == v2
<b>E AssertionError: assert {'foo': 'bar'} == {'foo': 'baz'}</b>
E Differing items:
E {'foo': 'bar'} != {'foo': 'baz'}
E Use -v to get the full diff

如果您想查看不截断的完整差异行,您需要在输出中自定义此行。对于单个测试,这可以通过向 assert 添加自定义消息来完成。声明:

def test_eggs():
assert a == b, '{0} != {1}'.format(a, b)

如果您想将此行为应用于所有测试,请定义自定义 pytest_assertrepr_compare 钩。在 conftest.py文件:

# conftest.py
def pytest_assertrepr_compare(config, op, left, right):
if op in ('==', '!='):
return ['{0} {1} {2}'.format(left, op, right)]

值的相等比较现在仍然会在太长时被剥离;要显示完整的行,您仍然需要使用 -vv 增加详细程度标志。

现在比较 AssertionError 中的值行不会被剥离,完整的差异显示在 Click to see difference对话框,突出显示差异部分:

enter image description here

关于python - 如何让 PyC​​harm 显示来自 pytest 的整个错误差异?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/50608443/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com