[created_at: 2020-06-18]
Pytest的setup和teardown方法可以实现测试用例的前后执行操作。
Pytest中还有另外一种方式实现这些操作fixture
,使用起来更加灵活。
附:学习链接1 学习链接2
fixture区别于传统的(setup/teardown)有显著改进:
1.有独立的命名,并通过声明它们从测试函数、模块、类或整个项目中的使用来激活。
2.按模块化的方式实现,每个fixture都可以互相调用。
3.fixture的范围从简单的单元测试到复杂的功能测试,可以对fixture配置参数,或者跨函数function,类class,模块module或整个测试session范围。
- 定义fixture函数跟定义普通函数差不多,只是需要在函数上加装饰器
@pytest.fixture()
- fixture命名不要以test开头,跟测试用例区分开
- fixture函数有返回值,没有返回值默认返回None
- 可以直接在测试文件中定义fixture函数
- 也可以使用conftest.py文件存储fixture函数
- 引用方式1:测试方法中直接引用fixture函数名
- 引用方式2:每个测试方法或类上加装饰器
@pytest.mark.userfixtures()
- 批量引用1:定义比较大的fixture的作用范围scope
- 批量引用2:使用
pytestmark
标记需要引用的fixture函数(貌似只能引用一个) - 批量引用3:变更conftest.py文件的存放位置,例如根目录
fixture的作用范围(scope)
ixture里面有个scope参数可以控制fixture的作用范围:session>module>class>function
-function:每一个函数或方法都会调用
-class:每一个类调用一次,一个类中可以有多个方法
-module:每一个.py文件调用一次,该文件内又有多个function和class
-session:是多个文件调用一次,可以跨.py文件调用,每个.py文件就是module
练习实例:conftest.py与test1.py,test1.py可以多复制一份同时执行看结果
# conftest.py
import pytest
#session级别
@pytest.fixture(scope="session")
def fixture1():
print("【1-1】session setup")
# 使用yield,前面实现的是setup方法,后面实现的teardown方法
yield
print("【1-2】session teardown")
#module级别
@pytest.fixture(scope="module")
def fixture2():
print("【2-1】module setup")
yield
print("【2-2】module teardown")
#class级别
@pytest.fixture(scope="class")
def fixture32():
print("【32-1】class setup")
yield
print("【32-2】class teardown")
#class级别
@pytest.fixture(scope="class")
def fixture31():
print("【31-1】class setup")
yield
print("【31-2】class teardown")
#class级别
@pytest.fixture(scope="class")
def fixture33():
print("【33-1】class setup")
yield
print("【33-2】class teardown")
#function级别
@pytest.fixture(scope="function")
def fixture4():
print("【4-1】function setup")
yield fixture4
print("【4-2】function teardown")
#使用参数autouse="true",那么就可以在py文件中执行时自动调用,无需手动引用
@pytest.fixture(scope="function",autouse="true")
def fixture5():
print("【5-1】function setup")
yield
print("【5-2】function teardown")
#test1.py
import pytest
#使用如下固定语法,可以每个测试方法都调用fixture33
pytestmark=pytest.mark.usefixtures("fixture33")
#class及function级别的fixture加到最上面即可
@pytest.mark.usefixtures("fixture1")
@pytest.mark.usefixtures("fixture2")
#同一个级别的fixture按从下到上的顺序执行
@pytest.mark.usefixtures("fixture31")
@pytest.mark.usefixtures("fixture32")
class Test_f1:
# 测试方法中直接引用fixture函数
def test_f1a1(self,fixture4):
print("《1-1》test_f1a1 in class Test_f1")
def test_f1a2(self):
print("《1-2》test_f1a2 in class Test_f1")
#如果类前面不加usefixtures装饰器的话,是不会执行class及function级别的fixture
class Test_f2:
def test_f2a1(self):
print("《2-1》test_f2a1 in class Test_f2")
def test_f2a2(self):
print("《2-2》test_f2a2 in class Test_f2")