软件测试/测试开发全日制|Pytest测试框架Fixture作用域详解

简介: 软件测试/测试开发全日制|Pytest测试框架Fixture作用域详解

前言

Pytest的fixtrue是存在作用域的,比如作用域为函数级别,那么没执行一条用例,就会重新执行一次fixtrue,如果是类级别,那么多个类执行时会在去执行fixture。fixture的作用域有5个,分别是: function,class,module,package,session。有了这些作用域我们可以不用重复的去执行fixture,从而节省时间。下面我们通过代码示例分别对这五种作用域来实验。

function作用域

function: 默认范围,fixture在测试结束时被销毁,示例代码如下:

import pytest


@pytest.fixture(scope="function")
def login():
    print("正在登录")


class TestDemo:
    def test_demo1(self, login):
        print("测试用例1")

    def test_demo2(self, login):
        print("测试用例2")

------------
运行结果如下:
============================= test session starts =============================
collecting ... collected 2 items

test_a.py::TestDemo::test_demo1 正在登录
PASSED                                   [ 50%]测试用例1

test_a.py::TestDemo::test_demo2 正在登录
PASSED                                   [100%]测试用例2


============================== 2 passed in 0.03s ==============================

我们可以看到正在登录执行了两次,也就是说我们的函数级别的fixture在每个用例执行前都会执行内部代码。

class作用域

class: fixture在类中的最后一个测试执行结束后销毁,示例代码如下:

import pytest


@pytest.fixture(scope="class")
def login():
    print("正在登录")


class TestDemo:
    def test_demo1(self, login):
        print("测试用例1")

    def test_demo2(self, login):
        print("测试用例2")

-------------------
运行结果如下:
============================= test session starts =============================
collecting ... collected 2 items

test_a.py::TestDemo::test_demo1 正在登陆
PASSED                                   [ 50%]测试用例1

test_a.py::TestDemo::test_demo2 PASSED                                   [100%]测试用例2


============================== 2 passed in 0.03s ==============================

我们可以看到与上面的方法级别相比,类级别只执行了一次正在登录

module作用域

module: fixture在模块中的最后一个测试执行结束后销毁,示例代码如下:

import pytest


@pytest.fixture(scope="module")
def login():
    print("正在登录")


class TestDemo:
    def test_demo1(self, login):
        print("测试用例1")

    def test_demo2(self, login):
        print("测试用例2")

def test_demo3(login):
    print("测试用例3")


def test_demo4(login):
    print("测试用例4")


--------------------
============================= test session starts =============================
collecting ... collected 4 items

test_a.py::TestDemo::test_demo1 正在登录
PASSED                                   [ 25%]测试用例1

test_a.py::TestDemo::test_demo2 PASSED                                   [ 50%]测试用例2

test_a.py::test_demo3 PASSED                                             [ 75%]测试用例3

test_a.py::test_demo4 PASSED                                             [100%]测试用例4


============================== 4 passed in 0.05s ==============================

我们可以看到正在登录执行了一次,我们在这个模块中有4条用例,有类也有函数,但就只执行了一次,说明我们定义的模块作用域生效了。

package作用域

package: fixture在包中的最后一个测试执行结束后销毁,整体的目录结构如下图:

在这里插入图片描述

  • 根目录:mytest
    • 二级目录: scripts
      • 三级目录:test_demo01.py
      • 三级目录: test_demo02.py
    • 二级目录: tests
      • 三级目录:test_demo01.py
      • 三级目录: test_demo02.py
    • 二级目录:conftest.py
    • 二级目录:test_demo.py

test_demo01.py内容如下:

def test_demo01(login):
    print("scripts包内的第一个测试用例")

其他的测试文件内容依次类推。

conftest.py内容如下:

import pytest

@pytest.fixture(scope="package")
# @pytest.fixture(scope="module")
def login():
    print("正在登陆")
    return "login"

执行结果如下:

======================================================================= test session starts =======================================================================
platform win32 -- Python 3.7.7, pytest-7.4.4, pluggy-1.2.0 -- C:\Users\89703\PycharmProjects\mytest\venv\Scripts\python.exe
cachedir: .pytest_cache
rootdir: C:\Users\89703\PycharmProjects
mytest/mytest/scripts/test_demo02.py::test_demo02 scripts包内的第二个测试用例
PASSED
mytest/tests/test_demo01.py::test_demo01 tests包内的第一个测试用例
PASSED
mytest/tests/test_demo02.py::test_demo02 tests包内的第二个测试用例
PASSED

======================================================================== 5 passed in 0.04s ========================================================================

session作用域

session: fixture在整个测试周期执行结束后销毁,我们只需要修改conftest.py的内容,示例如下:

conftest.py内容:

import pytest

@pytest.fixture(scope="session")
# @pytest.fixture(scope="module")
def login():
    print("正在登陆")
    return "login"

执行结果如下:

======================================================================= test session starts =======================================================================
platform win32 -- Python 3.7.7, pytest-7.4.4, pluggy-1.2.0 -- C:\Users\89703\PycharmProjects\mytest\venv\Scripts\python.exe
cachedir: .pytest_cache
rootdir: C:\Users\89703\PycharmProjects
collected 5 items                                                                                                                                                  

