我的编程空间,编程开发者的网络收藏夹
学习永远不晚

Pytest自动化测试框架如何使用

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

Pytest自动化测试框架如何使用

这篇文章主要讲解了“Pytest自动化测试框架如何使用”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Pytest自动化测试框架如何使用”吧!

    Pytest和Unittest测试框架的区别?

    如何区分这两者,很简单unittest作为官方的测试框架,在测试方面更加基础,并且可以再次基础上进行二次开发,同时在用法上格式会更加复杂;而pytest框架作为第三方框架,方便的地方就在于使用更加灵活,并且能够对原有unittest风格的测试用例有很好的兼容性,同时在扩展上更加丰富,可通过扩展的插件增加使用的场景,比如一些并发测试等;

    Pytest 安装

    pip安装:

    pip install pytest

    测试安装成功:

    pytest --helppy.test --help

    检查安装版本:

    pytest --version

    Pytest 示例

    Pytest编写规则:

    • 测试文件以test_开头(以_test为结尾)

    • 测试的类以Test开头;

    • 测试的方法以test_开头

    • 断言使用基本的assert

    test_example.py

    def count_num(a: list) -> int:    return len(a)  def test_count():    assert count_num([1, 2, 3]) != 3

    执行测试:

    pytest test_example.py

    执行结果:

    C:\Users\libuliduobuqiuqiu\Desktop\GitProjects\PythonDemo\pytest>pytest test_example.py -v
    ================================================================= test session starts =================================================================
    platform win32 -- Python 3.6.8, pytest-6.2.5, py-1.10.0, pluggy-1.0.0 -- d:\coding\python3.6\python.exe
    cachedir: .pytest_cache
    rootdir: C:\Users\libuliduobuqiuqiu\Desktop\GitProjects\PythonDemo\pytest
    plugins: Faker-8.11.0
    collected 1 item                                                                                                                                       
     
    test_example.py::test_count FAILED                                                                                                               [100%]
     
    ====================================================================== FAILURES =======================================================================
    _____________________________________________________________________ test_count ______________________________________________________________________
     
        def test_count():
    >       assert count_num([1, 2, 3]) != 3
    E       assert 3 != 3
    E        +  where 3 = count_num([1, 2, 3])
     
    test_example.py:11: AssertionError
    =============================================================== short test summary info ===============================================================
    FAILED test_example.py::test_count - assert 3 != 3
    ================================================================== 1 failed in 0.16s ==================================================================

    备注:

    • .代表测试通过,F代表测试失败;

    • -v显示详细的测试信息, -h显示pytest命令详细的帮助信息;

    标记

    默认情况下,pytest会在当前目录下寻找以test_为开头(以_test结尾)的测试文件,并且执行文件内所有以test_为开头(以_test为结尾)的所有函数和方法;

    指定运行测试用例,可以通过::显示标记(文件名::类名::方法名)(文件名::函数名)

    pytest test_example3.py::test_odd

    指定一些测试用例测试运行,可以使用-k模糊匹配

    pytest -k example

    通过pytest.mark.skip()或者pytest.makr.skipif()条件表达式,跳过指定的测试用例

    import pytest test_flag = False @pytest.mark.skip()def test_odd():    num = random.randint(0, 100)    assert num % 2 == 1  @pytest.mark.skipif(test_flag is False, reason="test_flag is False")def test_even():    num = random.randint(0, 1000)    assert num % 2 == 0

    通过pytest.raises()捕获测试用例可能抛出的异常

    def test_zero():    num = 0    with pytest.raises(ZeroDivisionError) as e:        num = 1/0    exc_msg = e.value.args[0]    print(exc_msg)    assert num == 0

    预先知道测试用例会失败,但是不想跳过,需要显示提示信息,使用pytest.mark.xfail()

    @pytest.mark.xfail()def test_sum():    random_list = [random.randint(0, 100)  for x in range(10)]    num = sum(random_list)    assert num < 20

    对测试用例进行多组数据测试,每组参数都能够独立执行一次(可以避免测试用例内部执行单组数据测试不通过后停止测试)

    @pytest.mark.parametrize('num,num2', [(1,2),(3,4)])def test_many_odd(num: int, num2: int):    assert num % 2 == 1    assert num2 % 2 == 0

    固件(Fixture)

    固件就是一些预处理的函数,pytest会在执行测试函数前(或者执行后)加载运行这些固件,常见的应用场景就有数据库的连接和关闭(设备连接和关闭)

    简单使用

    import pytest @pytest.fixture()def postcode():    return "hello"def test_count(postcode):    assert postcode == "hello"

    按照官方的解释就是当运行测试函数,会首先检测运行函数的参数,搜索与参数同名的fixture,一旦pytest找到,就会运行这些固件,获取这些固件的返回值(如果有),并将这些返回值作为参数传递给测试函数;

    预处理和后处理

    接下来进一步验证关于官方的说法:

    import pytest @pytest.fixture()def connect_db():    print("Connect Database in .......")    yield    print("Close Database out .......") def read_database(key: str):    p_info = {        "name": "zhangsan",        "address": "China Guangzhou",        "age": 99    }    return p_info[key] def test_count(connect_db):    assert read_database("name") == "zhangsan"

    执行测试函数结果:

    ============================= test session starts =============================
    platform win32 -- Python 3.6.8, pytest-6.2.5, py-1.10.0, pluggy-1.0.0 -- D:\Coding\Python3.6\python.exe
    cachedir: .pytest_cache
    rootdir: C:\Users\libuliduobuqiuqiu\Desktop\GitProjects\PythonDemo\pytest
    plugins: Faker-8.11.0
    collecting ... collected 1 item
     
    test_example.py::test_count Connect Database in .......
    PASSED                                       [100%]Close Database out .......
     
     
    ============================== 1 passed in 0.07s ==============================

    备注:

    • 首先从结果上看验证了官方的解释,pytest执行测试函数前会寻找同名的固件加载运行;

    • connect_db固件中有yield,这里pytest默认会判断yield关键词之前的代码属于预处理,会在测试前执行,yield之后的代码则是属于后处理,将在测试后执行;

    作用域

    从前面大致了解了固件的作用,抽离出一些重复的工作方便复用,同时pytest框架中为了更加精细化控制固件,会使用作用域来进行指定固件的使用范围,(比如在这一模块中的测试函数执行一次即可,不需要模块中的函数重复执行)更加具体的例子就是数据库的连接,这一连接的操作可能是耗时的,我只需要在这一模块的测试函数运行一次即可,不需要每次都运行。

    而定义固件是,一般通过scop参数来声明作用,常用的有:

    • function: 函数级,每个测试函数都会执行一次固件;

    • class: 类级别,每个测试类执行一次,所有方法都可以使用;

    • module: 模块级,每个模块执行一次,模块内函数和方法都可使用;

    • session: 会话级,一次测试只执行一次,所有被找到的函数和方法都可用。

    import pytest  @pytest.fixture(scope="function")def func_scope():    print("func_scope")  @pytest.fixture(scope="module")def mod_scope():    print("mod_scope") @pytest.fixture(scope="session")def sess_scope():    print("session_scope")  def test_scope(sess_scope, mod_scope, func_scope):    pass def test_scope2(sess_scope, mod_scope, func_scope):    pass

    执行结果:

    ============================= test session starts =============================
    platform win32 -- Python 3.6.8, pytest-6.2.5, py-1.10.0, pluggy-1.0.0 -- D:\Coding\Python3.6\python.exe
    cachedir: .pytest_cache
    rootdir: C:\Users\libuliduobuqiuqiu\Desktop\GitProjects\PythonDemo\pytest
    plugins: Faker-8.11.0
    collecting ... collected 2 items
     
    test_example2.py::test_scope session_scope
    mod_scope
    func_scope
    PASSED                                      [ 50%]
    test_example2.py::test_scope2 func_scope
    PASSED                                     [100%]
     
    ============================== 2 passed in 0.07s ==============================

    从这里可以看出module,session作用域的固件只执行了一次,可以验证官方的使用介绍

    自动执行

    有人可能会说,这样子怎么那么麻烦,unittest框架中直接定义setUp就能自动执行预处理,同样的pytest框架也有类似的自动执行; pytest框架中固件一般通过参数autouse控制自动运行。

    import pytest @pytest.fixture(scope='session', autouse=True)def connect_db():   print("Connect Database in .......")   yield   print("Close Database out .......")  def test1():   print("test1")  def test2():   print("test")

    执行结果:

    ============================= test session starts =============================
    platform win32 -- Python 3.6.8, pytest-6.2.5, py-1.10.0, pluggy-1.0.0 -- D:\Coding\Python3.6\python.exe
    cachedir: .pytest_cache
    rootdir: C:\Users\libuliduobuqiuqiu\Desktop\GitProjects\PythonDemo\pytest
    plugins: Faker-8.11.0
    collecting ... collected 2 items
     
    test_example.py::test1 Connect Database in .......
    PASSED                                            [ 50%]test1
     
    test_example.py::test2 PASSED                                            [100%]test
    Close Database out .......
     
     
    ============================== 2 passed in 0.07s ==============================

    从结果看到,测试函数运行前后自动执行了connect_db固件;

    参数化

    前面简单的提到过了@pytest.mark.parametrize通过参数化测试,而关于固件传入参数时则需要通过pytest框架中内置的固件request,并且通过request.param获取参数

    import pytest @pytest.fixture(params=[    ('redis', '6379'),    ('elasticsearch', '9200')])def param(request):    return request.param  @pytest.fixture(autouse=True)def db(param):    print('\nSucceed to connect %s:%s' % param)     yield     print('\nSucceed to close %s:%s' % param) def test_api():    assert 1 == 1

    执行结果:

    ============================= test session starts =============================
    platform win32 -- Python 3.6.8, pytest-6.2.5, py-1.10.0, pluggy-1.0.0 -- D:\Coding\Python3.6\python.exe
    cachedir: .pytest_cache
    rootdir: C:\Users\libuliduobuqiuqiu\Desktop\GitProjects\PythonDemo\pytest
    plugins: Faker-8.11.0
    collecting ... collected 2 items
     
    test_example.py::test_api[param0] 
    Succeed to connect redis:6379
    PASSED                                 [ 50%]
    Succeed to close redis:6379
     
    test_example.py::test_api[param1] 
    Succeed to connect elasticsearch:9200
    PASSED                                 [100%]
    Succeed to close elasticsearch:9200
     
     
    ============================== 2 passed in 0.07s ==============================

    这里模拟连接redis和elasticsearch,加载固件自动执行连接然后执行测试函数再断开连接。

    感谢各位的阅读,以上就是“Pytest自动化测试框架如何使用”的内容了,经过本文的学习后,相信大家对Pytest自动化测试框架如何使用这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是编程网,小编将为大家推送更多相关知识点的文章,欢迎关注!

    免责声明:

    ① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

    ② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

    Pytest自动化测试框架如何使用

    下载Word文档到电脑,方便收藏和打印~

    下载Word文档

    猜你喜欢

    Pytest自动化测试框架如何使用

    这篇文章主要讲解了“Pytest自动化测试框架如何使用”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Pytest自动化测试框架如何使用”吧!Pytest和Unittest测试框架的区别?如何
    2023-07-05

    Pytest自动化测试框架的使用

    本文主要介绍了Pytest自动化测试框架的使用,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2023-03-19

    Python测试框架pytest如何使用

    本文小编为大家详细介绍“Python测试框架pytest如何使用”,内容详细,步骤清晰,细节处理妥当,希望这篇“Python测试框架pytest如何使用”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。前言pytes
    2023-06-30

    自动化测试框架pytest的Fixture固件怎么调用

    本篇内容介绍了“自动化测试框架pytest的Fixture固件怎么调用”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!什么是固件Fixture
    2023-07-05

    C#中如何使用单元测试框架进行自动化测试

    C#中如何使用单元测试框架进行自动化测试引言:在软件开发过程中,自动化测试是一个非常重要的环节。通过编写和运行测试代码,可以帮助我们验证和确保代码的正确性和稳定性。在C#开发中,我们可以使用单元测试框架来实现自动化测试。本文将介绍C#中常用
    2023-10-22

    Python测试框架pytest怎么使用

    这篇文章主要介绍了Python测试框架pytest怎么使用的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇Python测试框架pytest怎么使用文章都会有所收获,下面我们一起来看看吧。一、Pytest简介Pyt
    2023-06-29

    python自动化测试框架pytest和unittest的区别是什么

    这篇文章给大家介绍python自动化测试框架pytest和unittest的区别是什么,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。一、用例设计规则1.unittest(1)测试类必须继承unittest.TestCa
    2023-06-02

    Python自动化测试框架之unittest使用详解

    unittest是Python自动化测试框架之一,提供了一系列测试工具和接口,支持单元测试、功能测试、集成测试等多种测试类型。unittest使用面向对象的思想实现测试用例的编写和管理,可以方便地扩展和定制测试框架,支持多种测试结果输出格式
    2023-05-18

    Pytest接口自动化测试框架搭建模板的示例分析

    小编给大家分享一下Pytest接口自动化测试框架搭建模板的示例分析,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!auto_api_test开发环境: Pychar
    2023-06-14

    编程热搜

    • Python 学习之路 - Python
      一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
      Python 学习之路 - Python
    • chatgpt的中文全称是什么
      chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
      chatgpt的中文全称是什么
    • C/C++中extern函数使用详解
    • C/C++可变参数的使用
      可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
      C/C++可变参数的使用
    • css样式文件该放在哪里
    • php中数组下标必须是连续的吗
    • Python 3 教程
      Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
      Python 3 教程
    • Python pip包管理
      一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
      Python pip包管理
    • ubuntu如何重新编译内核
    • 改善Java代码之慎用java动态编译

    目录