Pytest测试用例之setup与teardown方法(二)

本文详细介绍了Pytest框架中不同级别的setup与teardown方法的使用及执行顺序,包括类级、方法级和类内级,帮助理解如何有效组织测试用例。

日常积累 | 初识Pytest  | 日常积累 | 初识pytest (二) | Pytest测试用例之setup与teardown方法(一)继续分享, 今天继模块级以及函数式setup与teardown之外的2种类与方法级的写法与执行顺序

回顾

pytest框架用例运行级别

>>模块级(setup_module/teardown_module)开始于横块始末,全局的 

>>函数级(setup_function/teardown_function)只对函数用例生效(不在类中)

>>类级(setup_class/teardown_calss)只在类中前后运行一次(在类中)

>>方法级(setup_method/teardown_method)开始于方法始末(在类中)

>>类里面的(setup/teardown)运行在调用方法前后

接下来我们进入今天的小猪脚类与方法的setup、teardown

01类里面的

pytest 框架类里面的前置与后置用法setup、teardown ]

以下代码是类里面的前置后置简要代码,我们一起看看他的执行顺序

# coding=utf-8# authou:shichao# python测试社区学习记录
import pytest

class Testcaselist():
    # 类里面的    def setup(self):        print('setup:每个用例前开始执行')
    def teardown(self):        print('teardown:每个用例后开始执行')
    # 测试用例    def test_001(self):        print("正在执行第一条用例")        p = "Python"        assert "h" in p
    def test_002(self):        print("正在执行第二条用例")        p = 'test'        assert 't' in p
    if __name__ == '__main__':        pytest.main(['-s', 'test_fixtclass.py'])



以下是代码执行后控制台输出

Testing started at 17:29 ...F:\python3\python_code\venv\Scripts\python.exe "F:\PyCharm\PyCharm Community Edition 2019.2.2\helpers\pycharm\_jb_pytest_runner.py" --path F:/python3/python_code/Study/API_AutoTest_Pytest/test_fixtclass.pyLaunching pytest with arguments F:/python3/python_code/Study/API_AutoTest_Pytest/test_fixtclass.py in F:\python3\python_code\Study\API_AutoTest_Pytest
============================= test session starts =============================platform win32 -- Python 3.7.4, pytest-5.4.3, py-1.8.1, pluggy-0.13.1 -- F:\python3\python_code\venv\Scripts\python.execachedir: .pytest_cacherootdir: F:\python3\python_code\Study\API_AutoTest_Pytestcollecting ... collected 2 items
test_fixtclass.py::Testcaselist::test_001 setup:每个用例前开始执行PASSED                         [ 50%]正在执行第一条用例teardown:每个用例后开始执行
test_fixtclass.py::Testcaselist::test_002 setup:每个用例前开始执行PASSED                        [100%]正在执行第二条用例teardown:每个用例后开始执行

============================== 2 passed in 0.02s ==============================
Process finished with exit code 0

>>类里面的setup、teardown控制台输出解析

# 类里面的 [ 可以看到控制台输出的结果执行顺序 ]

test_fixtclass.py : test_001 >>setup:每个用例前开始执行>>PASSED>> [ 50%]正在执行第一条用例>>teardown:每个用例后开始执行

test_fixtclass.py : test_002 >>setup:每个用例前开始执行>>PASSED>> [100%]正在执行第二条用例>>teardown:每个用例后开始执行

这是我们的类里面的setup、teardown作用对类里的测试用例生效

* 类里面的在每条测试用例执行前都会去执行一次

图例01

02类级

接着我们在看看[ 类级setup_class、teardown_class前置与后置用法 ]

以下代码是类级的前置后置简要代码,我们一起看看他的执行顺序

# coding=utf-8
# authou:shichao
# python测试社区学习记录
import pytest




class Testcaselist():
    print('setup_class:所有用例执行之前')


# 类级
def setup_class(self):
    print('setup_class:所有用例执行之前')


def teardown_class(self):
    print('teardown_class:所有用例执行结束之后')


# 测试用例
def test_001(self):
    print("正在执行第一条用例")
    p = "Python"
    assert "h" in p


def test_002(self):
    print("正在执行第二条用例")
    p = 'test'
    assert 't' in p
    
if __name__ == '__main__':
    pytest.main(['-s', 'test_fixtclass.py'])


以下是代码执行后控制台输出

Testing started at 20:12 ...
F:\python3\python_code\venv\Scripts\python.exe "F:\PyCharm\PyCharm Community Edition 2019.2.2\helpers\pycharm\_jb_pytest_runner.py" --path F:/python3/python_code/Study/API_AutoTest_Pytest/test_fixtclass.py
Launching pytest with arguments F:/python3/python_code/Study/API_AutoTest_Pytest/test_fixtclass.py in F:\python3\python_code\Study\API_AutoTest_Pytest


============================= test session starts =============================
platform win32 -- Python 3.7.4, pytest-5.4.3, py-1.8.1, pluggy-0.13.1 -- F:\python3\python_code\venv\Scripts\python.exe
cachedir: .pytest_cache
rootdir: F:\python3\python_code\Study\API_AutoTest_Pytest
collecting ... collected 2 items


