前言
今天我们再说一下pytest框架和unittest框架相同的fixture的使用, 了解unittest的同学应该知道我们在初始化环境和销毁工作时,unittest使用的是setUp,tearDown方法,那么在pytest框架中同样存在类似的方法,今天我们就来具体说明。
先附上官方文档的一段说明
1.每个级别的setup/teardown都可以多次复用
2.如果相应的初始化函数执行失败或者被跳过则不会执行teardown方法
3.在pytest4.2之前,xunit fixture 不遵循fixture的作用规则的,因此可以在一个session级别且参数auto=True的fixture前执行setup_method方法
但是到目前为止,所有的xunit fixture已经遵循了fixture执行的规则
function级别
实例
def setup_function(function): print('\n--------------------') print('函数执行前所做的操作') print('\n--------------------') def teardown_function(function): print('\n--------------------') print('函数执行后所做的操作') print('\n--------------------') def test_function_1(): print('\n测试函数1') def test_function_2(): print('\n测试函数2') if __name__ == '__main__': import pytest pytest.main(['-sq', 'functionLevel.py'])
输出结果
functionLevel.py -------------------- 函数执行前所做的操作 -------------------- 测试函数1 -------------------- 函数执行后所做的操作 -------------------- -------------------- 函数执行前所做的操作 -------------------- 测试函数2 -------------------- 函数执行后所做的操作 -------------------- [100%] ========================== 2 passed in 0.03 seconds ===========================
说明
通过输出结果我们可以总结:setup_function会在每一个测试函数前执行初始化操作;teardown_function会在每一个测试函数执行后执行销毁工作
method级别
class TestMethod(object): def setup_method(self, method): print('\n--------------------') print('方法执行前所做的操作') print('\n--------------------') def teardown_method(self, method): print('\n--------------------') print('方法执行后所做的操作') print('\n--------------------') def test_method_1(self): print('\n测试方法1') def test_method_2(self): print('\n测试方法2') if __name__ == '__main__': import pytest pytest.main(['-sq', 'methodLevel.py'])
输出结果
methodLevel.py -------------------- 方法执行前所做的操作 -------------------- 测试方法1 -------------------- 方法执行后所做的操作 -------------------- -------------------- 方法执行前所做的操作 -------------------- 测试方法2 -------------------- 方法执行后所做的操作 -------------------- [100%] ========================== 2 passed in 0.03 seconds ===========================
说明
通过输出结果我们可以总结:setup_method会在每一个测试方法前执行初始化操作;teardown_method会在每一个测试方法执行后执行销毁工作,且方法级别的fixture是作用在测试类中的方法上的
class级别
实例
class TestClass(object): @classmethod def setup_class(cls): print('\nsetup_class() for {}'.format(cls.__name__)) @classmethod def teardown_class(cls): print('\nteardown_class() for {}'.format(cls.__name__)) def test_1(self): print('self.test_1()') def test_2(self): print('self.test_2()') if __name__ == '__main__': import pytest pytest.main(['-sq', 'classLevel.py'])
输出结果
classLevel.py setup_class() for TestClass .self.test_1() .self.test_2() teardown_class() for TestClass [100%] ========================== 2 passed in 0.06 seconds ===========================
说明
通过输出结果我们可以总结:setup_class会在测试类执行前执行一次初始化操作;teardown_class会在测试类执行后执行一次销毁工作,且class级别的fixture需要使用@classmethod装饰
module级别
实例
def setup_module(module): print('\nsetup_module() for {}'.format(module.__name__)) def teardown_module(module): print('\nteardown_module() for {}'.format(module.__name__)) def test_1(): print('test_1()') def test_2(): print('test_2()') class TestClass(object): def test_3(self): print('self.test_3()') def test_4(self): print('self.test_4()') if __name__ == '__main__': import pytest pytest.main(['-sq', 'moduleLevel.py'])
输出结果
moduleLevel.py setup_module() for moduleLevel .test_1() .test_2() .self.test_3() .self.test_4() teardown_module() for moduleLevel [100%] ========================== 4 passed in 0.04 seconds ===========================
说明
通过输出结果我们可以总结:setup_module会在整个测试文件也就是模块中的测试类或者测试函数,测试方法执行前执行一次初始化操作;teardown_module会在整个测试文件也就是模块中的测试类或者测试函数,方法执行后执行一次销毁工作
以上就是xunit fixture的4个级别,实际工作中该如何使用还需多练习,深入理解才能得心应手!
附上官方文档做参考虽是英文但是很详细
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持小牛知识库。
本文向大家介绍python pytest进阶之conftest.py详解,包括了python pytest进阶之conftest.py详解的使用技巧和注意事项,需要的朋友参考一下 前言 前面几篇文章基本上已经了解了pytest 命令使用,收集用例,finxture使用及作用范围,今天简单介绍一下conftest.py文件的作用和实际项目中如是使用此文件! 实例场景 首先们思考这样一个问题:如果我们
本文向大家介绍python pytest进阶之fixture详解,包括了python pytest进阶之fixture详解的使用技巧和注意事项,需要的朋友参考一下 前言 学pytest就不得不说fixture,fixture是pytest的精髓所在,就像unittest中的setup和teardown一样,如果不学fixture那么使用pytest和使用unittest是没什么区别的(个人理解)。
本文向大家介绍IOS CocoaPods详解之进阶篇,包括了IOS CocoaPods详解之进阶篇的使用技巧和注意事项,需要的朋友参考一下 一、Podfile.lock文件 上文讲过,在开始使用CocoaPods,执行完pod install之后,会生成一个Podfile.lock文件。这个文件看起来跟我们关系不大,实际上绝对不应该忽略它。 该文件用于保存已经安装的Pods依赖库的版本,通过Coc
本文向大家介绍详解webpack进阶之插件篇,包括了详解webpack进阶之插件篇的使用技巧和注意事项,需要的朋友参考一下 一、插件篇 1. 自动补全css3前缀 autoprefixer 官方是这样说的:Parse CSS and add vendor prefixes to CSS rules using values from the Can I Use website,也就是说它是一个自动
本文向大家介绍python进阶教程之动态类型详解,包括了python进阶教程之动态类型详解的使用技巧和注意事项,需要的朋友参考一下 动态类型(dynamic typing)是Python另一个重要的核心概念。我们之前说过,Python的变量(variable)不需要声明,而在赋值时,变量可以重新赋值为任意值。这些都与动态类型的概念相关。 动态类型 在我们接触的对象中,有一类特殊的对象,是用于存储数
JavaScript早已不是当年的一个脚本语言,随着Web应用和Node.js的兴起、函数式编程的复兴,以及响应式编程开始进入人们视野,让JavaScript看上去更“专业”了。虽然和十几年前相比较,JavaScript也加入了很多功能和语法糖,但是它的核心原理并没有太大变化。