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效果: