pytest钩子函数-pytest_runtest_logreport提取测试用例相关信息

问题:想在每个日志中记录测试用例开始结束时间,获取到测试用例的名称。

解决办法:使用钩子pytest_runtest_logreport

pytest中,想要在conftest.py文件中获取正在运行的测试用例的名称,可以使用pytest_runtest_logreport钩子函数。这个钩子函数会在每个测试用例运行之后被调用,并且提供了一个报告对象,其中包含了关于测试用例的各种信息,包括它的名称。

下面是一个如何在conftest.py中使用pytest_runtest_logreport钩子函数来获取并打印正在运行的测试用例名称的示例:

python 复制代码
# conftest.py

def pytest_runtest_logreport(report):
    if report.passed:
        print(f"测试用例 {report.nodeid} 执行成功")
    else:
        print(f"测试用例 {report.nodeid} 执行失败")

在上面的代码中,report.nodeid是测试用例的唯一标识符,它通常包含了测试文件的路径、文件名、测试函数名以及任何参数化信息。如果只关心测试函数的名称,您可以使用report.nodeid.split('::')[-1]来获取它。

例如,如果想要仅打印测试函数的名称,可以这样做:

python 复制代码
# conftest.py

def pytest_runtest_logreport(report):
    test_name = report.nodeid.split('::')[-1]
    if report.passed:
        print(f"开始执行测试用例: {test_name}")
    else:
        print(f"测试用例 {test_name} 执行失败")

    # 在测试用例结束后打印
    print(f"测试用例 {test_name} 已执行结束")

请注意,pytest_runtest_logreport钩子函数会在每个测试用例运行之后立即调用,包括那些由于某种原因(如前置条件失败)而被跳过的测试用例。因此,如果只想在真正执行的测试用例之后打印信息,可能需要检查report.outcome属性来确定测试用例的状态。

另外,这种方法打印的信息可能会在测试摘要和其他输出中混合,如果想要更精细地控制输出格式或位置,可能需要使用其他钩子函数或插件功能。

在控制台加了这个钩子后,可以很明显看出哪个用例失败了

相关推荐
Madison-No712 分钟前
【Linux】自动化构建工具--make/Makefile
linux·运维·服务器
TG:@yunlaoda360 云老大2 小时前
腾讯云国际站代理商:腾讯云负载均衡的健康探测源IP,我该如何诊断和配置?
服务器·云计算·腾讯云
susu10830189112 小时前
FAT32/VFAT 文件系统不支持 Linux 文件权限,cp文件总是异常
linux·运维·服务器
絔离3 小时前
Linux下查看系统启动时间、运行时间
linux·运维·服务器
落羽的落羽4 小时前
【Linux系统】从零掌握make与Makefile:高效自动化构建项目的工具
linux·服务器·开发语言·c++·人工智能·机器学习·1024程序员节
TG:@yunlaoda360 云老大4 小时前
腾讯云国际站WAF:如何在腾讯云WAF上设置CC攻击防护,以保障业务数据免被恶意爬取?
服务器·云计算·腾讯云
shao9185165 小时前
Gradio全解14——使用Gradio构建MCP的服务器与客户端(4)——Python包命令:uv与uvx实战
pytest·uv·1024程序员节·npx·uvx·uv pip·ruff
Mr.H01275 小时前
gitbash链接远程仓库时,出现的ssh密钥链接问题
运维·服务器·ssh·bash
wanhengidc5 小时前
云手机是一种应用软件吗?
运维·服务器·网络·游戏·智能手机·1024程序员节
wanhengidc6 小时前
云手机 无限畅玩手游 巨 椰
运维·服务器·网络·游戏·智能手机