Python自动化之pytest框架fixture
简介:
fixture区别于unnitest的传统单元测试(setup/teardown)有显著改进:
1.有独立的命名,并通过声明它们从测试函数、模块、类或整个项目中的使用来激活。
2.按模块化的方式实现,每个fixture都可以互相调用。
3.fixture的范围从简单的单元测试到复杂的功能测试,可以对fixture配置参数,或者跨函数function,类class,模块module或整个测试session范围。
fixture源码详解:
import pytest """ fixture源码详解 fixture(scope='function',params=None,autouse=False,ids=None,name=None) scope作用域: "function"级别(默认值):每个用例之前(之后)执行 "class"级别:每个类之前(之后)执行 "module"级别:每一个.py文件调用一次 "session"级别:多个文件调用一次,可以跨.py文件调用,每个.py文件就是module autouse自动执行:默认False,不写成True时需要手动调用 params:一个可选的参数列表,它将导致多个参数调用fixture功能和所有测试使用它 ids:每个字符串id的列表,每个字符串对应于params这样他们就是测试ID的一部分。如果没有提供ID它们将从params自动生成 name:fixture的名称。这默认为装饰函数的名称 """ @pytest.fixture(scope="function", autouse=True) def connect_mysql(): print("链接数据库") # 用例之前执行 yield print("关闭数据库") # 用例之后执行 @pytest.fixture() def first(connect_mysql): # fixture作为参数传入,作为fixture的相互调用 print("调用链接数据库") @pytest.fixture() def returnData(): return "fixture可以有返回数据,也可以返回一个元祖,list或字典" class TestDemo: def test_post(self, connect_mysql): # 手动调用fixture a = 1 assert a == 1