pytest教程-43-钩子函数-pytest_report_header

2024-05-09 22:52

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

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

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

pytest_report_header 钩子函数允许你在 pytest 的终端报告的头部添加自定义信息。这个钩子在生成报告时被调用,通常用于显示测试环境的配置信息、版本信息或其他重要的上下文信息。

以下是一个具体的代码示例,展示了如何在 conftest.py 文件中使用 pytest_report_header 钩子函数:

# conftest.pyimport pytestdef pytest_report_header(config):# 获取 pytest 配置信息env = config.get('env', {})version = env.get('MY_APP_VERSION', 'unknown')platform = env.get('MY_PLATFORM', 'unknown')# 创建自定义的报告头部信息header_info = (f"Testing Environment:\n"f"  Application Version: {version}\n"f"  Platform: {platform}\n"f"  Start Time: {time.ctime()}\n")# 返回自定义的报告头部信息return header_info# 你可以在 pytest.ini 文件中设置环境变量,例如:
# [pytest]
# env = MY_APP_VERSION=1.0.0
# env = MY_PLATFORM=development

在这个示例中,我们首先从 config 对象中获取环境变量,这些环境变量包含了应用版本和平台信息。然后,我们创建了一个包含这些信息的字符串,作为自定义的报告头部信息。最后,我们返回这个字符串,它将在 pytest 的终端报告头部显示。

请注意,为了使这个示例工作,你需要在 pytest.ini 文件中设置相应的环境变量,或者在命令行中使用 --env 参数来设置它们。这样,当你运行测试时,pytest_report_header 钩子函数就会读取这些环境变量,并在报告头部显示相应的信息。

这个示例展示了如何使用 pytest_report_header 钩子函数来增强 pytest 的报告,使其包含更多关于测试环境的信息。在实际应用中,你可以根据需要添加或修改头部信息的内容。

在这个更复杂的示例中,我们将使用 pytest_report_header 钩子函数来展示如何集成多个源的信息,包括环境变量、系统信息和自定义的测试统计数据。我们将在 pytest 的报告头部显示这些信息,以便为测试提供更多的上下文。

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

# conftest.pyimport pytest
import os
import platform
import time
from collections import defaultdict# 假设我们有一个自定义的统计器来跟踪测试结果
class TestStatistics:def __init__(self):self.passed = 0self.failed = 0self.skipped = 0def increment(self, result):if result == "passed":self.passed += 1elif result == "failed":self.failed += 1elif result == "skipped":self.skipped += 1def summary(self):return {"passed": self.passed,"failed": self.failed,"skipped": self.skipped}# 全局统计器实例
test_statistics = TestStatistics()def pytest_runtest_logreport(report):# 更新测试统计数据if report.passed:test_statistics.increment("passed")elif report.failed:test_statistics.increment("failed")elif report.skipped:test_statistics.increment("skipped")def pytest_report_header(config):# 获取系统信息system_info = platform.platform()# 获取环境变量env_vars = ", ".join([f"{key}={value}" for key, value in os.environ.items() if key.startswith('TEST_')])# 获取自定义的测试统计数据stats_summary = test_statistics.summary()# 创建自定义的报告头部信息header_info = (f"Testing Report Header\n"f"System: {system_info}\n"f"Environment Variables: {env_vars}\n"f"Test Statistics:\n"f"   Passed: {stats_summary['passed']}\n"f"   Failed: {stats_summary['failed']}\n"f"   Skipped: {stats_summary['skipped']}\n"f"   Total: {stats_summary['passed'] + stats_summary['failed'] + stats_summary['skipped']}\n"f"Start Time: {time.ctime()}\n")# 返回自定义的报告头部信息return header_info# 在 pytest 运行结束时重置统计器
def pytest_sessionfinish(session, exitstatus):test_statistics = TestStatistics()

在这个示例中,我们首先定义了一个 TestStatistics 类来跟踪测试结果。在每个测试用例执行后,我们通过 pytest_runtest_logreport 钩子函数更新统计数据。

然后,在 pytest_report_header 钩子函数中,我们收集了系统信息、环境变量和自定义的测试统计数据。我们将这些信息组合成一个多行字符串,作为报告的头部信息。这个字符串包含了系统平台、环境变量、测试统计数据和测试开始时间。

