如何在 py.test 运行结束时获取 TestReports 列表?

Ale*_*lex 5 python pytest

我想在所有测试结束时获得所有测试的列表(例如以 py.test TestReport 的形式)。

我知道这pytest_runtest_makereport会做类似的事情,但仅限于一次测试。但是我想conftest.pypy.test应用程序终止之前实现一个钩子或其他东西来处理整个测试列表。

有没有办法做到这一点?

Dan*_*har 5

这是一个可以帮助您的示例。文件结构:

/example:
   __init__.py  # empty file
   /test_pack_1
      __init__.py # empty file
      conftest.py # pytest hooks
      test_my.py  # a few tests for demonstration
Run Code Online (Sandbox Code Playgroud)

有 2 个测试test_my.py

def test_one():
    assert 1 == 1
    print('1==1')


def test_two():
    assert 1 == 2
    print('1!=2')
Run Code Online (Sandbox Code Playgroud)

示例conftest.py

import pytest
from _pytest.runner import TestReport
from _pytest.terminal import TerminalReporter


@pytest.hookimpl(hookwrapper=True)
def pytest_terminal_summary(terminalreporter):  # type: (TerminalReporter) -> generator
    yield
    # you can do here anything - I just print report info
    print('*' * 8 + 'HERE CUSTOM LOGIC' + '*' * 8)

    for failed in terminalreporter.stats.get('failed', []):  # type: TestReport
        print('failed! node_id:%s, duration: %s, details: %s' % (failed.nodeid,
                                                                 failed.duration,
                                                                 str(failed.longrepr)))

    for passed in terminalreporter.stats.get('passed', []):  # type: TestReport
        print('passed! node_id:%s, duration: %s, details: %s' % (passed.nodeid,
                                                                 passed.duration,
                                                                 str(passed.longrepr)))
Run Code Online (Sandbox Code Playgroud)

文件说pytest_terminal_summary退出状态ARG

运行测试而无需任何其他选项:py.test ./example. 输出示例:

example/test_pack_1/test_my.py .F
********HERE CUSTOM LOGIC********
failed! node_id:test_pack_1/test_my.py::test_two, duration: 0.000385999679565, details: def test_two():
>       assert 1 == 2
E       assert 1 == 2

example/test_pack_1/test_my.py:7: AssertionError
passed! node_id:test_pack_1/test_my.py::test_one, duration: 0.00019907951355, details: None

=================================== FAILURES ===================================
___________________________________ test_two ___________________________________

    def test_two():
>       assert 1 == 2
E       assert 1 == 2

example/test_pack_1/test_my.py:7: AssertionError
====================== 1 failed, 1 passed in 0.01 seconds ======================
Run Code Online (Sandbox Code Playgroud)

希望这可以帮助。

笔记!确保在运行测试之前删除了 .pyc 文件