pytest之fixture用法

2023-10-21 08:50
文章标签 用法 pytest fixture

本文主要是介绍pytest之fixture用法,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一、fixture是什么

fixture是pytest用于将测试前后进行预备、清理工作的代码处理机制。
相较于setup和teardown而言,有以下几点优势:

  1. fixture命名更加灵活,局限性较小
  2. conftest.py配置里面可以实现数据共享,不需要import就能自动找到一些配置

二、fixture的scope

  1. (scope=“function”) 每一个函数或方法都会调用,默认就是function
# 示例:1、先定义一个fixture。这个fixture的函数不需要test_开头命名
@pytest.fixture(scope='function')
def  t_func1():print('function级别的前置操作:func1')# 2、在用例里调用这个fixture 
def test_one(t_func1):expect = 1actual = 1assert expect == actual

执行后,在用例调用前会执行fixture里的操作:
在这里插入图片描述

  1. (scope=“class”) 每一个类调用一次
# 示例:1、先定义一个fixture。这个fixture的函数不需要test_开头命名
@pytest.fixture(scope='class',autouse=True)
def t_func2():print('class级别的前置操作:func2')# 2、在用例里调用这个fixture 
class TestClassFixture():def test_one(self):expect = 1actual = 1print('ok')assert expect == actualdef test_two(self):expect = 1actual = 2assert expect == actual

虽然类中有2个方法,但fixture的scope是class,因此只执行一次。
在这里插入图片描述

  1. (scope=“module”) 每一个.py文件调用一次
# 示例:1、先定义一个fixture。scope为module
@pytest.fixture(scope='module',autouse=True)
def t_module():print('module级别的前置操作')#2、py文件中定义一个class一个函数
class TestClassFixture():def test_one(self):expect = 1actual = 1print('ok')assert expect == actualdef test_two(self):expect = 1actual = 2assert expect == actualdef test_three():expect = 1actual = 2assert expect != actual

可以看到,虽然.py文件下存在一个类和一个函数。但只执行了一次前置操作在这里插入图片描述 4. (scope=“session”) 是多个文件调用一次

#1、在conftest.py中定义fixture
@pytest.fixture(scope='session',autouse=True)
def t_session():print('session级的fixture')#2、同一个文件夹,创建2个.py文件
#3、terminal中执行pytest命令

可以看到,test_fixture这个文件下,虽然有test_one和test_two两个py文件,但只执行了一次前置操作。
在这里插入图片描述

  1. fixture的作用范围(执行顺序):session>module>class>function
@pytest.fixture(scope="function")
def t_function():print("我是function fixture")@pytest.fixture(scope="class")
def t_class():print("我是class fixture")@pytest.fixture(scope="module")
def t_moudule():print("我是moudule fixture")@pytest.fixture(scope="session")
def t_session():print("我是session fixture")class TestOrder:def test_order(self,t_function,t_session,t_moudule,t_class):assert 1==1

虽然打乱了顺序,但是执行顺序依然是session>module>class>function
在这里插入图片描述

三、使用conftest管理fixture

  1. conftest.py为固定写法,不可修改名字。使用conftest.py文件方法无需导入
  2. 函数作用于当前文件夹及下属文件,conftest可以放在上层目录,但是要注释掉当前目录的方法,如果方法都一样的话

四、fixture返回数据,解决接口参数依赖

#1、conftest.py文件中定义fixture
@pytest.fixture(scope="function")
def get_params():params = {'key1': 'value1', 'key2': 'value2'}return params#2、用例文件中,使用fixture得到参数
import pytest
import requestsdef test_getparam(get_params):print("测试get请求")#第1种方法r=requests.get('https://httpbin.org/get',params=get_params)#第2种方法key1 = get_params['key1']key2 = get_params['key2']r=requests.get('https://httpbin.org/get',params={'key1':key1, 'key2':key2})print(r.status_code)assert r.status_code == 200res = r.json()assert res['url'] == 'https://httpbin.org/get?key1=value1&key2=value2'assert res['origin'] == '163.125.202.248'assert res['args']['key1'] == 'value1'assert res['args']['key2'] == 'value2'

五、yield做后置操作

#1、conftest文件定义fixture,yield关键字之后可以定义后置操作
@pytest.fixture(scope='function')
def t_func1():print('function级别的前置操作:func1')yieldprint('function级别的后置操作:func1')# 2、用例文件
def test_three(t_func1):expect = 1actual = 2assert expect != actualprint('ok')

在这里插入图片描述

#1、conftest文件定义fixture,yield也可以返回值,但pytest中不常用这个用法
@pytest.fixture(scope='function')
def t_func1():print('function级别的前置操作:func1')yield 'potizo'print('function级别的后置操作:func1')# 2、用例文件
def test_three(t_func1):expect = 1actual = 2assert expect != actualprint('ok')print(t_func1)

在这里插入图片描述

六、fixture的另一种调用方式:uesfixtures

@pytest.fixture(scope='function',autouse=True)
def get_params():params = {'key':'value'}return params    
  1. fixture的调用方式有2种,usefixtures这种无法接受返回值。
  • 第一种,可以接收返回值:
    def test_func(get_params):
    xxx

  • 第二种,无法接收返回值:
    @pytest.mark.usefixtures(‘get_params’)
    def test_func():
    xxx

  1. usefixtures的执行顺序
