• pytest_用例运行级别_class级


    '''
    模块级(setup_module/teardown_module)开始于模块始末,
    全局的在类中不起作用
    类级(setup_class/teardown_class)只在类中前后运行一次(在
    类中)
    方法级(setup_method/teardown_method)开始于方法始末
    (在类中)
    
    函数级(setup_function/teardown_function只对函数用例生
    效(在类中不生效)
    setup_function
    teardown_function
    '''
    import  pytest
    def setup_function():
        print()
        print("setup_function:class外的每个用例前开始执行")
    
    def teardown_function():
        print("teardown_function:class外的每个个用例后开始执行")
    
    def setup_module():
        """
        这是一个module级别的setup,它会在本module(test_fixt_class.py)里
        所有test执行之前,被调用一次。
        注意,它是直接定义为一个module里的函数"""
        print()
        print("-------------- setup before module --------------")
    def teardown_module():
        """
        这是一个module级别的teardown,它会在本module(test_fixt_class.py)里
        所有test执行完成之后,被调用一次。
        注意,它是直接定义为一个module里的函数"""
        print("-------------- teardown after module --------------")
    def test_add():
        print("正在执行test_fire")
        a = "hello"
        b = "hello word"
        assert a in b
    class TestCase():
        def setup(self):
            print("setup: 每个用例开始前执行")
        def teardown(self):
            print("teardown: 每个用例结束后执行")
        def setup_class(self):
            print("setup_class:所有用例执行之前")
        def teardown_class(self):
            print("teardown_class:所有用例执行之前")
        def setup_method(self):
            print("setup_method: 每个用例开始前执行")
        def teardown_method(self):
            print("teardown_method: 每个用例结束后执行")
        def test_one(self):
            print("正在执行----test_one")
            x = "this"
            assert 'h' in x
        def test_three(self):
            print("正在执行test_two")
            a = "hello"
            b = "hello word"
            assert a in b
        def add(self,a, b):
            print("这是加减法")
            return a + b
    if __name__ == '__main__':
        pytest.main(['-s', 'test_fixt_class'])

    运行结果:
    ============================= test session starts =============================
    platform win32 -- Python 3.7.4, pytest-5.1.0, py-1.8.0, pluggy-0.12.0
    rootdir: E:py_pytestinterfacecollected 3 items

    test_fixt_class.py
    -------------- setup before module --------------

    setup_function:class外的每个用例前开始执行
    .正在执行test_fire
    teardown_function:class外的每个个用例后开始执行
    setup_class:所有用例执行之前
    setup_method: 每个用例开始前执行
    setup: 每个用例开始前执行
    .正在执行----test_one
    teardown: 每个用例结束后执行
    teardown_method: 每个用例结束后执行
    setup_method: 每个用例开始前执行
    setup: 每个用例开始前执行
    .正在执行test_two
    teardown: 每个用例结束后执行
    teardown_method: 每个用例结束后执行
    teardown_class:所有用例执行之前
    -------------- teardown after module --------------
    [100%]

    ============================== 3 passed in 0.02s ==============================

    结论1:
    模块级(setup_module/teardown_module)开始于模块始末,
    全局的在类中不起作用
    函数级(setup_function/teardown_function只对函数用例生
    效(在类中不生效)
    
    结论2:
    从结果看出,运行的优先级: 
    setup_model>setup_class>setup_method> setup >用例case> teardown> teardown_method> teardown_class >teardown_model
    
    结论3:
     从运行结果看出, setup_module/teardown_module 的优先级 
     是最大的,然后函数里面用到的 setup_function/teardown_function 
     不类里面的 setup_class/teardown_class 互不干涉
     
    
    
     
     
  • 相关阅读:
    0基础培训Web前端2个月实习一个月4000?
    amazon kindle和kindle阅读
    手动双面打印
    一分价钱一分货
    【转】cocos2d-x 开发中使用的一些工具
    怎么做网线,网线水晶头接法和线序(图文详解)
    schedule
    Match+Faq
    【转】以XML文件方式保存用户数据——2013-08-25 22
    【转】针对iOS VS. Android开发游戏的优劣——2013-08-25 17
  • 原文地址:https://www.cnblogs.com/tallme/p/11369791.html
Copyright © 2020-2023  润新知