本文介绍了参数化后如何运行拆卸功能/夹具的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!
问题描述
我正在尝试运行tearDown函数/夹具来实现一个测试用例的整个参数化。因此,我希望在我的conftest.py文件中包含如下内容
@pytest.fixture(autouse=True, scope="parametrization")
def parametrization_scope():
print("First run of parametrization fixture")
# Executing 100 parametrizations
yield
print("Yield run of parametrization fixture")
在我的test.py中类似于
@pytest.mark.parametrize(n-params)
# run initiate fixture here of parametrization
def test():
# executing n number of times
# run yield fixture here of parametrization
推荐答案
您可以使用测试类解决缺少的参数化&qot;范围,如下所示:
import pytest
@pytest.fixture(scope="class")
def foo():
print("setup")
yield None
print("teardown")
class TestSum:
@pytest.mark.parametrize(
"a,b,c",
[(3, 5, 8), (2, 4, 6)],
)
def test_eval(self, a, b, c, foo):
assert a + b == c
如果只有TestSum类使用fixture foo,您甚至可以将foo的定义放在该类中。
这篇关于参数化后如何运行拆卸功能/夹具的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持!