pytest教程-45-钩子函数-pytest_report_testitemFinished

news2025/1/24 11:48:18

领取资料,咨询答疑,请➕wei:  June__Go

上一小节我们学习了pytest_report_collectionfinish钩子函数的使用方法,本小节我们讲解一下pytest_report_testitemFinished钩子函数的使用方法。

pytest_report_testitemFinished 钩子函数在每个测试项(测试函数或测试方法)执行完成后被调用。这个钩子可以用来获取测试结果、执行自定义的报告逻辑,或者在测试结束后进行一些清理工作。以下是一个具体的代码示例,展示了如何在 conftest.py 文件中使用这个钩子函数:

# conftest.py

import pytest

# 全局变量用于存储测试结果
test_results = {}

def pytest_report_testitemFinished(item, report):
    # 获取测试项的名称和结果
    test_name = item.name
    test_result = report.outcome

    # 将测试结果存储在全局字典中
    test_results[test_name] = test_result

    # 根据测试结果执行不同的操作
    if test_result == "passed":
        print(f"{test_name} passed.")
    elif test_result == "failed":
        print(f"{test_name} failed.")
        print(f"Failure details: {report.longrepr}")
    elif test_result == "skipped":
        print(f"{test_name} skipped.")
    else:
        print(f"{test_name} had an unknown outcome: {test_result}")

    # 如果需要,可以在这里执行一些清理工作,例如关闭资源
    # ...

# 在测试运行结束时,可以输出所有测试结果
def pytest_sessionfinish(session, exitstatus):
    # 输出所有测试项的结果
    for test_name, result in test_results.items():
        print(f"{test_name}: {result}")

    # 清空测试结果字典,为下一次测试会话做准备
    test_results.clear()

在这个示例中,我们首先定义了一个全局字典 test_results 来存储每个测试项的名称和结果。在 pytest_report_testitemFinished 钩子函数中,我们根据测试结果的 outcome 属性(可以是 "passed"、"failed"、"skipped" 或其他值)来执行不同的操作。例如,我们可以打印出失败的测试项的详细信息。

我们还定义了一个 pytest_sessionfinish 钩子函数,在测试会话结束时输出所有测试项的结果,并清空 test_results 字典,以便为下一次测试会话做准备。

请注意,这个示例中的代码仅用于演示如何使用 pytest_report_testitemFinished 钩子函数来处理测试结果。在实际应用中,你可能需要根据具体的测试需求来调整这些操作,例如生成更详细的测试报告或者执行更复杂的后处理逻辑。

在这个复杂的示例中,我们将使用 pytest_report_testitemFinished 钩子函数来实现一个更高级的测试结果处理流程。我们将在测试用例完成后收集详细的结果信息,包括执行时间、断言结果、异常信息等,并在测试会话结束时生成一个详细的测试报告。此外,我们还将展示如何使用 pytest_sessionfinish 钩子函数来执行测试后的清理工作。

首先,确保你的项目中有一个 conftest.py 文件。然后,在 conftest.py 文件中定义 pytest_report_testitemFinishedpytest_sessionfinish 钩子函数:

# conftest.py

import pytest
import json
from datetime import datetime

# 全局变量用于存储测试结果
test_results = {}

def pytest_report_testitemFinished(item, report):
    # 获取测试项的名称和结果
    test_name = item.name
    test_result = report.outcome

    # 获取测试执行时间
    execution_time = report.duration

    # 获取断言结果和异常信息
    assert_count = len(report.assertion_list)
    exception_info = report.longrepr if report.failed else None

    # 创建测试结果字典
    test_result_data = {
        'name': test_name,
        'outcome': test_result,
        'duration': execution_time,
        'assert_count': assert_count,
        'exception_info': exception_info
    }

    # 将测试结果存储在全局字典中
    test_results[test_name] = test_result_data

    # 根据测试结果执行不同的操作
    if test_result == "passed":
        print(f"{test_name} passed in {execution_time:.2f} seconds.")
    elif test_result == "failed":
        print(f"{test_name} failed in {execution_time:.2f} seconds.")
        if exception_info:
            print(f"Exception: {exception_info}")
    elif test_result == "skipped":
        print(f"{test_name} skipped.")