#1、conftest文件中定义2个fixture
@pytest.fixture(scope='function')
def t_func1():print('function级别的前置操作:func1')yield 'potizo'print('function级别的后置操作:func1')@pytest.fixture(scope='function')
def t_func1_new():print('function级别的前置操作:func1_new')yield 'potizo'print('function级别的后置操作:func1_new')#2、用例文件中使用usefixtures方式调用这两个fixture
@pytest.mark.usefixtures("t_func1")
@pytest.mark.usefixtures("t_func1_new")
def test_usefixtures():print('ok')

执行顺序:靠近方法的那个fixture先调用
在这里插入图片描述
也可以在usefixtures中一次调用多个fixture,用,分割。

@pytest.mark.usefixtures("t_func1","t_func1_new")
def test_usefixtures():print('ok')```

执行顺序如下:
在这里插入图片描述

七、fixture的2个参数:ids和params

# 1、 定义fixture 
#request和params\ids是关键字,不能改
@pytest.fixture(params=["data1","data2"],ids=["case1","case2"])
def params_fixture(request):return request.param
#2、 测试方法调用这个fixture
def test_params(params_fixture):print(params_fixture)

实际工作中很少这样用
在这里插入图片描述

这篇关于pytest之fixture用法的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

JavaScript中的reduce方法执行过程、使用场景及进阶用法

《JavaScript中的reduce方法执行过程、使用场景及进阶用法》:本文主要介绍JavaScript中的reduce方法执行过程、使用场景及进阶用法的相关资料,reduce是JavaScri... 目录1. 什么是reduce2. reduce语法2.1 语法2.2 参数说明3. reduce执行过程

Python itertools中accumulate函数用法及使用运用详细讲解

《Pythonitertools中accumulate函数用法及使用运用详细讲解》:本文主要介绍Python的itertools库中的accumulate函数,该函数可以计算累积和或通过指定函数... 目录1.1前言:1.2定义:1.3衍生用法:1.3Leetcode的实际运用:总结 1.1前言:本文将详

MyBatis-Flex BaseMapper的接口基本用法小结

《MyBatis-FlexBaseMapper的接口基本用法小结》本文主要介绍了MyBatis-FlexBaseMapper的接口基本用法小结,文中通过示例代码介绍的非常详细,对大家的学习或者工作具... 目录MyBATis-Flex简单介绍特性基础方法INSERT① insert② insertSelec

深入解析Spring TransactionTemplate 高级用法(示例代码)

《深入解析SpringTransactionTemplate高级用法(示例代码)》TransactionTemplate是Spring框架中一个强大的工具,它允许开发者以编程方式控制事务,通过... 目录1. TransactionTemplate 的核心概念2. 核心接口和类3. TransactionT

数据库使用之union、union all、各种join的用法区别解析

《数据库使用之union、unionall、各种join的用法区别解析》:本文主要介绍SQL中的Union和UnionAll的区别,包括去重与否以及使用时的注意事项,还详细解释了Join关键字,... 目录一、Union 和Union All1、区别:2、注意点:3、具体举例二、Join关键字的区别&php

解决Cron定时任务中Pytest脚本无法发送邮件的问题

《解决Cron定时任务中Pytest脚本无法发送邮件的问题》文章探讨解决在Cron定时任务中运行Pytest脚本时邮件发送失败的问题,先优化环境变量,再检查Pytest邮件配置,接着配置文件确保SMT... 目录引言1. 环境变量优化:确保Cron任务可以正确执行解决方案:1.1. 创建一个脚本1.2. 修

oracle中exists和not exists用法举例详解

《oracle中exists和notexists用法举例详解》:本文主要介绍oracle中exists和notexists用法的相关资料,EXISTS用于检测子查询是否返回任何行,而NOTE... 目录基本概念:举例语法pub_name总结 exists (sql 返回结果集为真)not exists (s

Springboot中Jackson用法详解

《Springboot中Jackson用法详解》Springboot自带默认json解析Jackson,可以在不引入其他json解析包情况下,解析json字段,下面我们就来聊聊Springboot中J... 目录前言Jackson用法将对象解析为json字符串将json解析为对象将json文件转换为json

bytes.split的用法和注意事项

当然,我很乐意详细介绍 bytes.Split 的用法和注意事项。这个函数是 Go 标准库中 bytes 包的一个重要组成部分,用于分割字节切片。 基本用法 bytes.Split 的函数签名如下: func Split(s, sep []byte) [][]byte s 是要分割的字节切片sep 是用作分隔符的字节切片返回值是一个二维字节切片,包含分割后的结果 基本使用示例: pa

UVM:callback机制的意义和用法

1. 作用         Callback机制在UVM验证平台,最大用处就是为了提高验证平台的可重用性。在不创建复杂的OOP层次结构前提下,针对组件中的某些行为,在其之前后之后,内置一些函数,增加或者修改UVM组件的操作,增加新的功能,从而实现一个环境多个用例。此外还可以通过Callback机制构建异常的测试用例。 2. 使用步骤         (1)在UVM组件中内嵌callback函