从0开始python学习-33.夹具@pytest.fixture(scope=““,params=““,autouse=““,ids=““,name=““)

目录

[1. 创建夹具](#1. 创建夹具)

[1.1 pytest方式](#1.1 pytest方式)

[1.2 unittest方式](#1.2 unittest方式)

[2. 使用夹具](#2. 使用夹具)

[2.1 通过参数引用](#2.1 通过参数引用)

[2.2 通过函数引用](#2.2 通过函数引用)

[3. 参数详解](#3. 参数详解)

[3.1 scope:作用域](#3.1 scope:作用域)

[3.2 params-参数化](#3.2 params-参数化)

[3.3 autouse=True表示自动使用,默认为False](#3.3 autouse=True表示自动使用,默认为False)

[3.4 ids:设置变量名](#3.4 ids:设置变量名)

[3.5 name:别名](#3.5 name:别名)


1. 创建夹具

1.1 pytest方式

python 复制代码
@pytest.fixture()
def test_a():
    print('case执行之前执行')
    yield
    print('case执行之后执行')

1.2 unittest方式

python 复制代码
class Test:
    def setup_method(self):
        print('setup_method:case执行之前执行--用例之前执行一次')
    def teardown_method(self):
        print('teardown_method:case执行之后执行--每个case执行之前均执行')
    def setup_class(self):
        print('setup_class:case执行之前执行--每个case执行之后均执行')
    def teardown_class(self):
        print('teardown_class:case执行之后执行--全部用例执行完了之后才执行')

2. 使用夹具

2.1 通过参数引用

2.2 通过函数引用

3. 参数详解

@pytest.fixture(scope="",params="",autouse="",ids="",name="")

3.1 scope:作用域

表示标记方法的作用域:function(默认),class,module,package,session

session > module > class > function

function:每个用例都有一个

python 复制代码
@pytest.fixture(scope='function')
def test_a():
    print('之前执行')
    yield
    print('之后执行')
class Test_A:
    def test_1(self,test_a):
        print('test_1')
    def test_2(self,test_a):
        print('test_2')
class Test_B:
    def test_3(self,test_a):
        print('test_3')

class:每个class 共用一个

python 复制代码
@pytest.fixture(scope='class')
def test_a():
    print('之前执行')
    yield
    print('之后执行')
class Test_A:
    def test_1(self,test_a):
        print('test_1')
    def test_2(self):
        print('test_2')
class Test_B:
    def test_3(self):
        print('test_3')

下面就不举例了:module:每个文件共用一个;package:每个包共用一个;session:全局共用一个

3.2 params-参数化

支持列表[]、元组()、字典列表[{},{}],字典元组({},{})

fixture引用外部参数

python 复制代码
param = ['111',[1,2],('a','b')]
@pytest.fixture(params=param)
def test_a(request):
    test = request.param
    return test

def test_1(test_a):
    print(test_a)

fixture标签直接进行参数化

python 复制代码
@pytest.fixture(params=[1,2,'aaaa'])
def test_b(request):
    test1 = request.param
    return test1
def test_2(test_b):
    print(test_b)

3.3 autouse=True表示自动使用,默认为False

autouse=True时无论是否使用都会被使用

python 复制代码
@pytest.fixture(autouse=True)
def test_a():
    print('test_a')

def test_1():
    print('test_1')

autouse=False时必须要手动调用了才会被使用

python 复制代码
@pytest.fixture(autouse=False)
def test_b():
    print('test_b')

def test_2(test_b):
    print('test_2')

3.4 ids:设置变量名

当使用params参数化时,给每一个值设置一个变量名

python 复制代码
param = ['111',[1,2],('a','b')]
@pytest.fixture(params=param,ids=['user1','user2','user3'])
def test_a(request):
    test = request.param
    return test

def test_1(test_a):
    print(test_a)

3.5 name:别名

表示被@pytest.fixture标记的方法取一个别名,当取了别名后,原来的名称就不能用了

python 复制代码
@pytest.fixture(name='yyyy')
def test_a():
    print('11111')

def test_1(yyyy):
    print('test_1')
def test_2(test_a):
    print('test_1')
相关推荐
我先去打把游戏先25 分钟前
ESP32学习笔记(基于IDF):ESP32连接MQTT服务器
服务器·笔记·单片机·嵌入式硬件·学习·esp32
deng-c-f4 小时前
Linux C/C++ 学习日记(29):IO密集型与CPU密集型、CPU的调度与线程切换
linux·学习·线程·cpu·io密集·cpu密集
四谎真好看5 小时前
Java 黑马程序员学习笔记(进阶篇18)
java·笔记·学习·学习笔记
洋洋的笔记5 小时前
银行测试学习计划
学习
应用市场5 小时前
构建自定义命令行工具 - 打造专属指令体
开发语言·windows·python
东方佑5 小时前
从字符串中提取重复子串的Python算法解析
windows·python·算法
Dfreedom.6 小时前
一文掌握Python四大核心数据结构:变量、结构体、类与枚举
开发语言·数据结构·python·变量·数据类型
一半烟火以谋生6 小时前
Python + Pytest + Allure 自动化测试报告教程
开发语言·python·pytest
Allan_20256 小时前
数据库学习
数据库·学习
报错小能手6 小时前
linux学习笔记(43)网络编程——HTTPS (补充)
linux·网络·学习