【pytest】Pytest框架 conftest.py文件的使用详解

conftest.py是pytest特有的本地测试配置文件,既可以用来设置项目级别的fixture,也可以用来导入外部插件,本文给大家介绍Pytest框架 conftest.py文件的使用,感兴趣的朋友一起看看吧

conftest.py文件特点

  • 所有同目录测试文件运行前都会执行conftest.py文件 不需要import导入
  • conftest.py,pytest用例会自动识别该文件,放到项目的根目录下就可以全局目录调用了,如果放到某个package下,那就在该package内有效,可有多个conftest.py
  • conftest.py与运行的用例要在同一个pakage下,并且有__init__.py文件
  • 可以跨.py文件调用,有多个.py文件调用时,可让conftest.py只调用了一次fixture,或调用多次fixture

1、conftest.py文件介绍

conftest.py文件是Pytest框架里面一个很重要的东西,它可以在这个文件里面编写Fixture函数,这个Fixture函数的作用,就相当于Unittest框架里面的setup()前置函数和teardown()后置函数,虽然Pytest框架也有setup()前置函数和teardown()后置函数,但是在实际工作中没必要写在测试用例文件中,直接写在conftests.py里面就好了,Pytest框架会自动去找conftest.py文件里面的东西,这样更灵活。
总结:在实际工作中,通常conftest.py@pytest.fixture()结合使用,实现全局的前后置应用。

2、conftest.py的注意事项

  1. conftest.py文件是单独存放的一个夹具(Fixture)配置文件,名称是不能更改。
  2. 可以在不同的.py文件中使用同一个Fixture函数。
  3. 原则上conftest.py需要和运行的用例放到同一目录中,并且有__init__.py文件,那么conftest.py作用于整个目录。
  4. 如果希望Fixture(夹具)共享给所有测试,则可以把conftest.py文件放在测试框架的根目录下。
  5. conftest.py文件中的内容,不需要做任何的imprt导入的操作就能够读取到,因为Pytest用例会自动查找。
  6. 建议把测试项目的所有Fixture都存放在conftest.py文件中,把conftest.py当作Pytest的Fixture仓库。

3、conftest.py的使用

(1)测试框架的根目录或者包中创建conftest.py文件

"""
1.学习目标
    掌握conftest.py文件编写格式
2.操作步骤
    2.1 conftest.py文件名不能修改
        conftest.py文件中存放项目所有的fixture
        方便对fixture管理和维护
    2.2 在conftest.py定义函数
        在函数前添加@pytest.fixture()装饰器
        在测试用例的函数中传入fixture标识的函数名。
提示:conftest.py文件放在项目的根目录,作用域是全局的。
    conftest.py文件放在某一个包下,作用域只在该包内。
"""
import pytest
from selenium import webdriver
@pytest.fixture()
def login():
    print("打开APP")
    print("登录成功")
    yield  # 当用例执行完成后,执行yield后的代码
    print("关闭APP")
@pytest.fixture()
def driver(request):  # request是Pytest中的一个关键字,固定写法。
    # 步骤1:创建浏览器驱动对象
    driver = webdriver.Chrome()
    # 步骤3:定义用例执行后要执行的代码,封装到一个函数中
    def end():  # 这个end函数命是自定义的
        driver.quit()
    # 步骤4:执行上面封装的代码。
    # 通过request关键字,结束上面的函数。
    request.addfinalizer(end)  # 终结函数
    # 步骤2:返回浏览器驱动对象,给测试用例
    return driver

(2)测试用例文件如下 

import pytest
# 注意:要把conftest.py文件中定义的fixture方法添加到用例中
def test_add_cart(login): # 把conftest.py文件中的fixture函数传入用例
    print("添加购物车--需要登录")
def test_add_address(login):
    print("添加收货地址--需要登录")
if __name__ == '__main__':
    pytest.main()
"""
执行结果:
test_01.py::test_add_cart 打开APP
登录成功
添加购物车--需要登录
PASSED关闭APP
test_01.py::test_add_address 打开APP
登录成功
添加收货地址--需要登录
PASSED关闭APP
""" 