请注意,为了使这个示例工作,你需要在 pytest.ini 文件中设置相应的环境变量,或者在命令行中使用 --env 参数来设置它们。此外,你可能需要在测试运行结束后重置统计器,以避免在连续运行多个测试时统计数据相互干扰。

这个示例展示了如何使用 pytest_report_header 钩子函数来创建一个包含丰富信息的测试报告头部。在实际应用中,你可以根据需要添加或修改头部信息的内容,以及如何集成和展示测试统计数据。

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

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



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

相关文章

Elasticsearch 在 Java 中的使用教程

《Elasticsearch在Java中的使用教程》Elasticsearch是一个分布式搜索和分析引擎,基于ApacheLucene构建,能够实现实时数据的存储、搜索、和分析,它广泛应用于全文... 目录1. Elasticsearch 简介2. 环境准备2.1 安装 Elasticsearch2.2 J

Linux系统中卸载与安装JDK的详细教程

《Linux系统中卸载与安装JDK的详细教程》本文详细介绍了如何在Linux系统中通过Xshell和Xftp工具连接与传输文件,然后进行JDK的安装与卸载,安装步骤包括连接Linux、传输JDK安装包... 目录1、卸载1.1 linux删除自带的JDK1.2 Linux上卸载自己安装的JDK2、安装2.1

Kotlin 作用域函数apply、let、run、with、also使用指南

《Kotlin作用域函数apply、let、run、with、also使用指南》在Kotlin开发中,作用域函数(ScopeFunctions)是一组能让代码更简洁、更函数式的高阶函数,本文将... 目录一、引言:为什么需要作用域函数?二、作用域函China编程数详解1. apply:对象配置的 “流式构建器”最

Linux卸载自带jdk并安装新jdk版本的图文教程

《Linux卸载自带jdk并安装新jdk版本的图文教程》在Linux系统中,有时需要卸载预装的OpenJDK并安装特定版本的JDK,例如JDK1.8,所以本文给大家详细介绍了Linux卸载自带jdk并... 目录Ⅰ、卸载自带jdkⅡ、安装新版jdkⅠ、卸载自带jdk1、输入命令查看旧jdkrpm -qa

Java使用Curator进行ZooKeeper操作的详细教程

《Java使用Curator进行ZooKeeper操作的详细教程》ApacheCurator是一个基于ZooKeeper的Java客户端库,它极大地简化了使用ZooKeeper的开发工作,在分布式系统... 目录1、简述2、核心功能2.1 CuratorFramework2.2 Recipes3、示例实践3

springboot简单集成Security配置的教程

《springboot简单集成Security配置的教程》:本文主要介绍springboot简单集成Security配置的教程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,... 目录集成Security安全框架引入依赖编写配置类WebSecurityConfig(自定义资源权限规则

MySQL Workbench 安装教程(保姆级)

《MySQLWorkbench安装教程(保姆级)》MySQLWorkbench是一款强大的数据库设计和管理工具,本文主要介绍了MySQLWorkbench安装教程,文中通过图文介绍的非常详细,对大... 目录前言:详细步骤:一、检查安装的数据库版本二、在官网下载对应的mysql Workbench版本,要是

Android Kotlin 高阶函数详解及其在协程中的应用小结

《AndroidKotlin高阶函数详解及其在协程中的应用小结》高阶函数是Kotlin中的一个重要特性,它能够将函数作为一等公民(First-ClassCitizen),使得代码更加简洁、灵活和可... 目录1. 引言2. 什么是高阶函数?3. 高阶函数的基础用法3.1 传递函数作为参数3.2 Lambda

通过Docker Compose部署MySQL的详细教程

《通过DockerCompose部署MySQL的详细教程》DockerCompose作为Docker官方的容器编排工具,为MySQL数据库部署带来了显著优势,下面小编就来为大家详细介绍一... 目录一、docker Compose 部署 mysql 的优势二、环境准备与基础配置2.1 项目目录结构2.2 基

Linux安装MySQL的教程

《Linux安装MySQL的教程》:本文主要介绍Linux安装MySQL的教程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录linux安装mysql1.Mysql官网2.我的存放路径3.解压mysql文件到当前目录4.重命名一下5.创建mysql用户组和用户并修