fixture是pytest特有的功能,使用装饰器 @pytest.fixture 标记的函数在其他函数中能被当作参数传入并被调用。
fixture有明确的名字,在其他函数,模块,类或整个工程调用它时会被激活。
fixture是基于模块来执行的,每个fixture的名字就可以触发一个fixture的函数,它自身也可以调用其他的fixture。
fixture作用是为了提供一种可靠和可重复的手段去运行那些最基本的测试内容。比如在测试网站的功能时,每个测试用例都要登录和退出,利用fixture就可以只做一次,否则每个测试用例都要做这两步就显得很冗余。
fixture的可用参数如下:
import pytest
# function作用范围为每个函数或方法
@pytest.fixture(scope="function")
def my_fixture():
# yield之前为前置操作,yield之后为后置操作
print("\n前置操作")
yield
print("\n后置操作")
class TestPractice1:
# 因为没使用autouse参数,使用时需要传入方法名
def test_001(self, my_fixture):
print("执行用例001")
def test_002(self):
print("执行用例002")
class TestPractice2:
def test_003(self, my_fixture):
print("执行用例003")
def test_004(self):
print("执行用例004")
执行结果
import pytest
# class作用范围为每个类
@pytest.fixture(scope="class")
def my_fixture():
# yield之前为前置操作,yield之后为后置操作
print("\n前置操作")
yield
print("\n后置操作")
class TestPractice1:
# 因为没使用autouse参数,使用时需要传入方法名
def test_001(self, my_fixture):
print("执行用例001")
def test_002(self):
print("执行用例002")
class TestPractice2:
def test_003(self):
print("执行用例003")
def test_004(self, my_fixture):
print("执行用例004")
执行结果
import pytest
# module作用范围为每个模块
@pytest.fixture(scope="module")
def my_fixture():
# yield之前为前置操作,yield之后为后置操作
print("\n前置操作")
yield
print("\n后置操作")
class TestPractice1:
# 因为没使用autouse参数,使用时需要传入方法名
def test_001(self, my_fixture):
print("执行用例001")
def test_002(self):
print("执行用例002")
class TestPractice2:
def test_003(self):
print("执行用例003")
def test_004(self, my_fixture):
print("执行用例004")
执行结果
上面我们使用被fixture装饰的函数,都需要将其函数名称当作参数传入到要使用的方法中。需要注意,自动执行范围与scope的作用域相关。
import pytest
@pytest.fixture(autouse=True)
def my_fixture():
# yield之前为前置操作,yield之后为后置操作
print("\n前置操作")
yield
print("\n后置操作")
class TestPractice1:
# 因为没使用autouse参数,使用时需要传入方法名
def test_001(self):
print("执行用例001")
def test_002(self):
print("执行用例002")
class TestPractice2:
def test_003(self):
print("执行用例003")
def test_004(self):
print("执行用例004")
执行结果
在上面的例子中,fixture返回值都是None,我们可以选择让fixture返回我们需要的东西。如果你的fixture需要配置一些数据,读个文件,或者连接一个数据库,那么你可以让fixture返回这些数据或资源。
实现步骤:
注意:参数化时,如果使用了autouse,每个方法都会执行一次参数化,所以autouse慎用。
import pytest
@pytest.fixture(params=[1, 2, 3])
def my_fixture(request):
# yield之前为前置操作,yield之后为后置操作
print("\n前置操作")
yield request.param
print("\n后置操作")
class TestPractice1:
# 参数化
def test_001(self, my_fixture):
print("执行用例001")
print(f"获取参数化的值:{my_fixture}")
def test_002(self):
print("执行用例002")
执行结果
如果没有前后置操作,只想做参数化操作,我们可以使用return返回 request.param
import pytest
@pytest.fixture(params=[1, 2, 3])
def my_fixture(request):
return request.param
class TestPractice1:
# 参数化
def test_001(self, my_fixture):
print("执行用例001")
print(f"获取参数化的值:{my_fixture}")
def test_002(self):
print("执行用例002")
执行结果
import pytest
@pytest.fixture(params=[1, 2, 3], ids=["v1", "v2", "v3"])
def my_fixture(request):
# yield之前为前置操作,yield之后为后置操作
return request.param
class TestPractice1:
# 参数化
def test_001(self, my_fixture):
print("执行用例001")
print(f"获取参数化的值:{my_fixture}")
def test_002(self):
print("执行用例002")
执行结果
name用于给被fixture标记的方法取别名
import pytest
@pytest.fixture(name="rename_fixture")
def my_fixture(request):
print("前置操作")
yield
print("后置操作")
class TestPractice1:
# 使用方法别名调用fixture
def test_001(self, rename_fixture):
print("执行用例001")
def test_002(self):
print("执行用例002")
需要注意是,使用该参数后,原函数名就不可用了。
import pytest
@pytest.fixture()
def fixture_1():
print("\nfixture1的前置")
yield
print("fixture1的后置")
# 在fixture_2中调用fixture_1
@pytest.fixture()
def fixture_2(fixture_1):
print("fixture2的前置")
yield
print("\nfixture2的后置")
class TestPractice1:
# 调用fixture_2
def test_001(self, fixture_2):
print("执行用例001")
def test_002(self):
print("执行用例002")
执行结果
import pytest
@pytest.fixture()
def fixture_1():
print("fixture1的前置")
yield
print("\nfixture1的后置")
@pytest.fixture()
def fixture_2():
print("\nfixture2的前置")
yield
print("fixture2的后置")
class TestPractice1:
# 调用多个fixture,执行顺序与调用顺序有关
def test_001(self, fixture_2, fixture_1):
print("执行用例001")
def test_002(self):
print("执行用例002")
执行结果
上面的演示,用例和fixture均是在同一个文件中,我们可以创建一个固定名称为conftest.py的文件,将其放在用例同级或上级以上目录,在这个文件中定义一个被fixture装饰的函数,这个函数可以在其下级任意目录,不需要import而直接使用。
这里有以下几点需要注意:
-事必有法,然后有成- 最后祝大家早日达到测试的天花板!
以下是我收集到的比较好的学习教程资源,虽然不是什么很值钱的东西,如果你刚好需要,可以留言【777】直接拿走就好了
都看到这啦,若是文章对大家有帮助的话,大家可以点赞、关注支持一下哈~