• pytest.fixture的初始化清除操作


    需要导入模块pytest

    使用装饰器:pytest.fixture(scope='function',autouse=False)

    fixture()函数参数解释说明

      fixture里面有个scope参数可以控制fixture的作用范围:session>module>class>function

      -function:每一个函数或方法都会调用

      -class:每一个类调用一次,一个类中可以有多个方法

      -module:每一个.py文件调用一次,该文件内又有多个function和class

      -session:是多个文件调用一次,可以跨.py文件调用,每个.py文件就是module

    def fixture(
        callable_or_scope=None,
        *args,
        scope="function",
        params=None,
        autouse=False,
        ids=None,
        name=None
    )
    参数说明
    :arg scope: the scope for which this fixture is shared, one of
                    ``"function"`` (default), ``"class"``, ``"module"``,
                    ``"package"`` or ``"session"`` (``"package"`` is considered **experimental**
                    at this time).
    
                    This parameter may also be a callable which receives ``(fixture_name, config)``
                    as parameters, and must return a ``str`` with one of the values mentioned above.
    
                    See :ref:`dynamic scope` in the docs for more information.
    
        :arg params: an optional list of parameters which will cause multiple
                    invocations of the fixture function and all of the tests
                    using it.
                    The current parameter is available in ``request.param``.
    
        :arg autouse: if True, the fixture func is activated for all tests that
                    can see it.  If False (the default) then an explicit
                    reference is needed to activate the fixture.
    
        :arg ids: list of string ids each corresponding to the params
                    so that they are part of the test id. If no ids are provided
                    they will be generated automatically from the params.
    
        :arg name: the name of the fixture. This defaults to the name of the
                    decorated function. If a fixture is used in the same module in
                    which it is defined, the function name of the fixture will be
                    shadowed by the function arg that requests the fixture; one way
                    to resolve this is to name the decorated function
                    ``fixture_<fixturename>`` and then use
                    ``@pytest.fixture(name='<fixturename>')``.
        """
    fixture()函数参数说明

    初始化清除操作:

      方式一:

      def simple_setup():

        清除操作

        yield

        清除操作or清除操作函数

      方式二:

        def simple_setup(request):

          清除操作

          request.addfinalizer(清除操作函数)

    例子:

       参数中设置autouse=True ,则每个测试用例都执行初始化清除操作

    @pytest.fixture(scope='function')
    def simple_request():
        print('开始初始化')
        yield
        after_test()
    def after_test():
        print('开始清除')
    # autoust=False,添加初始化操作函数名作为参数,就会执行初始化操作,不加则不执行
    def test_request(simple_request):
        print('测试用例1,开始执行测试')
        assert 1 == 1
    def test_request2():
        print('测试用例2,开始执行测试')
        assert 1 == 1
    @pytest.fixture(scope='function')
    def simple_request(request):
        print('开始初始化')
        request.addfinalizer(after_test)
    
    def after_test():
        print('开始清除')
    
    # autoust=False,添加初始化操作函数名作为参数,就会执行初始化操作,不加则不执行
    def test_request(simple_request):
        print('测试用例1,开始执行测试')
        assert 1 == 1
    
    def test_request2():
        print('测试用例2,开始执行测试')
        assert 1 == 1

    执行结果:

      

      

  • 相关阅读:
    dart的map方法如何获取index
    Flutter学习(一)——创建一个项目
    springcloudOpenFeign在实际工作使用场景
    springcloud:config搭配bus使用
    springcloud:一篇学会springcloud config
    springcloud一篇搞定GateWay
    springcloud一篇搞定Hystrix
    Dockerfile实践二 爱我
    Redis小结 爱我
    程序员必备知识点 爱我
  • 原文地址:https://www.cnblogs.com/aiyumo/p/12401938.html
Copyright © 2020-2023  润新知