软件测试/测试开发全日制|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在整个测试周期执行结束后销毁

希望本文能够帮到大家!

相关文章
|
2月前
|
SQL 安全 Linux
Metasploit Pro 4.22.8-20251014 (Linux, Windows) - 专业渗透测试框架
Metasploit Pro 4.22.8-20251014 (Linux, Windows) - 专业渗透测试框架
150 1
Metasploit Pro 4.22.8-20251014 (Linux, Windows) - 专业渗透测试框架
|
2月前
|
Linux 网络安全 iOS开发
Metasploit Framework 6.4.95 (macOS, Linux, Windows) - 开源渗透测试框架
Metasploit Framework 6.4.95 (macOS, Linux, Windows) - 开源渗透测试框架
199 1
Metasploit Framework 6.4.95 (macOS, Linux, Windows) - 开源渗透测试框架
|
3月前
|
安全 Linux 网络安全
Metasploit Pro 4.22.8-2025091701 (Linux, Windows) - 专业渗透测试框架
Metasploit Pro 4.22.8-2025091701 (Linux, Windows) - 专业渗透测试框架
303 2
Metasploit Pro 4.22.8-2025091701 (Linux, Windows) - 专业渗透测试框架
|
3月前
|
Linux 网络安全 iOS开发
Metasploit Framework 6.4.90 (macOS, Linux, Windows) - 开源渗透测试框架
Metasploit Framework 6.4.90 (macOS, Linux, Windows) - 开源渗透测试框架
405 1
Metasploit Framework 6.4.90 (macOS, Linux, Windows) - 开源渗透测试框架
|
3月前
|
安全 Linux 网络安全
Metasploit Framework 6.4.88 (macOS, Linux, Windows) - 开源渗透测试框架
Metasploit Framework 6.4.88 (macOS, Linux, Windows) - 开源渗透测试框架
572 0
|
11月前
|
数据可视化 前端开发 测试技术
接口测试新选择:Postman替代方案全解析
在软件开发中,接口测试工具至关重要。Postman长期占据主导地位,但随着国产工具的崛起,越来越多开发者转向更适合中国市场的替代方案——Apifox。它不仅支持中英文切换、完全免费不限人数,还具备强大的可视化操作、自动生成文档和API调试功能,极大简化了开发流程。
|
6月前
|
Java 测试技术 容器
Jmeter工具使用:HTTP接口性能测试实战
希望这篇文章能够帮助你初步理解如何使用JMeter进行HTTP接口性能测试,有兴趣的话,你可以研究更多关于JMeter的内容。记住,只有理解并掌握了这些工具,你才能充分利用它们发挥其应有的价值。+
1020 23
|
8月前
|
SQL 安全 测试技术
2025接口测试全攻略:高并发、安全防护与六大工具实战指南
本文探讨高并发稳定性验证、安全防护实战及六大工具(Postman、RunnerGo、Apipost、JMeter、SoapUI、Fiddler)选型指南,助力构建未来接口测试体系。接口测试旨在验证数据传输、参数合法性、错误处理能力及性能安全性,其重要性体现在早期发现问题、保障系统稳定和支撑持续集成。常用方法包括功能、性能、安全性及兼容性测试,典型场景涵盖前后端分离开发、第三方服务集成与数据一致性检查。选择合适的工具需综合考虑需求与团队协作等因素。
1219 24
|
8月前
|
SQL 测试技术
除了postman还有什么接口测试工具
最好还是使用国内的接口测试软件,其实国内替换postman的软件有很多,这里我推荐使用yunedit-post这款接口测试工具来代替postman,因为它除了接口测试功能外,在动态参数的支持、后置处理执行sql语句等支持方面做得比较好。而且还有接口分享功能,可以生成接口文档给团队在线浏览。
349 2
|
10月前
|
JSON 前端开发 测试技术
大前端之前端开发接口测试工具postman的使用方法-简单get接口请求测试的使用方法-简单教学一看就会-以实际例子来说明-优雅草卓伊凡
大前端之前端开发接口测试工具postman的使用方法-简单get接口请求测试的使用方法-简单教学一看就会-以实际例子来说明-优雅草卓伊凡
761 10
大前端之前端开发接口测试工具postman的使用方法-简单get接口请求测试的使用方法-简单教学一看就会-以实际例子来说明-优雅草卓伊凡