test_fixtclass.py::Testcaselist::test_001 setup_class:所有用例执行之前
PASSED                         [ 50%]正在执行第一条用例


test_fixtclass.py::Testcaselist::test_002 PASSED                         [100%]正在执行第二条用例
teardown_class:所有用例执行结束之后




============================== 2 passed in 0.02s ==============================


Process finished with exit code 0


>>类级setup_class、teardown_class控制台输出解析

# 类级 [ 我们可以看到控制台输出的结果执行顺序 ]

>>test_fixtclass.py:Testcaselist: >>setup_class:所有用例执行之前>>test_001 >>[ 50%]正在执行第一条用例>>PASSED  >>test_002>>[100%]正在执行第二条用例>>PASSED >>teardown_class:所有用例执行结束之后

* 类级前置后置只打开一次就执行所有的测试用例

图例02

03方法级

接着我们在看看[ 方法级setup_method、teardown_method在一个测试用例文件里一起写前置与后置用法 看看它的执行顺序 ]

以下代码是模块级的前置后置简要代码,我们一起看看他的执行顺序

# coding=utf-8# authou:shichao# python测试社区学习记录
import pytest

class Testcaselist():
    # 方法级    def setup_method(self):        print('setup_method:每个用例开始之前执行')
    def teardown_method(self):        print('teardown_method:每个用例结束后执行')
    # 测试用例    def test_001(self):        print("正在执行第一条用例")        p = "Python"        assert "h" in p
    def test_002(self):        print("正在执行第二条用例")        p = 'test'        assert 't' in p
    if __name__ == '__main__':        pytest.main(['-s', 'test_fixtclass.py'])

以下是代码执行后控制台输出

Testing started at 17:48 ...F:\python3\python_code\venv\Scripts\python.exe "F:\PyCharm\PyCharm Community Edition 2019.2.2\helpers\pycharm\_jb_pytest_runner.py" --path F:/python3/python_code/Study/API_AutoTest_Pytest/test_fixtclass.pyLaunching pytest with arguments F:/python3/python_code/Study/API_AutoTest_Pytest/test_fixtclass.py in F:\python3\python_code\Study\API_AutoTest_Pytest
============================= test session starts =============================platform win32 -- Python 3.7.4, pytest-5.4.3, py-1.8.1, pluggy-0.13.1 -- F:\python3\python_code\venv\Scripts\python.execachedir: .pytest_cacherootdir: F:\python3\python_code\Study\API_AutoTest_Pytestcollecting ... collected 2 items
test_fixtclass.py::Testcaselist::test_001 setup_method:每个用例开始之前执行PASSED                         [ 50%]正在执行第一条用例teardown_method:每个用例结束后执行
test_fixtclass.py::Testcaselist::test_002 setup_method:每个用例开始之前执行PASSED                         [100%]正在执行第二条用例teardown_method:每个用例结束后执行

============================== 2 passed in 0.02s ==============================
Process finished with exit code 0

>>方法级的setup_method、teardown_method控制台输出解析

# 类里面的 [ 可以看到控制台输出的结果执行顺序 ]

test_fixtclass.py : test_001 >>setup_method:每个用例开始之前执行>>PASSED>> [ 50%]正在执行第一条用例>>teardown_method:每个用例结束后执行

test_fixtclass.py : test_002 >>setup_method:每个用例开始之前执行>>PASSED>> [100%]正在执行第二条用例>>teardown_method:每个用例结束后执行

* 方法级的在每条测试用例执行前都会去执行一次

图例03

04类级+方法级+类里面的

接着我们在看看[ 类级+方法级setup、teardown、setup_class、teardown_class、setup_method、teardown_method在一个测试用例文件里一起写前置与后置用法 看看它的执行顺序 ]

以下代码是类级+模块级的前置后置简要代码,我们一起看看他的执行顺序

# coding=utf-8# authou:shichao# python测试社区学习记录
import pytest

class Testcaselist():
    # 类里面的    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_001(self):        print("正在执行第一条用例")        p = "Python"        assert "h" in p
    def test_002(self):        print("正在执行第二条用例")        p = 'test'        assert 't' in p
    if __name__ == '__main__':        pytest.main(['-s', 'test_fixtclass.py'])

以下是代码执行后控制台输出

