python pytest进阶之xunit fixture详解
前言
今天我们再说一下pytest框架和unittest框架相同的fixture的使用,了解unittest的同学应该知道我们在初始化环境和销毁工作时,unittest使用的是setUp,tearDown方法,那么在pytest框架中同样存在类似的方法,今天我们就来具体说明。
先附上官方文档的一段说明
1.每个级别的setup/teardown都可以多次复用
2.如果相应的初始化函数执行失败或者被跳过则不会执行teardown方法
3.在pytest4.2之前,xunitfixture不遵循fixture的作用规则的,因此可以在一个session级别且参数auto=True的fixture前执行setup_method方法
但是到目前为止,所有的xunitfixture已经遵循了fixture执行的规则
function级别
实例
defsetup_function(function):
print('\n--------------------')
print('函数执行前所做的操作')
print('\n--------------------')
defteardown_function(function):
print('\n--------------------')
print('函数执行后所做的操作')
print('\n--------------------')
deftest_function_1():
print('\n测试函数1')
deftest_function_2():
print('\n测试函数2')
if__name__=='__main__':
importpytest
pytest.main(['-sq','functionLevel.py'])
输出结果
functionLevel.py -------------------- 函数执行前所做的操作 -------------------- 测试函数1 -------------------- 函数执行后所做的操作 -------------------- -------------------- 函数执行前所做的操作 -------------------- 测试函数2 -------------------- 函数执行后所做的操作 -------------------- [100%] ==========================2passedin0.03seconds===========================
说明
通过输出结果我们可以总结:setup_function会在每一个测试函数前执行初始化操作;teardown_function会在每一个测试函数执行后执行销毁工作
method级别
实例
classTestMethod(object):
defsetup_method(self,method):
print('\n--------------------')
print('方法执行前所做的操作')
print('\n--------------------')
defteardown_method(self,method):
print('\n--------------------')
print('方法执行后所做的操作')
print('\n--------------------')
deftest_method_1(self):
print('\n测试方法1')
deftest_method_2(self):
print('\n测试方法2')
if__name__=='__main__':
importpytest
pytest.main(['-sq','methodLevel.py'])
输出结果
methodLevel.py -------------------- 方法执行前所做的操作 -------------------- 测试方法1 -------------------- 方法执行后所做的操作 -------------------- -------------------- 方法执行前所做的操作 -------------------- 测试方法2 -------------------- 方法执行后所做的操作 -------------------- [100%] ==========================2passedin0.03seconds===========================
说明
通过输出结果我们可以总结:setup_method会在每一个测试方法前执行初始化操作;teardown_method会在每一个测试方法执行后执行销毁工作,且方法级别的fixture是作用在测试类中的方法上的
class级别
实例
classTestClass(object):
@classmethod
defsetup_class(cls):
print('\nsetup_class()for{}'.format(cls.__name__))
@classmethod
defteardown_class(cls):
print('\nteardown_class()for{}'.format(cls.__name__))
deftest_1(self):
print('self.test_1()')
deftest_2(self):
print('self.test_2()')
if__name__=='__main__':
importpytest
pytest.main(['-sq','classLevel.py'])
输出结果
classLevel.py setup_class()forTestClass .self.test_1() .self.test_2() teardown_class()forTestClass [100%] ==========================2passedin0.06seconds===========================
说明
通过输出结果我们可以总结:setup_class会在测试类执行前执行一次初始化操作;teardown_class会在测试类执行后执行一次销毁工作,且class级别的fixture需要使用@classmethod装饰
module级别
实例
defsetup_module(module):
print('\nsetup_module()for{}'.format(module.__name__))
defteardown_module(module):
print('\nteardown_module()for{}'.format(module.__name__))
deftest_1():
print('test_1()')
deftest_2():
print('test_2()')
classTestClass(object):
deftest_3(self):
print('self.test_3()')
deftest_4(self):
print('self.test_4()')
if__name__=='__main__':
importpytest
pytest.main(['-sq','moduleLevel.py'])
输出结果
moduleLevel.py setup_module()formoduleLevel .test_1() .test_2() .self.test_3() .self.test_4() teardown_module()formoduleLevel [100%] ==========================4passedin0.04seconds===========================
说明
通过输出结果我们可以总结:setup_module会在整个测试文件也就是模块中的测试类或者测试函数,测试方法执行前执行一次初始化操作;teardown_module会在整个测试文件也就是模块中的测试类或者测试函数,方法执行后执行一次销毁工作
以上就是xunitfixture的4个级别,实际工作中该如何使用还需多练习,深入理解才能得心应手!
附上官方文档做参考虽是英文但是很详细
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持毛票票。