目录

1、前言

fixture中文名翻译为夹具,作用与上一篇中setupteardown一致,都是用来做前后置处理的,但fixture更灵活更强大。它支持部分前后置,比如有时候我们不需要为每一条测试用例都添加前后置,使用setupteardown要么为整个模块添加前后置,要么为整个类,所有类方法,所有函数添加前后置,使用fixture就可以很好的解决这个场景的问题。

2、Fixture的优势

  • 可以实现部分前后置,如前言中所述
  • 名称可以自定义,无需像setupteardown一样有固定命名
  • 可以通过conftest.py文件进行全局配置,实现共享前后置,且不需要import
  • 可以通过设置scope参数实现与setupteardown各级别一样的功能,而且多了sessionpackage级别,实现了多包和多模块前后置
  • 可以实现unittest不能实现的功能,比如unittest测试用例间无法传递参数和数据,通过fixture可以解决这个问题

3、Fixture的定义与调用

(1)定义方法

import pytest


@pytest.fixture()
def my_fixture():
    print("定义一个试夹具")

(2)参数简要说明

fixture(scope="function", params=None, autouse=False, ids=None, name=None):  
  • scope:表示所定义fixture的作用域
    • function:函数级别(包括类方法)(默认作用域),只在调用该fixture的函数或方法前(后)执行一次
    • class:类级别,只在调用该fixture的类的前(后)执行一次
    • module:模块级别,只在调用该fixture的模块前(后)执行一次
    • package:包级别,只在调用该fixture的包前(后)执行一次
    • sessionsession级别,整个会话只执行一次,即运行项目时整个过程只执行一次
  • params:一个可选参数列表,可用于参数化或给其他fixture传递数据
  • autouse:自动使用,默认值为False,设置True时配合scope实现setupteardown一样的全部前后置
  • ids:一个字符串id的列表,即当使用params参数化时,为每一条测试用例起别名或描述
  • name:为定义的fixture提供一个别名

(3)调用方法

  • 方式一:将定义的fixture名称或别名作为测试用例的参数,可以传递多个,按先后顺序执行
import pytest


@pytest.fixture()
def fixture_1():
    print("这是一个前置处理")


def testcase_1(fixture_1):
    print("这是测试用例1")


"""
执行结果
fixture/use_fixture_1.py::testcase_1 这是一个前置处理
这是测试用例1
PASSED
"""
  • 方式二:使用@pytest.mark.usefixture(fixture_name)装饰器
    • 在类上使用,表示类中所有测试方法都会调用这个fixture
    • 在函数上使用,表示只有这个函数会调用这个fixture
    • 同样可以传递多个fixture,按顺序执行
    • 如果fixture设置了别名,无法使用这个装饰器调用fixture
    • 如果fixture有返回值,用这个装饰器无法获取返回值,也就无法给测试用例传递数据实现参数化
import pytest


@pytest.fixture()
def fixture_2():
    print("这是一个前置处理")


@pytest.mark.usefixtures("fixture_2")
def test_2():
    print("这是测试用例2")
    
"""
执行结果
fixture/use_fixture_2.py::test_2 这是一个前置处理
这是测试用例2
PASSED
"""
  • 方式三fixture设置autouse=True实现自动调用,同样无法获取返回值
import pytest


@pytest.fixture(autouse=True)
def fixture_3():
    print("这是一个前置处理")


def testcase_1():
    print("这是测试用例1")

def testcase_2():
    print("这是测试用例2")

"""
执行结果
fixture/use_fixture_3.py::testcase_1 这是一个前置处理
这是测试用例1
PASSED
fixture/use_fixture_3.py::testcase_2 这是一个前置处理
这是测试用例2
PASSED
"""

参考
https://www.cnblogs.com/miki-peng/p/14736425.html
https://www.cnblogs.com/liuyuelinfighting/p/15998510.html