Testing started at 17:57 ...F:\python3\python_code\venv\Scripts\python.exe "F:\PyCharm\PyCharm Community Edition 2019.2.2\helpers\pycharm\_jb_pytest_runner.py" --path F:/python3/python_code/Study/API_AutoTest_Pytest/test_fixtclass.pyLaunching pytest with arguments F:/python3/python_code/Study/API_AutoTest_Pytest/test_fixtclass.py in F:\python3\python_code\Study\API_AutoTest_Pytest
============================= test session starts =============================platform win32 -- Python 3.7.4, pytest-5.4.3, py-1.8.1, pluggy-0.13.1 -- F:\python3\python_code\venv\Scripts\python.execachedir: .pytest_cacherootdir: F:\python3\python_code\Study\API_AutoTest_Pytestcollecting ... collected 2 items
test_fixtclass.py::Testcaselist::test_001 setup_class:所有用例执行之前setup_method:每个用例开始之前执行setup:每个用例前开始执行PASSED                         [ 50%]正在执行第一条用例teardown:每个用例后开始执行teardown_method:每个用例结束后执行
test_fixtclass.py::Testcaselist::test_002 setup_method:每个用例开始之前执行setup:每个用例前开始执行PASSED                         [100%]正在执行第二条用例teardown:每个用例后开始执行teardown_method:每个用例结束后执行teardown_class:所有用例执行结束之后

============================== 2 passed in 0.02s ==============================
Process finished with exit code 0

>>类里面的+类级+方法级前置后置控制台输出解析

# 类里面的+类级+方法级 [ 我们可以看到控制台输出的结果执行顺序 ]

>>test_fixtclass.py::Testcaselist:setup_class:所有用例执行之前>>比如:所有用例开始前只打开一次浏览器

setup:每个用例前开始执行>>setup_method:每个用例开始之前执行>>test_001>>[ 50%]正在执行第一条用例>>PASSED >>teardown:每个用例后开始执行>>teardown_method:每个用例结束后执行

setup:每个用例前开始执行>>setup_method:每个用例开始之前执行>>test_002>>[ 50%]正在执行第一条用例>>PASSED >>teardown:每个用例后开始执行>>teardown_method:每个用例结束后执行

>>teardown_class:所有用例执行结束之后>>比如:所有用例结束只最后关闭浏览器

从结果看出,运行的优先级:setup_class>>setup_method>

setup >用例>teardown>teardown_method>>teardown_class

图例04

以上就是今天给大家介绍的pytest前置后置[ 类级以及方法级] 的用法以及在实际代码中他们的执行优先级,小小的顺序结构可能会影响你这条case是否执行通过,希望本次分享对大家有所帮助

注:本文内容来源于网络相关知识点综合总结,只作为知识分享,如有侵权可联系删除

日常积累,支持作者,可以将文章分享到朋友圈或点个在看,感谢大家的阅读!Bey , 下期再见

识别下方二维码,后台回复 "989" "Python" 领取 4G 入门到进阶成长资料

### Pytest 中的 SetupTeardown 方法Pytest 框架中,`setup()` 和 `teardown()` 是用于定义测试用例前后置操作的方法。这些方法可以应用于不同的作用域级别,例如模块级、类级或函数/方法级。 #### 函数级别的前置和后置处理 对于单个测试函数,可以通过定义 `setup_function` 和 `teardown_function` 来实现前置和后置逻辑[^1]: ```python def setup_function(function): print(f"Setup function {function.__name__}") def teardown_function(function): print(f"Teardown function {function.__name__}") def test_example(): assert True ``` 上述代码会在每次运行 `test_example` 前调用 `setup_function` 并在其完成后调用 `teardown_function`[^2]。 --- #### 类级别的前置和后置处理 如果多个测试方法共享相同的初始化资源,则可以在测试类中使用 `setup_class` 和 `teardown_class` 方法来管理这些资源[^3]: ```python class TestExample: @classmethod def setup_class(cls): print("Setup class") @classmethod def teardown_class(cls): print("Teardown class") def test_one(self): assert True def test_two(self): assert False ``` 在此示例中,`setup_class` 将在该类中的任何测试方法执行之前被调用一次,而 `teardown_class` 则将在所有测试方法完成之后被调用一次。 --- #### 方法级别的前置和后置处理 当需要为每个测试方法单独设置环境时,可使用 `setup_method` 和 `teardown_method`: ```python class TestMethodLevel: def setup_method(self, method): print(f"Setting up {method.__name__}") def teardown_method(self, method): print(f"Tearing down {method.__name__}") def test_first(self): assert True def test_second(self): assert False ``` 这里,每运行一个测试方法都会分别触发对应的 `setup_method` 和 `teardown_method` 调用。 --- #### 使用 Fixture 实现更灵活的 SetupTeardown 除了传统的 `setup_*` 和 `teardown_*` 方法外,Pytest 还支持通过 fixtures 提供更加灵活的方式来进行前置和后置处理: ```python import pytest @pytest.fixture(scope="module") def resource_setup(request): print("\nResource created!") def resource_teardown(): print("\nResource destroyed!") request.addfinalizer(resource_teardown) def test_with_fixture(resource_setup): assert True def test_another_with_fixture(resource_setup): assert False ``` 在这个例子中,fixture 的创建 (`resource_setup`) 发生于第一个依赖它的测试开始前;销毁 (`resource_teardown`) 则发生在最后一个依赖此 fixture 的测试结束后。 --- ### 总结 以上展示了多种方式在 Pytest 中实施测试用例的前置条件 (setup) 及清理工作 (teardown),具体选择取决于实际需求以及项目的复杂程度。
评论 2
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值