三.pytest实现常用的前后置(固件、夹具)处理

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结合使用实现全局的前置应用
  1. conftest.py文件是单独存放的一个夹具配置文件,名称是不能更改的
  2. 将@pytest.fixture装饰的函数写在conftest.py中可以让所有的py文件使用这同一个函数
  3. 原则上conftest.py需要和运行的用例放到同一层,并且不需要做import操作。即可以在多个路径中创建各个conftest.py文件,所有的py文件可以公同使用各个conftest.py中被pytest.fixture装饰的函数

代码示例这里就不写了,使用方法与上面相同,就是把@pytest.fixture装饰的部分写到了conftest.py中

你可能感兴趣的:(三.pytest实现常用的前后置(固件、夹具)处理)