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

2024-05-14 02:20

本文主要是介绍pytest教程-45-钩子函数-pytest_report_testitemFinished,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

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

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

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

# conftest.pyimport pytest# 全局变量用于存储测试结果
test_results = {}def pytest_report_testitemFinished(item, report):# 获取测试项的名称和结果test_name = item.nametest_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.pyimport pytest
import json
from datetime import datetime# 全局变量用于存储测试结果
test_results = {}def pytest_report_testitemFinished(item, report):# 获取测试项的名称和结果test_name = item.nametest_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

这篇关于pytest教程-45-钩子函数-pytest_report_testitemFinished的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/987479

相关文章

Python函数作用域与闭包举例深度解析

《Python函数作用域与闭包举例深度解析》Python函数的作用域规则和闭包是编程中的关键概念,它们决定了变量的访问和生命周期,:本文主要介绍Python函数作用域与闭包的相关资料,文中通过代码... 目录1. 基础作用域访问示例1:访问全局变量示例2:访问外层函数变量2. 闭包基础示例3:简单闭包示例4

全网最全Tomcat完全卸载重装教程小结

《全网最全Tomcat完全卸载重装教程小结》windows系统卸载Tomcat重新通过ZIP方式安装Tomcat,优点是灵活可控,适合开发者自定义配置,手动配置环境变量后,可通过命令行快速启动和管理... 目录一、完全卸载Tomcat1. 停止Tomcat服务2. 通过控制面板卸载3. 手动删除残留文件4.

Python中isinstance()函数原理解释及详细用法示例

《Python中isinstance()函数原理解释及详细用法示例》isinstance()是Python内置的一个非常有用的函数,用于检查一个对象是否属于指定的类型或类型元组中的某一个类型,它是Py... 目录python中isinstance()函数原理解释及详细用法指南一、isinstance()函数

python中的高阶函数示例详解

《python中的高阶函数示例详解》在Python中,高阶函数是指接受函数作为参数或返回函数作为结果的函数,下面:本文主要介绍python中高阶函数的相关资料,文中通过代码介绍的非常详细,需要的朋... 目录1.定义2.map函数3.filter函数4.reduce函数5.sorted函数6.自定义高阶函数

Python的pandas库基础知识超详细教程

《Python的pandas库基础知识超详细教程》Pandas是Python数据处理核心库,提供Series和DataFrame结构,支持CSV/Excel/SQL等数据源导入及清洗、合并、统计等功能... 目录一、配置环境二、序列和数据表2.1 初始化2.2  获取数值2.3 获取索引2.4 索引取内容2

Python中的sort方法、sorted函数与lambda表达式及用法详解

《Python中的sort方法、sorted函数与lambda表达式及用法详解》文章对比了Python中list.sort()与sorted()函数的区别,指出sort()原地排序返回None,sor... 目录1. sort()方法1.1 sort()方法1.2 基本语法和参数A. reverse参数B.

python依赖管理工具UV的安装和使用教程

《python依赖管理工具UV的安装和使用教程》UV是一个用Rust编写的Python包安装和依赖管理工具,比传统工具(如pip)有着更快、更高效的体验,:本文主要介绍python依赖管理工具UV... 目录前言一、命令安装uv二、手动编译安装2.1在archlinux安装uv的依赖工具2.2从github

C#实现SHP文件读取与地图显示的完整教程

《C#实现SHP文件读取与地图显示的完整教程》在地理信息系统(GIS)开发中,SHP文件是一种常见的矢量数据格式,本文将详细介绍如何使用C#读取SHP文件并实现地图显示功能,包括坐标转换、图形渲染、平... 目录概述功能特点核心代码解析1. 文件读取与初始化2. 坐标转换3. 图形绘制4. 地图交互功能缩放

Python函数的基本用法、返回值特性、全局变量修改及异常处理技巧

《Python函数的基本用法、返回值特性、全局变量修改及异常处理技巧》本文将通过实际代码示例,深入讲解Python函数的基本用法、返回值特性、全局变量修改以及异常处理技巧,感兴趣的朋友跟随小编一起看看... 目录一、python函数定义与调用1.1 基本函数定义1.2 函数调用二、函数返回值详解2.1 有返

Python Excel 通用筛选函数的实现

《PythonExcel通用筛选函数的实现》本文主要介绍了PythonExcel通用筛选函数的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着... 目录案例目的示例数据假定数据来源是字典优化:通用CSV数据处理函数使用说明使用示例注意事项案例目的第一