测试框架pytest教程(3)夹具-@pytest.fixture

内置fixture

Fixture使用@pytest.fixture装饰,pytest有一些内置的fixture

命令可以查看内置fixture

pytest --fixtures

 

fixture范围

在pytest中,夹具(fixtures)具有不同的作用范围(scope),用于控制夹具在测试中的生命周期和重用性。可以通过使用`@pytest.fixture`装饰器并指定`scope`参数来定义夹具的作用范围。

以下是pytest中常用的夹具作用范围:

1. `function`(默认值):每个测试函数运行一次,即每个测试函数都会重新初始化和清理夹具。

2. `class`:每个测试类内的所有测试函数都共享同一个实例化的夹具。在测试类开始时初始化夹具,在测试类结束时清理夹具。

3. `module`:每个测试模块中所有测试函数都共享同一个实例化的夹具。在测试模块开始时初始化夹具,在测试模块结束时清理夹具。

4. `package`:每个测试包(包含多个模块)中的所有测试函数共享同一个实例化的夹具。在测试包开始时初始化夹具,在测试包结束时清理夹具。

5. `session`:整个测试会话中的所有测试函数共享同一个实例化的夹具。在测试会话开始时初始化夹具,在测试会话结束时清理夹具。

夹具的作用范围决定了夹具在测试过程中的生命周期和重用性。选择合适的作用范围可以提高测试的效率和性能,同时确保夹具在适当的时候进行初始化和清理。

要使用指定作用范围的夹具,请将`scope`参数传递给`@pytest.fixture`装饰器,例如:

```python
import pytest@pytest.fixture(scope="module")
def my_fixture():# 初始化夹具yield# 清理夹具
```

在上面的例子中,`my_fixture`被定义为模块级别的夹具,它将在测试模块开始时进行初始化,在测试模块结束时进行清理。

自动使用autouse

`autouse`是pytest夹具(fixture)的一个参数,用于指示夹具是否自动应用于所有测试函数,而无需在测试函数中显式调用夹具。

当你将`autouse=True`传递给夹具装饰器时,夹具将自动在每个测试函数运行前执行,并在测试函数运行后执行清理操作。这使得夹具的使用变得非常方便,无需在每个测试函数中添加装饰器或调用夹具函数。

例如,考虑以下的示例:

```python
import pytest@pytest.fixture(autouse=True)
def setup_and_teardown():# 在每个测试函数之前执行设置操作print("Setup")yield# 在每个测试函数之后执行清理操作print("Teardown")def test_one():print("Test one")def test_two():print("Test two")
```

在上述示例中,`setup_and_teardown`夹具被设置为`autouse=True`,因此它将自动应用于所有的测试函数。每个测试函数在运行之前都会执行`setup_and_teardown`夹具的设置操作,并在测试函数运行后执行清理操作。

运行上述示例的测试会产生以下输出:

```
Setup
Test one
Teardown
Setup
Test two
Teardown
```

注意,使用`autouse`参数应谨慎,确保夹具的设置和清理操作不会对每个测试函数产生意外的副作用,并且在确实需要自动应用于每个测试函数时使用它。否则,推荐在需要使用夹具的测试函数上显式添加夹具装饰器。

fixture可用性

夹具可用性是从测试的角度确定的。仅当测试位于定义了固定装置的范围内时,固定装置才可供测试请求。如果固定装置是在类内部定义的,则只能由该类内部的测试请求。但是,如果在模块的全局范围内定义了固定装置,则该模块中的每个测试(即使它是在类内部定义的)都可以请求它。

同样,如果测试与定义自动使用装置的范围相同,则该测试也只能受自动使用装置影响(请参阅 自动使用装置首先在其范围内执行)。

一个固定装置还可以请求任何其他固定装置,无论它是在哪里定义的,只要请求它们的测试可以看到涉及的所有固定装置。

