pytest实现fixture的原理,pytest fixtures
本文主要介绍pytest的官方文档,解释fixture,调用fixture,fixture的可重用性。有需要的朋友可以借鉴一下,希望能有所帮助。祝大家进步很大,早日升职加薪。
目录
夹具调用其他夹具和夹具的可重用性1、夹具调用其他夹具2、夹具的可重用性
fixtures调用其他fixtures及fixture复用性
pytest最大的一个优点就是非常灵活。
它可以将复杂的测试需求简化为更简单、更有条理的功能,然后这些功能可以根据自己的需要依赖于其他功能。
fixture可以调用其他fixture,这也是灵活性的体现之一。
一、Fixtures调用别的Fixtures
直接看一个简单的例子:
导入pytest
#排列
@pytest.fixture
定义first_entry():
#这是一个fixture函数,返回值为:a
返回“a”
#排列
@pytest.fixture
定义订单(第一项):
#这是另一个请求前一个fixture函数first_entry()的fixture函数,
#并将first_entry()的返回值放入list [],最后返回。
返回[first_entry]
定义测试字符串(订单):
#行动
#在测试函数中请求第二个fixture函数命令,您可以获得返回的[]
order . append(“b”)
#断言
assert order==[a , b]
正如您所看到的,pytest中的一个fixture请求另一个fixture,就像一个测试函数请求一个fixture一样,所有的请求规则都适用。
同样,如果我们必须自己做这些事情,它将如下:
定义first_entry():
返回“a”
定义订单(第一项):
返回[first_entry]
定义测试字符串(订单):
#行动
order . append(“b”)
#断言
assert order==[a , b]
entry=first_entry()
list=order(first_entry=entry)
测试字符串(顺序=列表)
二、Fixtures的复用性
pytest中的Fixtures还可以让我们定义可以重复使用的公共设置步骤,就像使用普通函数一样。
两个不同的测试函数可以请求相同的fixture,并且每个测试函数将得到自己的结果。
这具有确保不同的测试功能不会相互影响的优点。
我们可以使用这种机制来确保每个测试函数都获得自己新的、干净的和一致的数据。
导入pytest
#排列
@pytest.fixture
定义first_entry():
返回“a”
#排列
@pytest.fixture
定义订单(第一项):
返回[first_entry]
定义测试字符串(订单):
#行动
order . append(“b”)
#断言
assert order==[a , b]
def test_int(订单):
#行动
order.append(2)
#断言
assert order==[a ,2]
从代码中可以看出,虽然fixture函数order先后被两个测试函数调用过,但是每次调用给出的结果都是一样的。它不影响测试函数test_int中order的返回值,因为order.append(b )是在测试函数test_string中执行的。
还是那句话,这些事情都是我们自己做的,仅此而已:
定义first_entry():
返回“a”
定义订单(第一项):
返回[first_entry]
定义测试字符串(订单):
#行动
order . append(“b”)
#断言
assert order==[a , b]
def test_int(订单):
#行动
order.append(2)
#断言
assert order==[a ,2]
entry=first_entry()
list=order(first_entry=entry)
测试字符串(顺序=列表)
entry=first_entry()
list=order(first_entry=entry)
test_int(order=the_list)
接下来继续按照官方文档解读夹具的特性:一次请求多个夹具,多次请求夹具。
以上是pytest官方文档解读fixture调用fixture和fixture复用性的详细内容。更多关于pytest fixtures调用复用性的信息,请关注盛行IT软件开发工作室的其他相关文章!
郑重声明:本文由网友发布,不代表盛行IT的观点,版权归原作者所有,仅为传播更多信息之目的,如有侵权请联系,我们将第一时间修改或删除,多谢。