Unittest
setUp/tearDown
setUp当中得到的变量,用self.xxx = value传递给测试用例
setUpClass/tearDownClass
setupClass当中得到的变量,用cls.xxx = value传递给测试用例
pytest
pytest有两种前置后置,一种是沿用unittest风格setup/teardown, setup_class/teardown_class
另一种测试fixture
定义fixture
@pytest.fixture #定义fixture必须用这个装饰器
def fix():
print(“前置代码”)
yield # yield为前置后置的分割线
print(“后置代码”)
fixture有4个作用域。
测试函数(function)、测试类(class)、测试模块文件(module)、测试会话(session)
@pytest.fixture(scope="function"(默认值)/"class"/"module"/"session")
def xxxx():
pass
设置fixture的返回值
@pytest.fixture
def init():
print("测试函数的前置")
yield "test","abc" #fixture的返回值放在yield旁
print("测试函数的后置")
调用fixture返回值
@pytest.mark.usefixtures("init") #调用函数名为init的fixture
def test_bbb(init): #把函数名为init的fixture的返回值作为参数传入这个测试函数里
print(init)
如果fixture有返回值,那么,将它作为测试函数的参数时,可以不用装饰器,如下图
fixture的共享机制conftest.py
1.放的都是fixture
2.文件名不能更改。不同包下,可以创建多个
3.对外共享
4.共享范围:
同级共享
向下共享
5.优先级:就近原则。如调用fixture后如何知道定义在哪个文件,查找路线:自己模块 > 同级 > 往上
都找不到,报错
共享是定义好fixture后,被测试函数调用
就近原则,是测试用例调用的fixture,向上查找放在哪个conftest文件里
6.嵌套
如下代码,init2里嵌套这init的代码
@pytest.fixture
def init():
print("* init before *")
yield "i am init"
print("* init after *")
@pytest.fixture
def init2(init): # 继承init的前置后置,再它的基础上增加一些内容
print("* init2 before *")
yield init # 继承init的返回值
print("* init2 after *")
测试函数调用init2
@pytest.mark.usefixtures("init2")
def test_data1():
assert True
运行结果:先运行init前置,再运行init2的前置,接着运行init2的后置,最后运行init的后置
什么时候嵌套? 一个fixture想完全使用另一个fixture,并在人家的基础上新增一些代码
当测试过程需要连接DB时,可以在conftest.py定义好如下代码,在需要用的测试函数调用这个fixture就好。
这个fixture定义scope为session,是一旦运行main模块,就立即启动db,运行完后则关闭db,autouse是自动使用这个fixture的开关,module、class、function的不建议开启autouse
@pytest.fixture(scope="session",autouse=True)
def db_fixture():
db = HandleDB() # 实例化DB
yield db
db.close() # 关闭连接