渣渣兔 发表于 2025-1-7 18:02:32

深入明确 pytest_runtest_makereport:怎样在 pytest 中自定义测试陈诉

pytest_runtest_makereport 是 pytest 系统中的一个钩子函数,它答应我们在测试执行时获取测试的陈诉信息。通过这个钩子,我们可以在测试运行时(无论是成功、失败还是跳过)对测试结果进一步处理,好比记载日志、添加自定义信息、天生陈诉等。
1、pytest_runtest_makereport 的作用
pytest_runtest_makereport 会在每个测试执行完成后被调用,并天生一个 TestReport 对象。这个对象包罗了测试的执行结果,通常包括:
测试名称:测试的名称
执行结果:测试是成功(passed)、失败(failed)、跳过(skipped)还是标记为 Xfail(预期失败)
异常信息:如果测试失败或有异常,这里会包罗异常的相关信息
执行时长:测试执行的时间
模块和函数信息:测试的模块、类、函数等
该钩子可以在每次测试完成后天生自定义陈诉或执行其他自定义操作。
2、使用 pytest_runtest_makereport
要使用 pytest_runtest_makereport,需要将它放在 conftest.py 文件中。
比方:记载每个测试的执行结果并天生日志
在 conftest.py 中定义 pytest_runtest_makereport 钩子:
@pytest.hookimpl(tryfirst=True, hookwrapper=True)
def pytest_runtest_makereport(item, call):
    outcome = yield
    rep = outcome.get_result()

    if rep.when == 'call':
      if rep.failed:
            logger.error(f"Test {item.nodeid}: FAILED\n")

            if call.excinfo:
                error_message = str(call.excinfo.value)
                logger.error(f"Test {item.nodeid} failed with error: {error_message}\n")
                print('这是error_message:', error_message)

      elif rep.skipped:
            outcome_status = 'SKIPPED'
            logger.info(f"Test {item.nodeid}: {outcome_status}\n")
      else:
            outcome_status = 'PASSED'
            logger.info(f"Test {item.nodeid}: {outcome_status}\n") 3、钩子函数的参数
pytest_runtest_makereport 吸收两个参数:
item:表现当前的测试项(pytest.Item 对象),它包罗了测试的相关信息,如测试名称、模块、类、函数等。
call:表现测试执行的结果。它是一个包罗执行过程信息的对象,通常具有以部属性:
call.excinfo:如果测试失败或堕落,这里会包罗异常信息。
call.result:测试的返回结果(仅在测试通过时有效)。
4、天生具体陈诉
可以使用 pytest_runtest_makereport 来天生更具体的测试陈诉。好比,将失败的测试详情写入到文件中,大概在每次测试后天生 HTML、JSON 等格式的陈诉。
比方:记载失败测试并输出到文件
# conftest.py

import pytest

def pytest_runtest_makereport(item, call):
    # 生成测试报告
    report = pytest.TestReport(item)
   
    # 如果测试失败,将失败信息写入到文件
    if report.failed:
      with open('failed_tests.log', 'a') as f:
            f.write(f"Test {item.nodeid} failed with error: {call.excinfo}\n")
5、获取具体的 TestReport 对象
pytest_runtest_makereport 默认返回的是一个 TestReport 对象,这个对象包罗了很多关于测试的信息。可以使用它来定制测试陈诉。
TestReport 对象的常用属性包括:
nodeid:测试的标识符(通常是文件路径 + 测试函数名称)。
outcome:测试结果,可以是 'passed', 'failed', 'skipped' 等。
longrepr:如果测试失败,这里包罗了失败的具体信息(比方堆栈跟踪)。
duration:测试的执行时长。
when:指示测试在何时执行。值可以是 'setup', 'call', 'teardown' 等,通常 call 是我们关心的测试执行阶段。
比方:打印具体的测试结果 
# conftest.py

import pytest

def pytest_runtest_makereport(item, call):
    report = pytest.TestReport(item)
   
    print(f"Test {item.nodeid} executed.")
    print(f"Outcome: {report.outcome}")
    print(f"Duration: {report.duration}")
   
    if report.outcome == 'failed':
      print(f"Failure details: {report.longrepr}")
【总结】
pytest_runtest_makereport 是一个强大的钩子函数,可以定制和扩展 pytest 的测试陈诉系统。通过该钩子,可以访问每个测试的具体结果,并在测试完成后执行自定义操作。这对于天生陈诉、日志记载、失败处理等非常有效。如果在使用 pytest 时需要更具体的陈诉或日志记载,pytest_runtest_makereport 是一个非常实用的工具。

免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。
页: [1]
查看完整版本: 深入明确 pytest_runtest_makereport:怎样在 pytest 中自定义测试陈诉