pytest教程-41-钩子函数-pytest_runtest_teardown

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

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

pytest_runtest_teardown 钩子函数在每个测试用例执行完成后被调用,无论是成功、失败还是跳过。这个钩子可以用来执行测试后的清理工作,例如关闭数据库连接、删除临时文件、恢复测试环境到原始状态等。以下是如何使用这个钩子函数的具体方法和代码示例:

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

# conftest.py

import pytest
import logging
from some_database_module import DatabaseConnection, close_connection  # 假设这是我们的数据库操作模块

# 设置日志
logging.basicConfig(level=logging.INFO, format='%(asctime)s - %(levelname)s - %(message)s')

# 假设我们有一个全局数据库连接对象
db_connection = None

def pytest_runtest_teardown(item, nextitem):
    # 在测试用例执行后执行的代码
    logging.info(f"Tearing down after test: {item.name}")
    
    # 关闭数据库连接
    if db_connection and not db_connection.is_closed():
        close_connection(db_connection)
        logging.info("Database connection closed.")
        db_connection = None  # 确保 db_connection 不再被引用

    # 删除测试期间创建的临时文件
    temp_files = ['temp_file1.txt', 'temp_file2.txt']
    for file_name in temp_files:
        try:
            if os.path.exists(file_name):
                os.remove(file_name)
                logging.info(f"Temporary file {file_name} removed.")
        except OSError as e:
            logging.error(f"Failed to remove temporary file {file_name}: {e}")

    # 执行其他清理操作,例如恢复系统状态、清理缓存等
    # ...

    # 如果测试用例失败,记录详细的错误信息
    if item.failed:
        logging.error(f"Test {item.name} failed with the following exceptions:")
        for excinfo in item.trace:
            logging.error(excinfo.get_traceback())

    # 如果测试用例跳过,记录跳过的原因
    if item.skipped:
        logging.info(f"Test {item.name} was skipped: {item.parent.get_closest_marker('skip').arguments[0]}")

# 在测试用例执行前执行的代码
def pytest_runtest_setup(item):
    # 初始化数据库连接
    global db_connection
    db_connection = DatabaseConnection()
    logging.info("Database connection initialized.")

    # 创建测试期间需要的临时文件
    for file_name in ['temp_file1.txt', 'temp_file2.txt']:
        open(file_name, 'w').close()
        logging.info(f"Temporary file {file_name} created.")

在这个示例中,我们在 pytest_runtest_teardown 钩子函数中首先关闭了数据库连接,并删除了测试期间创建的临时文件。我们还记录了测试用例失败时的详细错误信息,以及测试用例被跳过的原因。

pytest_runtest_setup 钩子函数中,我们初始化了数据库连接并创建了临时文件。这些操作在测试用例执行前执行,以确保测试环境准备就绪。

请注意,这个示例中的数据库操作和文件处理都是假设的,你需要根据你的项目实际情况来实现这些功能。这个示例展示了如何在测试用例执行前后执行一系列复杂的操作,并处理可能出现的异常情况。

在这个更复杂的示例中,我们将使用 pytest_runtest_teardown 钩子函数来处理多种情况,包括资源清理、异常捕获、断言验证以及测试结果的记录。我们将模拟一个具有多个资源(如数据库、文件系统、网络服务)的测试环境,并在测试结束后确保所有资源都被正确清理。

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

# conftest.py

import pytest
import logging
import os
import shutil
from some_database_module import DatabaseConnection, close_connection  # 假设这是我们的数据库操作模块
from some_network_module import close_network_connection  # 假设这是我们的网络操作模块

# 设置日志
logging.basicConfig(level=logging.INFO, format='%(asctime)s - %(levelname)s - %(message)s')

# 假设我们有一些全局资源对象
db_connection = None
network_resource = None

def pytest_runtest_teardown(item, nextitem):
    # 在测试用例执行后执行的代码
    logging.info(f"Tearing down after test: {item.name}")
    
    # 关闭数据库连接
    if db_connection and not db_connection.is_closed():
        try:
            close_connection(db_connection)
            logging.info("Database connection closed.")
        except Exception as e:
            logging.error(f"Failed to close database connection: {e}")
    
    # 关闭网络连接
    if network_resource:
        try:
            close_network_connection(network_resource)
            logging.info("Network resource connection closed.")
        except Exception as e:
            logging.error(f"Failed to close network resource: {e}")
    
    # 删除测试期间创建的临时文件和目录
    temp_files = ['temp_file1.txt', 'temp_file2.txt']
    temp_directories = ['temp_directory']
    for file_name in temp_files:
        try:
            if os.path.exists(file_name):
                os.remove(file_name)
                logging.info(f"Temporary file {file_name} removed.")
        except OSError as e:
            logging.error(f"Failed to remove temporary file {file_name}: {e}")
    
    for dir_name in temp_directories:
        try:
            if os.path.exists(dir_name):
                shutil.rmtree(dir_name)
                logging.info(f"Temporary directory {dir_name} removed.")
        except OSError as e:
            logging.error(f"Failed to remove temporary directory {dir_name}: {e}")
    
    # 验证测试结果
    if item.failed:
        logging.error(f"Test {item.name} failed with the following exceptions:")
        for excinfo in item.trace:
            logging.error(excinfo.get_traceback())
    
    # 如果测试用例跳过,记录跳过的原因
    if item.skipped:
        logging.info(f"Test {item.name} was skipped: {item.parent.get_closest_marker('skip').arguments[0]}")

    # 记录测试用例的执行时间
    execution_time = item.duration
    logging.info(f"Test {item.name} executed in {execution_time} seconds.")