def pytest_sessionfinish(session, exitstatus):
    # 获取当前时间戳
    timestamp = datetime.now().strftime("%Y-%m-%d %H:%M:%S")

    # 创建测试报告文件
    report_file = f"pytest_test_report_{timestamp}.json"

    # 将测试结果写入 JSON 文件
    with open(report_file, 'w') as json_report:
        json.dump(test_results, json_report, indent=4)

    # 打印报告文件的路径
    print(f"\nTest report saved to: {os.path.abspath(report_file)}")

    # 执行清理工作,例如关闭数据库连接或网络资源
    # ...

    # 清空测试结果字典,为下一次测试会话做准备
    test_results.clear()

在这个示例中,我们在 pytest_report_testitemFinished 钩子函数中收集了每个测试用例的详细信息,包括名称、结果、执行时间、断言数量和异常信息。我们将这些信息存储在全局字典 test_results 中,并根据测试结果打印相应的信息。

pytest_sessionfinish 钩子函数中,我们创建了一个 JSON 文件来保存所有测试用例的结果。这个文件包含了所有测试用例的详细信息,可以用于后续的分析或报告生成。我们还打印了报告文件的路径,以便用户可以轻松地找到它。

请注意,这个示例中的代码仅用于演示如何使用 pytest_report_testitemFinishedpytest_sessionfinish 钩子函数来处理测试结果和生成报告。在实际应用中,你可能需要根据具体的测试需求来调整这些操作,例如生成不同格式的报告或者执行更复杂的后处理逻辑。

最后感谢每一个认真阅读我文章的人,礼尚往来总是要有的,虽然不是什么很值钱的东西,如果你用得到的话可以直接拿走,希望可以帮助到大家!领取资料,咨询答疑,请➕wei:  June__Go

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1672230.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

7天精通Web APIs——正则阶段案例(理论+实战)(第六天)

正则表达式的定义和使用 定义:是一种匹配模式,用于匹配字符串中字符组合 作用:表单验证(匹配)、过滤敏感词(替换)、字符串中提取我们想要的部分(提取) 使用分为两步&…

MySQL-InnoDB数据存储结构

1、存储结构-页 索引结构提供了高效的索引方式,索引信息以及数据记录都保存在数据文件或索引文件中(本质存储在页结构中) 1.1、磁盘与内存交互的基本单位:页 在InnoDB中将数据划分为若干页,页的默认大小为&#xff…

SQLZOO:The JOIN operation

数据表:game-gaol-eteam game idmdatestadiumteam1team210018 June 2012National Stadium, WarsawPOLGRE10028 June 2012Stadion Miejski (Wroclaw)RUSCZE100312 June 2012Stadion Miejski (Wroclaw)GRECZE100412 June 2012National Stadium, WarsawPOLRUS... goal …

@游戏行业er!MongoDB广州线下沙龙邀您报名!

随着游戏和应用程序的发展,数据变得越来越重要。在为您的下一个游戏选择数据库时,数据库管理者常常会面对灵活性、可扩展性、可靠性、运营效率等问题或挑战。 MongoDB在游戏开发领域有着广泛的应用,灵活数据模型可以存储和处理各种类型的数据…

C++--String类

系列文章目录 文章目录 目录 系列文章目录 文章目录 前言 一、为什么要学习string 1.c语言的字符串 2.OJ上的使用 二、string类的接口介绍 1.string简介 2.string构造成员函数 3.operator函数 4.string容器size和length 5.重载operator[]和引用返回的意义 5.1 oper…

嫦娥六号揭秘真相:阿波罗登月是真是假?一文终结所有疑问!

近期,嫦娥六号的成功发射如同璀璨的星辰,再次将人们的视线聚焦于浩瀚的宇宙,与此同时,网络上关于美国阿波罗登月是否造假的争议也如潮水般涌现。一些声音宣称,嫦娥六号的发射为揭示美国阿波罗登月任务的真实性提供了关…

Java面试八股之String类的常用方法有哪些

Java中String类的常用方法有哪些 获取字符串信息: length():返回字符串的字符数。 isEmpty():判断字符串是否为空(即长度为0)。 访问单个字符: charAt(int index):返回指定索引处的字符。 …

InstantStyle —— 文本到图像生成中的风格保持新突破

在人工智能领域,文本到图像生成(Text-to-Image Generation)技术正迅速发展,其应用范围从娱乐到专业设计不断扩展。然而,风格一致性生成一直是该领域的一个技术难题。最近,InstantX团队提出了一种名为Instan…

GEVernova推出GEV新能源平台,引领新能源未来