例如,下面是一个带有固定装置 (outer ) 的测试文件,该夹具调用了一个不在它范围内的inner,但是inner在测试方法可调用的范围内,所以outer也可以调用inner。

import pytest@pytest.fixture
def order():return []@pytest.fixture
def outer(order, inner):order.append("outer")class TestOne:@pytest.fixturedef inner(self, order):order.append("one")def test_order(self, order, outer):assert order == ["one", "outer"]class TestTwo:@pytest.fixturedef inner(self, order):order.append("two")def test_order(self, order, outer):assert order == ["two", "outer"]

conftest.py: 跨多个文件共享固定装置

conftest.py是一个特殊的文件,它可以用于存放pytest的公共夹具(fixtures)和插件配置,以供项目中的多个测试文件共享和重用。

在pytest框架中,`conftest.py`文件需要放置在项目目录或测试目录的根目录下。当运行pytest时,它会自动加载这个文件,并提供其中定义的夹具和配置。

`conftest.py`文件通常包含以下内容:

1. 夹具定义:你可以在`conftest.py`中定义各种夹具,例如用于创建测试数据、配置测试环境或模拟外部依赖的夹具。这些夹具可以在项目中的任何测试文件中使用。

2. 共享夹具:`conftest.py`文件中定义的夹具可以在整个项目中共享和重用。这意味着你可以在多个测试文件中使用相同的夹具,而无需在每个文件中重新定义。

3. 配置选项:你可以在`conftest.py`中配置pytest的选项,例如设置报告的格式、启用特定的插件或定制断言行为。

4. 插件配置:如果你使用了一些pytest插件,你可以在`conftest.py`中配置这些插件的参数和行为。

使用`conftest.py`可以提高测试代码的可维护性和重用性,避免在每个测试文件中重复定义相同的夹具和配置。它使得夹具和配置可以在整个项目中共享,减少了冗余代码并提高了测试的效率。

根目录下的conftest.py可以被项目下的任何测试所使用,pytest会自动发现,不需要手动导入

可以有多个包含测试的嵌套目录/包,每个目录都可以有自己的conftest.py固定装置

夹具实例化顺序

当 pytest 想要执行测试时,一旦它知道将执行哪些装置,它就必须弄清楚它们的执行顺序。为此,它会考虑 3 个因素:

  1. 范围

  2. 依赖关系

  3. 自动使用

范围大的优先执行

import pytest@pytest.fixture(scope="session")
def order():return []@pytest.fixture
def func(order):order.append("function")@pytest.fixture(scope="class")
def cls(order):order.append("class")@pytest.fixture(scope="module")
def mod(order):order.append("module")@pytest.fixture(scope="package")
def pack(order):order.append("package")@pytest.fixture(scope="session")
def sess(order):order.append("session")class TestClass:def test_order(self, func, cls, mod, pack, sess, order):assert order == ["session", "package", "module", "class", "function"]

 

相同顺序的装置根据依赖关系执行

当一个装置请求另一个装置时,首先执行另一个装置。因此,如果fixturea请求fixture b,fixtureb将首先执行,因为a依赖于fixtureb并且没有它就无法运行。即使a 不需要 的结果b,它仍然可以请求b是否需要确保在 之后执行b

import pytest@pytest.fixture
def order():return []@pytest.fixture
def a(order):order.append("a")@pytest.fixture
def b(a, order):order.append("b")

执行顺序为order->a->b

自动使用的夹具调用的夹具也会自动使用

import pytest@pytest.fixture
def order():return []@pytest.fixture
def a(order):order.append("a")@pytest.fixture(autouse=True)
def b(a, order):order.append("b")

 夹具b为自动使用,那么它调用的a和order也会自动使用。

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

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

相关文章

【MySQL】JSON 格式字段处理

MySQL 5.7 版本后已支持 JSON 格式,这虽是 MySQL 的一小步,但可以说是程序开发的一大步,再也不用将 JSON 内容塞到 VARCHAR 类型字段了,程序设计也会变得更加灵活。网上大多只针对JSONObject 对象类型,本文也将详解 JS…

