pytest测试框架系列 - Pytest 用例之间相互依赖你会处理吗?

本文介绍了如何使用pytest-dependency插件管理测试用例的依赖关系。当增加操作用例失败时,后续的删除、修改和查询操作将不会执行。通过使用@pytest.mark.dependency()装饰器标记依赖,并指定depends参数引用相关用例。如果依赖用例失败,被依赖的用例将被跳过。文章提供了成功和失败的示例,并强调了当存在多个依赖时,只要一个失败,所有被依赖用例都将跳过。
摘要由CSDN通过智能技术生成

前言

场景:存在一个增删改查相关的操作功能,当增加操作用例失败时,删除、修改、查询操作不执行,这种场景该怎么来处理呢?

Pytest 框架提供了一个pytest-dependency 插件帮我们做了这件事情,我们只需要简单的使用即可。

pytest-dependency 详解 (建议掌握程度:☆☆☆☆)

安装

  • 在命令行窗口输入: pip install pytest-dependency
  • 查看安装版本:pip show pytest-dependency
    在这里插入图片描述

使用

使用方法 : 用 @pytest.mark.dependency()对所依赖的用例进行标记,使用@pytest.mark.dependency(depends=["测试用例名称"]) 引用依赖,测试用例名称可以是多个

说明:当依赖的用例执行失败,被依赖的用例直接跳过

依赖用例失败示例:

# !/usr/bin/python3
# _*_coding:utf-8 _*_
""""
# @Time  :2021/7/9 23:54
# @Author  : king
# @File    :test_dependency.py
# @Software  :PyCharm
# @blog     :https://blog.csdn.net/u010454117
# @WeChat Official Account: 【测试之路笔记】
"""
import pytest

@pytest.mark.dependency()
def test_add():
    print("我是 test_add 用例")
    assert False

@pytest.mark.dependency(depends=["test_add"])
def test_update():
    print("我是 test_update 用例")
    assert False

@pytest.mark.dependency(depends=["test_add"])
def test_delete():
    print("我是 test_delete 用例")
    assert True

@pytest.mark.dependency(depends=["test_add"])
def test_select():
    print("我是 test_select 用例")
    assert True

if __name__ == '__main__':
    pytest.main(["-s"])

执行结果:

Testing started at 23:59 ...
F:\pytest_demo\Scripts\python.exe "D:\JetBrains\PyCharm 2019.2.5\helpers\pycharm\_jb_pytest_runner.py" --path E:/pytest_demo/class_05/test_dependency.py
Launching pytest with arguments E:/pytest_demo/class_05/test_dependency.py in E:\pytest_demo\class_05
============================= test session starts =============================
platform win32 -- Python 3.7.0, pytest-6.2.4, py-1.10.0, pluggy-0.13.1 -- F:\pytest_demo\Scripts\python.exe
cachedir: .pytest_cache
rootdir: E:\pytest_demo\class_05
plugins: assume-2.4.3, dependency-0.5.1, ordering-0.6, rerunfailures-10.1
collecting ... collected 4 items
test_dependency.py::test_add FAILED                                      [ 25%]我是 test_add 用例
test_dependency.py:13 (test_add)
@pytest.mark.dependency()
    def test_add():
        print("我是 test_add 用例")
>       assert False
E       assert False
test_dependency.py:17: AssertionError
test_dependency.py::test_update SKIPPED (test_update depends on test...) [ 50%]
Skipped: test_update depends on test_add
test_dependency.py::test_delete SKIPPED (test_delete depends on test...) [ 75%]
Skipped: test_delete depends on test_add
test_dependency.py::test_select SKIPPED (test_select depends on test...) [100%]
Skipped: test_select depends on test_add
================================== FAILURES ===================================
__________________________________ test_add ___________________________________

    @pytest.mark.dependency()
    def test_add():
        print("我是 test_add 用例")
>       assert False
E       assert False

test_dependency.py:17: AssertionError
---------------------------- Captured stdout call -----------------------------
我是 test_add 用例
=========================== short test summary info ===========================
FAILED test_dependency.py::test_add - assert False
======================== 1 failed, 3 skipped in 0.04s =========================

Process finished with exit code 0
Assertion failed
Assertion failed

依赖用例成功示例:

# !/usr/bin/python3
# _*_coding:utf-8 _*_
""""
# @Time  :2021/7/9 23:54
# @Author  : king
# @File    :test_dependency.py
# @Software  :PyCharm
# @blog     :https://blog.csdn.net/u010454117
# @WeChat Official Account: 【测试之路笔记】
"""
import pytest

@pytest.mark.dependency()
def test_add():
    print("我是 test_add 用例")
    assert True

@pytest.mark.dependency(depends=["test_add"])
def test_update():
    print("我是 test_update 用例")
    assert False

@pytest.mark.dependency(depends=["test_add"])
def test_delete():
    print("我是 test_delete 用例")
    assert True

@pytest.mark.dependency(depends=["test_add"])
def test_select():
    print("我是 test_select 用例")
    assert True

if __name__ == '__main__':
    pytest.main(["-s"])

执行结果:
在这里插入图片描述
多个依赖用例存在失败示例:

# !/usr/bin/python3
# _*_coding:utf-8 _*_
""""
# @Time  :2021/7/9 23:54
# @Author  : king
# @File    :test_dependency.py
# @Software  :PyCharm
# @blog     :https://blog.csdn.net/u010454117
# @WeChat Official Account: 【测试之路笔记】
"""
import pytest

@pytest.mark.dependency()
def test_add():
    print("我是 test_add 用例")
    assert True

@pytest.mark.dependency()
def test_update():
    print("我是 test_update 用例")
    assert False

@pytest.mark.dependency(depends=["test_add", "test_update"])
def test_delete():
    print("我是 test_delete 用例")
    assert True

@pytest.mark.dependency(depends=["test_add"])
def test_select():
    print("我是 test_select 用例")
    assert True

if __name__ == '__main__':
    pytest.main(["-s"])

执行结果:
在这里插入图片描述

总结

  • @pytest.mark.dependency()对所依赖的用例进行标记,使用@pytest.mark.dependency(depends=["测试用例名称"]) 引用依赖,测试用例名称可以是多个
  • 用例多存在多个依赖时,只要存在一个依赖失败,被依赖用例就跳过,所有依赖成功才执行

以上为内容纯属个人理解,如有不足,欢迎各位大神指正,转载请注明出处!

如果觉得文章不错,欢迎关注微信公众号,微信公众号每天推送相关测试技术文章
个人微信号

评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

测试之路king

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值