1. setup与teardown,setup_class与teardown_class
为什么需要这些功能?
比如:web自动化执行用例之前,需要打开浏览器,执行之后需要关闭浏览器
# -*- coding: utf-8 -*-
# @Date: 2021-04-14
# @Author: liuhongkui
class TestHook:
# 这个函数在整个类所有的测试用例执行之前只执行一次
def setup_class(self):
print('一般用于执行初始化工作,比如创建日志对象、创建数据库连接对象')
# 这个函数在每个测试函数执行之前都会执行一次
def setup(self):
print('可以用于执行浏览器的打开操作')
def test_01(self):
print('测试test01')
def test_02(self):
print('测试test02')
def test_03(self):
print('测试test03')
# 这个函数在每个测试函数执行完成以后都会执行一次
def teardown(self):
print('可以用于关闭浏览器操作')
# 这个函数在每个测试类执行完成以后会执行一次
def teardown_class(self):
print('一般用于销毁日志对象,关闭数据库连接等等')
2. 使用@pytest.fixture()装饰器来实现部分用例的前后置
装饰器样例: @pytest.fixture(scope='', params='', autouse='', ids='', name='')
(1) scope表示的是被@pytest.fixture标记的方法的作用域,包含:function(默认),class,module,package/session
function会在每个测试函数执行时都调用被装饰的函数,等价于setup/teardown
class会在执行该函数的测试函数之前调用,等价于setup_class/teardown_class
module会在执行这个py文件之前只调用一次
(2)params:参数化(支持列表,元组,字典列表,字典元组)
(3)autouse:自动使用装饰函数,默认是False
(4)ids:当是引用params参数化时,给每一个值设置一个变量名。该参数意义不大
(5)name:给被装饰的函数取一个别名,注意:当取了别名以后原来的名称就用不了了
代码样例一,pytest.fixture的前后置调用
import pytest
# @pytest.fixture(scope='function', params='', autouse='', ids='', name='')
@pytest.fixture(scope='function')
def my_fixture():
print('前置执行...')
yield # 利用yield可以实现函数的前后置
print('后置执行...')
class TestHook:
def test_01(self):
print('测试test01')
# 当需要调用前后置函数时就把函数名传入到测试方法中即可
def test_02(self, my_fixture):
print('测试test02')
def test_03(self):
print('测试test03')
代码样例二,pytest.fixture参数化使用
import pytest
# 利用params指定参数,在被装饰的函数中添加request参数,并且将request.param返回可以将参数逐个传入到测试函数中调用
@pytest.fixture(scope='function', params=['参数1', '参数2', '参数3'])
def my_fixture(request):
print('前置执行...')
yield request.param
print('后置执行...')
class TestHook:
def test_01(self):
print('测试test01')
# 当需要调用前后置函数时就把函数名传入到测试方法中即可
def test_02(self, my_fixture):
# 由于params参数共有3个,因此test_02会执行三次
print('测试test02: {}'.format(my_fixture))
def test_03(self):
print('测试test03')
3. 通过conftest.py和@pytest.fixture结合使用实现全局的前置应用
- conftest.py文件是单独存放的一个夹具配置文件,名称是不能更改的
- 将@pytest.fixture装饰的函数写在conftest.py中可以让所有的py文件使用这同一个函数
- 原则上conftest.py需要和运行的用例放到同一层,并且不需要做import操作。即可以在多个路径中创建各个conftest.py文件,所有的py文件可以公同使用各个conftest.py中被pytest.fixture装饰的函数
代码示例这里就不写了,使用方法与上面相同,就是把@pytest.fixture装饰的部分写到了conftest.py中