算法修炼Day58|● 739. 每日温度 ● 496.下一个更大元素 I

LeetCode:739. 每日温度 739. 每日温度 - 力扣(LeetCode) 1.思路 自定义一个栈空间存储数组索引,将大于当前索引的数值时,计算索引差值,栈顶元素弹出,循环此步骤,直到:小于等于当…

Python处理空值NaN

fork_address_tempread_excel_column_to_list(./eqp_info.xls,Sheet1,车辆地址)for i in fork_address_temp:print(type(i))fork_address[0 if address nan else address for address in fork_address_temp]fork_address结果 <class float><class float><class…

RabbitMQ 消费者

RabbitMQ的消费模式分两种&#xff1a;推模式和拉模式&#xff0c;推模式采用Basic.Consume进行消费&#xff0c;拉模式则是调用Basic.Get进行消费。   消费者通过订阅队列从RabbitMQ中获取消息进行消费&#xff0c;为避免消息丢失可采用消费确认机制 消费者 拉模式拉模式的实…

企业数字化转型中,VR数字展厅能有哪些体验?

在数字化转型的浪潮下&#xff0c;企业纷纷开始注重数字展厅的开展&#xff0c;VR虚拟展厅结合VR全景技术&#xff0c;可以创造出许多有趣的玩法和体验&#xff0c;无论是虚拟参观、互动体验还是VR云会议对接&#xff0c;都为企业客户带来了全新的感知方式。 同传统展厅相比&am…

Kotlin 高阶函数详解

高阶函数 在 Kotlin 中&#xff0c;函数是一等公民&#xff0c;高阶函数是 Kotlin 的一大难点&#xff0c;如果高阶函数不懂的话&#xff0c;那么要学习 Kotlin 中的协程、阅读 Kotlin 的源码是非常难的&#xff0c;因为源码中有太多高阶函数了。 高阶函数的定义 高阶函数的…

好用的电容笔有哪些推荐?开学季便宜好用电容笔推荐

开学马上要来了&#xff0c;想必很多学生党都在为开学而做准备&#xff0c;要知道&#xff0c;原装的Apple Pencil&#xff0c;虽然功能很强&#xff0c;但是价格却很贵&#xff0c;不是一般人能够承受得起的。所以&#xff0c;是否也有类似于Apple Pencil这样的电容笔&#xf…

php开发websocket笔记(1)

1.运行server1.php文件 Windows命令行运行 php server1.php<?phperror_reporting(E_ALL); set_time_limit(0); //ob_implicit_flush(); $address 0.0.0.0;//可以监听网络上的请求 $address 127.0.0.1;//只能监听本机的请求$port 10005; //创建端口 $socket1 socket_cr…

6个比较火的AI绘画生成工具

随着人工智能技术的发展&#xff0c;市场上出现了越来越多的人工智能图像生成工具。这些人工智能图像生成工具可以自动创建惊人的图像、艺术作品和设计&#xff0c;以帮助设计师和创意人员更快地实现他们的创造性想法。在本文中&#xff0c;我们将推荐7种最近流行的人工智能图像…

【0基础入门Python Web笔记】三、python 之函数以及常用内置函数

三、python 之函数以及常用内置函数 函数函数定义函数调用函数参数返回值 常用内置函数input()函数range()函数其它 更多实战项目可进入下方官网 函数 函数是一种用于封装可重复使用代码块的工具&#xff0c;能够将一系列操作组织成一个逻辑单元。 函数定义 在Python中&…

创建R包-2.1:在RStudio中使用Rcpp制作R-Package(更新于2023.8.23)