# 在测试用例执行前执行的代码
def pytest_runtest_setup(item):
    # 初始化数据库连接
    global db_connection
    db_connection = DatabaseConnection()
    logging.info("Database connection initialized.")

    # 初始化网络资源
    global network_resource
    network_resource = SomeNetworkResource()  # 假设这是我们的网络资源对象
    logging.info("Network resource initialized.")

    # 创建测试期间需要的临时文件和目录
    for file_name in ['temp_file1.txt', 'temp_file2.txt']:
        open(file_name, 'w').close()
        logging.info(f"Temporary file {file_name} created.")
    
    try:
        os.makedirs('temp_directory')
        logging.info("Temporary directory created.")
    except OSError as e:
        logging.error(f"Failed to create temporary directory: {e}")

# 假设的网络资源类
class SomeNetworkResource:
    def __init__(self):
        # 初始化网络资源
        pass

    def close(self):
        # 关闭网络资源
        pass

在这个示例中,我们在 pytest_runtest_teardown 钩子函数中处理了数据库连接和网络资源的关闭,以及临时文件和目录的删除。我们还记录了测试用例的执行时间,并在测试用例失败时记录了详细的错误信息。如果测试用例被跳过,我们也记录了跳过的原因。

pytest_runtest_setup 钩子函数中,我们初始化了数据库连接和网络资源,并创建了临时文件和目录。这些操作在测试用例执行前执行,以确保测试环境准备就绪。

请注意,这个示例中的数据库操作、网络操作和文件处理都是假设的,你需要根据你的项目实际情况来实现这些功能。这个示例展示了如何在测试用例执行前后执行一系列复杂的操作,并处理可能出现的异常情况。同时,它还展示了如何记录测试结果和执行时间,以及如何在测试用例跳过时记录原因。

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

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

游戏辅助 -- 三种分析角色坐标方法(CE、xdbg、龙龙遍历工具)

所用工具下载地址: https://pan.quark.cn/s/d54e7cdc55e6 在上次课程中,我们成功获取了人物对象的基址:[[[0xd75db8]1C]28],而人物血量的地址则是基址再加上偏移量278。 接下来,我们需要执行以下步骤来进一步操作&a…

JSP技术讲解

目录 1、JSP简介 2、JSP体验 3、JSP运行原理 4、JSP基本语法 5、JSP指令 6、JSP内置九大对象 7、JSP标签 8、JSP配置 9、JSP排错 10、总结 在前面的Servlet学习中发现Servlet本质是一个java程序,因此Servlet更加擅长编写程序的业务逻辑,而如果要…

BACnet到OPC UA的楼宇自动化系统与生产执行系统(MES)整合

在智能制造的浪潮下,一家位于深圳的精密电子制造企业面临着前所未有的挑战:如何高效地将楼宇自动化系统与生产执行系统(MES)整合,实现能源管理与生产流程的精细化控制。这家企业的楼宇控制系统使用的是BACnet协议&…

牛客NC97 字符串出现次数的TopK问题【中等 哈希+优先级队列 Java/Go】

题目 题目链接: https://www.nowcoder.com/practice/fd711bdfa0e840b381d7e1b82183b3ee 核心 哈希,优先级队列Java代码 import java.util.*;public class Solution {/*** 代码中的类名、方法名、参数名已经指定,请勿修改,直接返…

思维导图网页版哪个好?2024年值得推荐的8个在线思维导图软件!

思维导图如今已成为一种常用的工具,帮助我们清晰地组织和整理信息。随着科技的发展,思维导图的产品形态也经过多轮迭代,从最初的本地客户端过渡到基于云的 Web 端,各类网页版思维导图软件应运而生,它们方便快捷&#x…

【3dmax笔记】035: 车削修改器

一、车削修改器介绍 车削:图形通过绕轴旋转来创建三维效果。 开放的样条线,车削之后是面片。闭合的样条线,车削之后,是实体。 一、车削修改器实例 绘制高脚杯,首先在前视图绘制如下二维图形。 添加一个车削的修改器…

【Linux】shell基础,shell脚本

Shell Shell是一个用C语言编写的程序,接受用户输入的命令,并将其传递给操作系统内核执行。Shell还负责解释和执行命令、管理文件系统、控制进程,是用户使用Linux的桥梁。Shell既是一种命令语言,又是一种程序设计语言 Shell脚本 Sh…

HTML Audio标签src使用base64字符

