Pytest测试框架(二):fixture 方法等相关操作--自定义测试用例的前置后置条件

pytest中的fixture:

  fixture是pytest特有的功能,它用pytest.fixture标识,定义在函数前面。fixture有明确的名字,在其他函数,模块,类或整个工程调用它时会被激活。fixture是基于模块来执行的,每个fixture的名字就可以触发一个fixture的函数,它自身也可以调用其他的fixture。

  可以把fixture看做是资源,在你的测试用例执行之前需要去配置这些资源,执行完后需要去释放资源。类似unittest中的setup和teardown功能。

fixture方法详解:

fixture(callable_or_scope=None,*args,scope="function",params=None,autouse=False,ids=None,name=None):

scope: 作用范围,设置范围后,会根据设置的范围去触发执行。

  可选范围如下:

  • function:每个方法(函数)都会执行一次。(默认)
  • class:每个类都会执行一次。类中有多个方法调用,只在第一个方法调用时执行
  • module:一个.py文件执行一次。一个.py文件可能包含多个类和方法
  • package/session:多个文件调用一次,可以跨.py文件

params:传入参数,接收一个列表,列表中每个数据都作为用例的输入

autouse:在一个session内所有的test都会自动调用当前的fixture,默认为false

ids:测试字符串id的列表,每个测试字符串id对应于params,默认为参数值

name:fixture的名称,默认为装饰函数的名称


fixture方法中的 scope 应用

scope参数:function(默认)  每个方法(函数)都会执行一次

代码示例:

import pytest


# fixture方法 类似unittest中的setup和teardown功能
@pytest.fixture()
def fixtrue_function():
    print("测试用例开始执行之前执行",end=" ")
    yield
    print(' '+"测试用例执行之后执行",end=" ")

class TestDemo03:
    def test_case_01(self,fixtrue_function):  # 测试用例中引用 fixture 函数
        print('exec test_case_031',end=' ')
        assert 1+3 == 4

    def test_case_02(self,fixtrue_function):  # 测试用例中引用 fixture 函数
        print('exec test_case_032',end=' ') 
        assert 8-0 == 8

执行效果:

scope参数: class   每个类都会执行一次。类中有多个方法调用,只在第一个方法调用时执行

代码示例:

import pytest


# fixture方法 类似unittest中的setup和teardown功能
@pytest.fixture(scope='class')
def fixtrue_function():
    print("测试用例开始执行之前执行",end=" ")
    yield
    print(' '+"测试用例执行之后执行",end=" ")

class TestDemo03:
    def test_case_01(self,fixtrue_function):  # 测试用例中引用 fixture 函数
        print('exec test_case_031',end=' ')
        assert 1+3 == 4

    def test_case_02(self,fixtrue_function):  # 测试用例中引用 fixture 函数
        print('exec test_case_032',end=' ')
        assert 8-0 == 8

执行效果:

scope参数: module   一个.py文件执行一次。一个.py文件可能包含多个类和方法

import pytest


# fixture方法 类似unittest中的setup和teardown功能
@pytest.fixture(scope='module')
def fixtrue_function():
    print("测试用例开始执行之前执行",end=" ")      # 初始化操作
    yield
    print(' '+"测试用例执行之后执行",end=" ")     # 清理操作

class TestDemo03:
    def test_case_01(self,fixtrue_function):  # 测试用例中引用 fixture 函数
        print('exec test_case_031',end=' ')
        assert 1+3 == 4

    def test_case_02(self,fixtrue_function):  # 测试用例中引用 fixture 函数
        print('exec test_case_032',end=' ')
        assert 8-0 == 8

class TestDemo04:
    def test_case_01(self,fixtrue_function):
        print('exec test_case_041',end=' ')
        assert 1+3 == 4

    def test_case_02(self,fixtrue_function):
        print('exec test_case_042',end=' ')
        assert 8-0 == 8

执行效果:

scope参数:package/session  多个文件调用一次,可以跨.py文件

同conftest.py文件的效果一样,

fixture方法中的 autouse 应用

autouse:在一个session内所有的test都会自动调用当前的fixture,默认为false

代码示例:

每次在测试用例中引用fixtrue函数比较麻烦,可以使用autouse=True,可自动调用当前的fixtrue

import pytest


# fixture方法 类似unittest中的setup和teardown功能
@pytest.fixture(scope='class',autouse=True)
def fixtrue_function():
    print("测试用例开始执行之前执行",end=" ")      # 初始化操作
    yield
    print(' '+"测试用例执行之后执行",end=" ")     # 清理操作

class TestDemo03:
    def test_case_01(self):
        print('exec test_case_031',end=' ')
        assert 1+3 == 4

    def test_case_02(self):
        print('exec test_case_032',end=' ')
        assert 8-0 == 8

执行效果:

fixture方法中的 name 应用

 name:fixture的名称,默认为装饰函数的名称

代码示例:

import pytest


# fixture方法 类似unittest中的setup和teardown功能
@pytest.fixture(scope='class',name='f1')  # name: fixture的名称,默认为装饰函数的名称
def fixtrue_function():
    print("测试用例开始执行之前执行",end=" ")      # 初始化操作
    yield
    print(' '+"测试用例执行之后执行",end=" ")     # 清理操作

class TestDemo03:
    def test_case_01(self,f1):
        print('exec test_case_031',end=' ')
        assert 1+3 == 4

    def test_case_02(self):
        print('exec test_case_032',end=' ')
        assert 8-0 == 8

执行效果:

fixture方法中的 params和ids 应用

params:传入参数,接收一个列表,列表中每个数据都作为用例的输入

ids:测试字符串id的列表,每个测试字符串id对应于params,默认为参数值

代码示例:

params 是传入参数的,ids是为传入的参数命名的,如下面代码:

示例1:

import pytest

# params 传入列表参数[1,2,3,4,5],ids为列表参数中的每个值命名,如ids中的num1 == params中的1
@pytest.fixture(params=[1,2,3,4,5],ids=['num1','num2','num3','num4','num5'])
def fixtrue_function(request):  # fixtrue_function函数中的形参request是固定值也是必填的
    return request.param

class TestDemo04:
    def test_case(self,fixtrue_function):
        print('exec test_case,use %d'%fixtrue_function ,end=' ')
        assert True

示例2:

import pytest

@pytest.fixture(params=[(1,2,3),(4,5,9),(10,20,30)],ids=['num1','num2','num3'])
def fixtrue_function(request):
    return request.param

class TestDemo04:
    def test_case(self,fixtrue_function):
        print('%d + %d ?= %d'%(fixtrue_function[0],fixtrue_function[1],fixtrue_function[2]),end=' ')
        assert fixtrue_function[0] + fixtrue_function[1] == fixtrue_function[2]

执行效果:

示例1效果:

 示例2效果:

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值