目录 0-前言 1-在RStudio中创建R包项目 2-创建R包 2.1通过R函数创建新包 2.2在RStudio通过菜单来创建一个新包 2.3关于R包创建的说明 3-添加R自定义函数 4-添加C函数 0-前言 目标&#xff1a;在RStudio中创建一个R包&#xff0c;这个R包中包含C函数&#xff0c;接口是Rc…

【Unity自制手册】游戏基础API大全

&#x1f468;‍&#x1f4bb;个人主页&#xff1a;元宇宙-秩沅 &#x1f468;‍&#x1f4bb; hallo 欢迎 点赞&#x1f44d; 收藏⭐ 留言&#x1f4dd; 加关注✅! &#x1f468;‍&#x1f4bb; 本文由 秩沅 原创 &#x1f468;‍&#x1f4bb; 收录于专栏&#xff1a;Uni…

嵌入式Linux开发实操(十):ADC接口开发

#前言 ADC就是模数转换,可以用来接一些模拟量设备,所谓模拟量就是波形不是方波而是各种包络形状的波形的信号,比如电压、电流等电信号或压力、温度、湿度、位移、声音等非电信号,ADC就是将这些信号转换为数字方波信号,以便于信息传递的。 #ADC硬件设计 key按键连接了AD…

《算法竞赛·快冲300题》每日一题:“凑二十四”

《算法竞赛快冲300题》将于2024年出版&#xff0c;是《算法竞赛》的辅助练习册。 所有题目放在自建的OJ New Online Judge。 用C/C、Java、Python三种语言给出代码&#xff0c;以中低档题为主&#xff0c;适合入门、进阶。 文章目录 题目描述题解C代码Java代码Python代码 “ 凑…

根据源码,模拟实现 RabbitMQ - 网络通讯设计,实现客户端Connection、Channel(完结)

目录 一、客户端代码实现 1.1、需求分析 1.2、具体实现 1&#xff09;实现 ConnectionFactory 2&#xff09;实现 Connection 3&#xff09;实现 Channel 二、编写 Demo 2.1、实例 2.1、实例演示 一、客户端代码实现 1.1、需求分析 RabbitMQ 的客户端设定&#xff…

深入浅出Pytorch函数——torch.nn.init.trunc_normal_

分类目录&#xff1a;《深入浅出Pytorch函数》总目录 相关文章&#xff1a; 深入浅出Pytorch函数——torch.nn.init.calculate_gain 深入浅出Pytorch函数——torch.nn.init.uniform_ 深入浅出Pytorch函数——torch.nn.init.normal_ 深入浅出Pytorch函数——torch.nn.init.c…

Mybatis的动态SQL及关键属性和标识的区别(对SQL更灵活的使用)

&#xff08; 虽然文章中有大多文本内容&#xff0c;想了解更深需要耐心看完&#xff0c;必定大有受益 &#xff09; 目录 一、动态SQL ( 1 ) 是什么 ( 2 ) 作用 ( 3 ) 优点 ( 4 ) 特殊标签 ( 5 ) 演示 二、#和$的区别 2.1 #使用 ( 1 ) #占位符语法 ( 2 ) #优点 2.…

朴素贝叶斯==基于样本特征来预测样本属于的类别y

目录 朴素贝叶斯基于样本特征来预测样本属于的类别y 朴素贝叶斯算法的基本概念与核心思想 假设两个特征维度之间是相互独立的 拉普拉斯平滑增加出现次数保证0不出现 ​编辑 基于样本特征来预测样本属于的类别y 什么是拉普拉斯平滑 朴素贝叶斯基于样本特征来预测样本属于的…

软考高项(九)项目范围管理 ★重点集萃★

&#x1f451; 个人主页 &#x1f451; &#xff1a;&#x1f61c;&#x1f61c;&#x1f61c;Fish_Vast&#x1f61c;&#x1f61c;&#x1f61c; &#x1f41d; 个人格言 &#x1f41d; &#xff1a;&#x1f9d0;&#x1f9d0;&#x1f9d0;说到做到&#xff0c;言出必行&am…