4、不同位置conftest.py文件的优先级

其作用范围是当前目录包括子目录里的测试模块。

  • 比如在测试框架的根目录创建conftest.py文件,文件中的Fixture的作用范围是所有测试模块。
  • 比如在某个单独的测试文件夹里创建conftest.py文件,文件中Fixture的作用范围,就仅局限于该测试文件夹里的测试模块。
  • 该测试文件夹外的测试模块,或者该测试文件夹外的测试文件夹,是无法调用到这个conftest.py文件中的Fixture。
  • 如果测试框架的根目录和子包中都有conftest.py文件,并且这两个conftest.py文件中都有一个同名的Fixture,实际生效的是测试框架中子包目录下的conftest.py文件中配置的Fixture。
  • 提示:一个用例可以添加多个conftest.py文件中定义的Fixture夹具,如下:

# 注意:要把conftest.py文件中定义的fixture方法添加到用例中
def test_add_cart(login, driver):
    print("添加购物车--需要登录") 

5、conftest.py中Fixture(夹具)的作用域

Fixture的scope参数也适用conftest.py文件中Fixture的特性:

  • conftest.py文件中Fixture的scope参数为session,那么所有的测试文件执行前(后)执行一次conftest.py文件中的Fixture。
  • conftest.py文件中Fixture的scope参数为module,那么每一个测试文件执行前(后)都会执行一次conftest.py文件中Fixture。
  • conftest.py文件中Fixture的scope参数为class,那么每一个测试文件中的测试类执行前(后)都会执行一次conftest.py文件中Fixture。
  • conftest.py文件中Fixture的scope参数为function,那么所有文件的测试用例执行前(后)都会执行一次conftest.py文件中Fixture。

6、总结:

  • Pytest框架中的setup()/teardown()函数,setup_class()/teardown_class()函数。他们是作用于所有用例或者所有类的。
  • @pytest.fixtrue()的作用域是既可以部分用例,也可以全部用例的前后置。
  • conftest.py文件和@pytest.fxtrue()装饰器结合使用,作用于全局用例的前后置。

到此这篇关于Pytest框架 conftest.py文件的使用详解的文章就介绍到这了

原文链接:https://www.jb51.net/article/250217.htm

### pytest 框架详解 #### 测试能力与特点 Pytest 提供了强大的验收测试功能,类似于 Robot Framework 的能力[^1]。这一工具最显著的特点在于提供详细的失败信息反馈,帮助开发者迅速定位并修正问题。 #### 兼容性和扩展性 此框架不仅支持最新的 Python 版本,而且兼容多个其他测试框架如 unittest、doctest 和 nose,实现了无缝集成。此外,pytest 社区维护着超过300个插件,极大地增强了测试的功能和灵活性。 #### 设计理念 为了简化代码编写过程并减少错误发生几率,pytest 被精心设计成易于使用的自动化测试解决方案。它允许使用者结合像 Selenium 或者 Splinter 这样的 GUI 工具来进行更加直观便捷的操作。 --- ### 实战项目案例分析 假设有一个简单的 Web 应用程序需要进行全面的单元测试和集成测试。下面将展示如何利用 pytest 来构建这样一个完整的测试套件: #### 安装依赖项 首先确保环境中已经安装好了必要的库文件: ```bash pip install pytest selenium splinter requests ``` #### 编写基本结构化测试脚本 创建名为 `tests` 文件夹,并在其内部建立如下所示的基础架构: - tests/ - conftest.py (配置全局设置) - test_webapp.py (具体页面逻辑验证) ##### 配置全局参数 (`conftest.py`) ```python import pytest from splinter import Browser @pytest.fixture(scope="module") def browser(): """启动浏览器实例""" b = Browser('chrome') yield b b.quit() ``` ##### 页面交互测试 (`test_webapp.py`) ```python def test_homepage_title(browser): url = "http://example.com" # 访问目标网址 browser.visit(url) assert "Example Domain" in browser.title, f"{url} title does not match expected value." ``` 以上例子展示了怎样通过 pytest 结合 splinter 插件实现对网页应用首页标题栏内容的有效校验。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值