近日,全球领先的能源设备制造和服务公司 GE Vernova 宣布推出 GEV 新能源平台,这是一个将金融、科技和产业深度融合的全新投资平台。GEV 新能源平台旨在为用户提供一站式可持续新能源投资解决方案,助力全球新能源转型和可持续发展。 新能源已…

vs-qt中无法加载qsqlite驱动,但是单独新建demo测试却又是正常的。。。

开发环境: Vs2015 + qt5.12 背景: 接手了一个项目,可以编译过去,也可以运行,, 但是登录一直失败,,但是数据库文件也是正常的。。。 最主要的是环境和同事的是一样的,,,但是他那边可以加载成功,我这边不可以。。 后来单独在vs中创建了一个demo,用来测试QSqlData…

如何高效管理微信?快速掌握捷径!

对于那些需要管理多个微信号的人来说,如何高效地管理这些账号成为了一个难题。今天,就给大家分享一个管理多个微信号的捷径——微信管理系统。 通过微信管理系统,你可以轻松实现高效管理多个微信号,一起来看看吧! 首…

一文汇总对比英伟达、AMD、英特尔显卡GPU

‍‍🏡博客主页: virobotics(仪酷智能):LabVIEW深度学习、人工智能博主 📑上期文章:『【仪酷LabVIEW AI工具包案例】使用LabVIEW AI工具包YOLOv5结合Dobot机械臂实现智能垃圾分类』 🍻本文由virobotics(仪酷…

C语言/数据结构——每日一题(环形链表)

一.前言 今天在力扣上刷到一道链表题——环形链表https://leetcode.cn/problems/linked-list-cycle 想着和大家们分享一下。让我们直接开始今天的分享吧。、 二.正文 1.1题目描述 1.2题目分析 这道题是想让我们做出分析,该链表是不是带环链表,如果是…

mac定时任务、自启动任务

https://quail.ink/mynotes/p/mac-startup-configuration-detailed-explanation <?xml version"1.0" encoding"UTF-8"?> <!DOCTYPE plist PUBLIC "-//Apple//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.d…

DIFT:Emergent Correspondence from Image Diffusion # 论文阅读

URL https://arxiv.org/pdf/2306.03881 主页&#xff1a;https://diffusionfeatures.github.io/ 代码&#xff1a;https://github.com/Tsingularity/dift TD;DR 23 年 6月 cornell 大学的文章&#xff0c;任务是做图片的特征匹配&#xff08;关联&#xff09;&#xff0c;特…

Github入门10问,收藏~

Github是Python开发中最常用到的工具和资源&#xff0c;Github上Python相关的仓库多达300多万个&#xff0c;但有很多人还不知道怎么去使用Github&#xff0c;这里来通过10个问题来科普下。 什么是GitHub&#xff1f;为什么要学习使用GitHub&#xff1f;如何创建GitHub账户&…

VTK —— 三、标准格式 - 示例1 - 读取建模不同格式模型(支持.ply、.vtp、.obj、.stl、.vtk、.g等模型格式)(附完整源码)

代码效果 本代码编译运行均在如下链接文章生成的库执行成功&#xff0c;若无VTK库则请先参考如下链接编译vtk源码&#xff1a; VTK —— 一、Windows10下编译VTK源码&#xff0c;并用Vs2017代码测试&#xff08;附编译流程、附编译好的库、vtk测试源码&#xff09; 教程描述 本…

宝塔面板各种疑难杂症处理命令教程

下载地址&#xff1a;宝塔面板各种疑难杂症处理命令教程 这份宝塔面板各种疑难杂症处理命令教程&#xff0c;可以解决市面上遇到的各种难题&#xff0c;建议有技术能行的下载使用&#xff0c;小白也可以下载来学习可以帮助你解决宝塔面板遇到的各种难题

Java面试八股之什么是Java反射

什么是Java反射 基本概念 反射是Java语言的一个重要特性&#xff0c;它允许我们在运行时分析类、接口、字段、方法等组件的信息&#xff0c;并能够动态地操作这些组件&#xff0c;包括创建对象、调用方法、访问和修改字段值等。简单来说&#xff0c;反射提供了在程序运行时对…

镊子蜡烛如何抓住反转进行交易?昂首资本2步抓住反转

很多投资者通过之前的文章知道镊子烛台图&#xff0c;甚至可以通过镊子烛台图有多倍收益&#xff0c;但是很多投资者又迷惑了&#xff0c;为什么我没有通过镊子烛台图获得收益&#xff0c;甚至有时还会亏损收手。其实事情很容易理解&#xff0c;Anzo Capital昂首资本认为那是因…