源码&#xff1a; <!DOCTYPE html> <html> <head> <meta charset"utf-8"> <title>Audio src base64</title> </head> <body><audio controls><source src"data:audio/mp3;base64,//OIxAAAAAAAAAA…

2.小土堆——tensorboard使用

1.tensorboard是啥&#xff1f; TensorBoard 是一个用于可视化 TensorFlow 训练过程和模型的工具。它可以帮助你以图形和图表的形式查看训练过程中的指标&#xff0c;比如损失和准确率的变化。你可以使用 TensorBoard 来监视模型的性能&#xff0c;并且更直观地理解模型的工作原…

Classifier guidance与Classifier free diffusion的简单理解

参考&#xff1a;Classifier Guidance 和 Classifier Free Guidance&#xff0c;一堆公式不如两行代码 - 蓟梗的文章 - 知乎 https://zhuanlan.zhihu.com/p/660518657 Classifier Guidance和Classifier-free Guidance 总结 - 走遍山水路的文章 - 知乎 https://zhuanlan.zhihu.c…

【雅思写作】Vince9120雅思小作文笔记——P1 Intro(前言)

文章目录 链接P1 Intro&#xff08;前言&#xff09;字数限制题型综述&#xff08;problem types overview&#xff09;1. **柱状图&#xff08;Bar Chart&#xff09;** - 描述不同类别在某个或多个变量上的数据量比较。2. **线图&#xff08;Line Graph&#xff09;** - 展示…

Lib city笔记:TrajectoryDataset

1 AbstractDataset 抽象类&#xff0c;所有数据集的基类 2 TrajectoryDataset 2.1 __init__ 2.2 get_data 2.3 cutter_filter 2.3.1 按照时间间隔切割 2.3.2 按照同一天切割 2.3.3 按照固定窗口长度切割 cut完的轨迹样子 每一个key是一个轨迹的id&#xff0c;对应的value内容…

SQL查询语句(三)范围查找关键字

在上一篇文章中&#xff0c;我们介绍了SQL语句中&#xff0c;逻辑关键字的作用&#xff0c;并举例演示了如何用逻辑关键字来组合WHERE子句。在文章的末尾我们提到了两个用于范围查找的关键字IN和BETWEEN。这两个关键字都可以与NOT关键字灵活组合&#xff0c;起到对字句结果取反…

Crowd counting 系列NO.2—MCNN

声明&#xff1a;博客是用latex写的&#xff0c;所以直接用图片来展示吧&#xff0c;效果是一样的。下载资源网上都很容易搜到&#xff0c;如需下载资源&#xff0c;请留言。

Java内存是怎样分配的

Java内存是怎样分配的 一、 1. 有些编程语言编写的程序会直接向操作系统请求内存&#xff0c;而 Java 语言为保证其平台无关性&#xff0c;并不允许程序直接向操作系统发出请求&#xff0c;而是在准备执行程序时由Java虚拟机&#xff08;JVM&#xff09;向操作系统请求一定的…

基于SpringBoot+Vue点餐系统设计和实现(源码+LW+部署讲解)

&#x1f339;作者简介&#xff1a;✌全网粉丝10W&#xff0c;前大厂员工&#xff0c;多篇互联网电商推荐系统专利&#xff0c;现有多家创业公司&#xff0c;致力于建站、运营、SEO、网赚等赛道。也是csdn特邀作者、博客专家、Java领域优质创作者&#xff0c;博客之星、掘金/华…

VxTerm使用教程:连接SSH服务端设备,什么是SSH

一、什么是SSH&#xff1f; <摘自百度> 安全外壳协议 SSH&#xff0c;即安全外壳协议&#xff08;Secure Shell&#xff09;&#xff0c;是一种网络协议&#xff0c;用于在计算机网络上提供安全的远程登录和命令执行功能。 SSH通过加密通信通道来保护数据传输&#xff0c…

C++:类与对象—继承

类与对象—继承 一、继承是什么&#xff1f;二、继承定义三、基类和派生类对象赋值转换四、继承中的作用域五、派生类的默认成员函数六、继承与友元七、继承与静态成员八、复杂的菱形继承及菱形虚拟继承九、继承的总结和反思十、考察重点 一、继承是什么&#xff1f; 继承(inh…

每日OJ题_记忆化搜索①_力扣509. 斐波那契数(四种解法)

目录 记忆化搜索概念和使用场景 力扣509. 斐波那契数 解析代码1_循环 解析代码2_暴搜递归 解析代码3_记忆化搜索 解析代码4_动态规划 记忆化搜索概念和使用场景 记忆化搜索是一种典型的空间换时间的思想&#xff0c;可以看成带备忘录的爆搜递归。 搜索的低效在于没有能够…

YOLOv5改进(二)BiFPN替换Neck网络

前言 针对红绿灯轻量化检测&#xff0c;上一节使用MobileNetv3替换了主干网络&#xff0c;本篇将在使用BiFPN替换Neck的方式优化算法~ 往期回顾 YOLOv5改进&#xff08;一&#xff09;MobileNetv3替换主干网络 目录 一、BiFPN简介二、改进方法一第一步&#xff1a;在common.…