mytest/test_demo.py::test_demo 正在登陆
包外的测试用例
PASSED
mytest/mytest/scripts/test_demo01.py::test_demo01 scripts包内的第一个测试用例
PASSED
mytest/mytest/scripts/test_demo02.py::test_demo02 scripts包内的第二个测试用例
PASSED
mytest/tests/test_demo01.py::test_demo01 tests包内的第一个测试用例
PASSED
mytest/tests/test_demo02.py::test_demo02 tests包内的第二个测试用例
PASSED

======================================================================== 5 passed in 0.03s ========================================================================

总结

fixtrue作用范围:

  • function: 默认范围,fixture在测试结束时被销毁
  • class: fixture在类中的最后一个测试执行结束后销毁
  • module: fixture在模块中的最后一个测试执行结束后销毁
  • package: fixture在包中的最后一个测试执行结束后销毁
  • session: fixture在整个测试周期执行结束后销毁

希望本文能够帮到大家!

相关文章
|
4天前
|
人工智能 搜索推荐 数据管理
探索软件测试中的自动化测试框架选择与优化策略
本文深入探讨了在现代软件开发流程中,如何根据项目特性、团队技能和长期维护需求,精准选择合适的自动化测试框架。
39 8
|
5天前
|
安全 Ubuntu Linux
Metasploit Pro 4.22.6-2024111901 (Linux, Windows) - 专业渗透测试框架
Metasploit Pro 4.22.6-2024111901 (Linux, Windows) - 专业渗透测试框架
26 9
Metasploit Pro 4.22.6-2024111901 (Linux, Windows) - 专业渗透测试框架
|
9天前
|
Java 测试技术 API
探索软件测试中的自动化测试框架
本文深入探讨了自动化测试在软件开发中的重要性,并详细介绍了几种流行的自动化测试框架。通过比较它们的优缺点和适用场景,旨在为读者提供选择合适自动化测试工具的参考依据。
|
9天前
|
数据管理 jenkins 测试技术
自动化测试框架的设计与实现
在软件开发周期中,测试是确保产品质量的关键步骤。本文通过介绍自动化测试框架的设计原则、组件构成以及实现方法,旨在指导读者构建高效、可靠的自动化测试系统。文章不仅探讨了自动化测试的必要性和优势,还详细描述了框架搭建的具体步骤,包括工具选择、脚本开发、执行策略及结果分析等。此外,文章还强调了持续集成环境下自动化测试的重要性,并提供了实际案例分析,以帮助读者更好地理解和应用自动化测试框架。
|
9天前
|
敏捷开发 测试技术 持续交付
自动化测试之美:从零开始搭建你的Python测试框架
在软件开发的马拉松赛道上,自动化测试是那个能让你保持节奏、避免跌宕起伏的神奇小助手。本文将带你走进自动化测试的世界,用Python这把钥匙,解锁高效、可靠的测试框架之门。你将学会如何步步为营,构建属于自己的测试庇护所,让代码质量成为晨跑时清新的空气,而不是雾霾中的忧虑。让我们一起摆脱手动测试的繁琐枷锁,拥抱自动化带来的自由吧!
|
28天前
|
JSON Java 测试技术
SpringCloud2023实战之接口服务测试工具SpringBootTest
SpringBootTest同时集成了JUnit Jupiter、AssertJ、Hamcrest测试辅助库,使得更容易编写但愿测试代码。
55 3
|
2月前
|
JSON 算法 数据可视化
测试专项笔记(一): 通过算法能力接口返回的检测结果完成相关指标的计算(目标检测)
这篇文章是关于如何通过算法接口返回的目标检测结果来计算性能指标的笔记。它涵盖了任务描述、指标分析(包括TP、FP、FN、TN、精准率和召回率),接口处理,数据集处理,以及如何使用实用工具进行文件操作和数据可视化。文章还提供了一些Python代码示例,用于处理图像文件、转换数据格式以及计算目标检测的性能指标。
71 0
测试专项笔记(一): 通过算法能力接口返回的检测结果完成相关指标的计算(目标检测)
|
3月前
|
移动开发 JSON Java
Jmeter实现WebSocket协议的接口测试方法
WebSocket协议是HTML5的一种新协议,实现了浏览器与服务器之间的全双工通信。通过简单的握手动作,双方可直接传输数据。其优势包括极小的头部开销和服务器推送功能。使用JMeter进行WebSocket接口和性能测试时,需安装特定插件并配置相关参数,如服务器地址、端口号等,还可通过CSV文件实现参数化,以满足不同测试需求。
256 7
Jmeter实现WebSocket协议的接口测试方法
|
3月前
|
JSON 移动开发 监控
快速上手|HTTP 接口功能自动化测试
HTTP接口功能测试对于确保Web应用和H5应用的数据正确性至关重要。这类测试主要针对后台HTTP接口,通过构造不同参数输入值并获取JSON格式的输出结果来进行验证。HTTP协议基于TCP连接,包括请求与响应模式。请求由请求行、消息报头和请求正文组成,响应则包含状态行、消息报头及响应正文。常用的请求方法有GET、POST等,而响应状态码如2xx代表成功。测试过程使用Python语言和pycurl模块调用接口,并通过断言机制比对实际与预期结果,确保功能正确性。
270 3
快速上手|HTTP 接口功能自动化测试
|
3月前
|
JavaScript 前端开发 测试技术
ChatGPT与接口测试
ChatGPT与接口测试,测试通过
55 5