pytest.ini配置文件

概述

pytest.ini 是 Pytest 测试框架的配置文件,用于指定测试运行时的各种配置选项。通过编辑 pytest.ini 文件,可以定制测试运行的行为,例如设置测试目录、指定测试文件匹配模式、配置测试报告、定义测试标记等。

用途

pytest.ini 文件的主要用途是配置 Pytest 测试框架的行为,包括但不限于:

设置测试文件匹配模式: 可以通过 python_files 选项指定测试文件的匹配模式,使得 Pytest 只运行符合指定模式的测试文件。

指定测试文件目录: 使用 testpaths 选项可以指定 Pytest 在哪些目录下查找测试文件,这样可以灵活地组织测试代码。

添加命令行选项: 通过 addopts 选项可以添加额外的命令行选项,例如设置测试输出的详细程度、指定测试标记、设置并发测试等。

定义测试标记: 使用 markers 选项可以定义自定义的测试标记,以便对测试进行分类和管理,例如将一些测试标记为 smoke、regression 等。

严格处理 XFail 测试: 可以通过 xfail_strict 选项设置是否严格处理 XFail 测试,即是否要求 XFail 测试必须失败才算通过。

指定生成测试报告的格式: 使用 junit_family 选项可以指定生成 JUnitXML 格式的测试报告,以便与其他测试工具集成。

配置内容

执行pytest -h查看可用于pytest.ini的所有配置项,内容如下:

markers (linelist): 为测试函数注册新的标记
empty_parameter_set_mark (string): 空参数集的默认标记
norecursedirs (args): 递归时要避免搜索的目录模式
testpaths (args): 当命令行上没有给出文件或目录时,要搜索测试的目录
filterwarnings (linelist): 每行指定一个 warnings.filterwarnings 的模式。在 -W/--pythonwarnings 之后处理。
consider_namespace_packages (bool): 在导入时解析模块名称时考虑命名空间包
usefixtures (args): 要与此项目一起使用的默认装置列表
python_files (args): 用于 Python 测试模块发现的 Glob 样式文件模式
python_classes (args): 用于 Python 测试类发现的前缀或 Glob 名称
python_functions (args): 用于 Python 测试函数和方法发现的前缀或 Glob 名称
disable_test_id_escaping_and_forfeit_all_rights_to_community_support (bool): 禁用字符串转义非 ASCII 字符,可能导致意外的副作用(自行承担风险使用)
console_output_style (string): 控制台输出风格: "classic",或带有附加进度信息 ("progress" (百分比) | "count" | "progress-even-when-capture-no" (即使 capture=no 也强制显示进度)
verbosity_test_cases (string): 指定测试用例执行的详细程度,覆盖主要级别。更高的级别将提供有关每个执行的测试用例的更详细信息。
xfail_strict (bool): xfail 标记的 strict 参数的默认值(默认值:False)
tmp_path_retention_count (string): 根据 tmp_path_retention_policy 控制我们应该保留多少个 tmp_path 目录。
tmp_path_retention_policy (string): 根据测试结果控制由 tmp_path 装置创建的目录的保留情况。(all/failed/none)
enable_assertion_pass_hook (bool): 启用 pytest_assertion_pass 钩子。确保删除任何以前生成的 pyc 缓存文件。
verbosity_assertions (string): 指定断言的详细程度,覆盖主要级别。更高的级别将在断言失败时提供更详细的解释。
junit_suite_name (string): JUnit 报告的测试套件名称
junit_logging (string): 将捕获的日志消息写入 JUnit 报告: 选择 no|log|system-out|system-err|out-err|all 之一
junit_log_passing_tests (bool): 将捕获的日志信息包含在传递测试的 JUnit 报告中
junit_duration_report (string): 要报告的持续时间: total|call 中的一个
junit_family (string): 为模式发出 XML: legacy|xunit1|xunit2 中的一个
doctest_optionflags (args): doctests 的选项标志
doctest_encoding (string): 用于 doctest 文件的编码
cache_dir (string): 缓存目录路径
log_level (string): --log-level 的默认值
log_format (string): --log-format 的默认值
log_date_format (string): --log-date-format 的默认值
log_cli (bool): 在测试运行期间启用日志显示(也称为“实时日志记录”)
log_cli_level (string): --log-cli-level 的默认值
log_cli_format (string): --log-cli-format 的默认值
log_cli_date_format (string): --log-cli-date-format 的默认值
log_file (string): --log-file 的默认值
log_file_mode (string): --log-file-mode 的默认值
log_file_level (string): --log-file-level 的默认值
log_file_format (string): --log-file-format 的默认值
log_file_date_format (string): --log-file-date-format 的默认值
log_auto_indent (string): --log-auto-indent 的默认值
pythonpath (paths): 将路径添加到 sys.path
faulthandler_timeout (string): 如果测试花费超过 TIMEOUT 秒,则转储所有线程的回溯信息。

pytest.ini 文件中可以包含以下类型的配置:

命令行选项: 通过在 pytest.ini 文件中设置 addopts 选项,用户可以为 pytest 命令行工具提供默认参数,从而在每次运行 pytest 时自动应用这些参数。

插件配置: 使用 plugins 选项,用户可以指定要加载的 pytest 插件。这使用户能够启用额外的功能或集成其他测试工具,从而定制 pytest 的行为。

环境变量: 用户可以在 pytest.ini 文件中定义环境变量,这些变量可以在测试代码中通过标准的环境变量访问机制获取。这样可以在测试运行时动态地设置和使用环境变量。

测试发现: 通过配置选项,如 norecursedirs 和 testpaths,用户可以定制 pytest 如何发现测试。这些选项允许用户指定 pytest 在哪些目录下搜索测试文件,以及忽略哪些目录。

日志和其他设置: pytest.ini 还允许用户配置日志行为、修改测试报告格式等。通过设置相关的配置选项,用户可以调整 pytest 的日志输出和测试报告的格式,以满足特定的需求和偏好。

配置文件示例

# pytest.ini# 命令行选项
[pytest]
addopts = -v -s --html=reports/test_report.html# 插件配置
[pytest]
plugins =pytest-xdistpytest-cov# 环境变量
[pytest]
env =ENVIRONMENT=developmentDATABASE_URL=sqlite:///:memory:# 测试发现
[pytest]
testpaths = tests
norecursedirs = .* build dist CVS _darcs {arch} *.egg venv# 日志和其他设置
[pytest]
log_format = %(asctime)s [%(levelname)s] %(message)s
log_date_format = %Y-%m-%d %H:%M:%S

addopts 配置

[pytest]
addopts = -v -s --html=reports/test_report.html

在这个示例中,addopts 设置了三个常用的 Pytest 命令行选项:

-v:增加输出的详细程度,显示每个测试用例的执行结果。
-s:允许将测试的输出打印到控制台,而不是被捕获并隐藏。
–html=reports/test_report.html:生成 HTML 格式的测试报告,并将其保存到指定的文件中(在这个例子中是 reports/test_report.html)。

收集用例规则配置

[pytest]# 指定测试文件的匹配模式,以确定哪些文件包含测试用例
python_files =     test_*  *_test  test*
python_classes =   Test*   test*
python_functions = test_*  test*# 指定要搜索测试文件的目录
testpaths = tests# 指定不要递归搜索的目录
norecursedirs =.*     # 忽略隐藏目录build  # 忽略 build 目录dist   # 忽略 dist 目录CVS    # 忽略 CVS 目录_darcs # 忽略 _darcs 目录{arch} # 忽略特定版本控制目录*.egg  # 忽略 .egg 目录venv   # 忽略虚拟环境目录

在这个示例中:

python_files 配置了测试文件的匹配模式,表示只有文件名符合 test_*.py 的文件会被识别为测试文件,其中 * 表示通配符,可以匹配任意字符。这样可以避免误将非测试文件识别为测试文件。

testpaths 指定了测试文件所在的目录。在这个示例中,测试文件应该存放在名为 tests 的目录下。

norecursedirs 指定了不要递归搜索的目录列表。在这个示例中,配置了一系列目录,Pytest 在搜索测试文件时会忽略这些目录及其子目录。这样可以避免搜索和收集非测试相关的文件,提高测试文件的发现效率。

通过这些配置选项,你可以根据项目的组织结构和需求,定制 Pytest 如何发现和收集测试文件,使得测试运行更加高效和精确。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/diannao/5121.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

使用通义千问,识别需求文档中的输入输出信号存储到excel表格,完成对需求的初步分析

操作步骤如下: 第一步,提取需求的输入输出信号为json格式, 提示词如下: 车速自动闭锁 使能条件(a&b&c&d&e&f) a. 电源状态为 ON(PowerMode ON) b. 主驾门锁…

idm下载速度慢解决办法 idm批量下载怎么用 idm优化下载速度 Internet Download Manager解决下载速度慢的方法教程

IDM (Internet Download Manager)是一款兼容性大,支持多种语言的下载管理软件,它可以自动检测并下载网页上的内容,这正是这一优点,使得它受到了广大用户的喜爱。但是在下载的过程中,我们会遇到idm下载速度慢怎么回事&a…

ubuntu搭建node私库Verdaccio

ubuntu搭建node私库Verdaccio Verdaccio 是一个轻量级的私有 npm 代理注册服务器,它是开源的,可以帮助你设置和维护企业内部的 npm 包的存储库。使用 Verdaccio 可以让你完全控制包的发布流程、依赖关系以及访问策略。这篇文章将指导你如何在 Ubuntu 系…

【Elasticsearch】安装配置与使用

1 前期准备 1.1 环境准备 麒麟ARM 64位操作系统 1.2 安装包准备 Elasticsearch下载地址: https://www.elastic.co/cn/downloads/elasticsearch 2 部署elasticsearch 2.1 创建es专用用户 注意:ES不能使用root用户来启动,必须使用普通用户来安装启…

【百度Apollo】探索自动驾驶:小白教学如何使用 Dreamview 播放数据包

🎬 鸽芷咕:个人主页 🔥 个人专栏: 《linux深造日志》《粉丝福利》 ⛺️生活的理想,就是为了理想的生活! 文章目录 引入一、Dreamview 简介二、使用 Dreamview 具体步骤步骤一:进入 Apollo Docker 环境步骤二&#xff…

.net报错异常及常用功能处理总结(持续更新)

.net报错异常及常用功能处理总结---持续更新 1. WebApi dynamic传参解析结果中ValueKind Object处理方法问题描述方案1:(推荐,改动很小)方案2: 2.C# .net多层循环嵌套结构数据对象如何写对象动态属性赋值问题描述JavaScript动态属性赋值.net…

初步认识Vscode

4.26初步认识Vscode (一)快捷键的使用 1. 打开控制端 ctrl ~2. 结束终端 ctrl c3. 多行同时对齐输出 按住shift alt 光标多选4. 多行同时任意位置输出 按住alt 光标单点你想要输入的位置5. 代码太长了,想混行编辑 alt z6. 打开设置控制…

记录一次大数据量接口优化过程

问题描述 记录一次大数据量接口优化过程。最近在优化一个大数据量的接口,是提供给安卓端APP调用的,因为安卓端没做分批次获取,接口的数据量也比较大,因为加载速度超过一两分钟,所以导致接口超时的异常,要让…

【网络原理】TCP协议的相关机制(确认应答、超时重传)

系列文章目录 【网络通信基础】网络中的常见基本概念 【网络编程】Java网络编程中的基本概念及实现UDP、TCP客户端服务器程序(万字博文) 【网络原理】UDP协议的报文结构 及 校验和字段的错误检测机制(CRC算法、MD5算法) 文章目…

# 谷歌 Chrome 浏览器无法安装插件的解决方法

谷歌 Chrome 浏览器无法安装插件的解决方法 运用开发模式安装 安装步骤: 1、 将 XX.crx 插件的扩展名改成 .zip 或者 .rar 并解压到文件夹 XX 目录。 1)如:下载的 前端框架 vue.js 插件 nhdogjmejiglipccpnnnanhbledajbpd-6.6.1-Crx4Chro…

大数据 - Doris系列《四》- Doris常用函数

往期文章: 大数据 - Doris系列《一》- Doris简介_doris详细介绍-CSDN博客 大数据 - Doris系列《二》- Doris安装(亲测成功版)_java8 please set vm.max_map_count to be 2000000 un-CSDN博客 大数据 - Doris系列《三》- 数据表设计之表的基…

Pytest:hooks钩子函数

Pytest:hooks钩子函数 Bootstrapping hooks 引导钩子Initialization hooks 初始化钩子Collection hooks 测试用例收集钩子Test running (runtest) hooks 测试运行钩子Reporting hooks 测试报告钩子Debugging/Interaction hooks 调试/交互钩子 Pytest的钩子函数可分为…

面试重点2:网页访问不了,从服务器层面如何排查

从服务器层面排查网页访问问题可以按照以下步骤进行: 1. 检查网络连接 确保服务器的网络连接正常,可以通过 ping 命令测试网络是否通畅,例如 ping www.example.com。 2. 排查 DNS 问题 如果访问域名无法解析,可能是 DNS 配置问…

Python深度学习实践:使用TensorFlow构建图像分类器

摘要 随着深度学习技术的飞速发展,图像识别已成为AI领域的热点应用之一。本篇文章将引导读者使用Python和Google的TensorFlow框架,从零开始构建一个简单的图像分类器。我们将深入探讨卷积神经网络(CNN)的基本原理,实现一个能够识别MNIST手写数字的数据集模型,并通过实战代…

Java自定义工具类中使用RedisTemplate的遇到空指针问题

话不多说,上错误代码,以下是我在静态方法里使用RedisTemplate类,这里加了Autowired ****省略import包**** public class CommonUtils {Autowiredprivate static RedisTemplate redisTemplate;public static String test() {String info &qu…

邦注科技即热式节能模温机 模温机的工作原理

模温机是一种用于控制模具温度的设备,主要用于塑料注塑、压铸、橡胶成型等工艺中。 其工作原理主要包括以下几个步骤: 加热阶段: 当模具需要加热时,双温模温机会启动加热系统,将热传导油或热传导水加热至设定温度。加…

Spring Cloud学习笔记(Hystrix):execute,queue,observe,toObservable样例和特性

这是本人学习的总结,主要学习资料如下 - 马士兵教育 1、Overview2、execute()2.1、Overview2.2、示例 3、queue()3.1、Overview3.2、示例 4、observe()4.1、Overview4.2、示例 5、toObservable()5.1、observe()和toObservable()的区别 1、Overview 我们知道Hystrix…

HDFS架构

HDFS 是一个主从 Master/Slave 架构一个 HDFS 集群包含一个 NameNode,这是一个 Master Server,用来管理文件系统的命名空间,以及协调客户端对文件的访问一个 HDFS 集群包含多个 DataNode,用来存储数据HDFS 会对外暴露一个文件系统命名空间,并允许用户数据以文件的形式进行存储在…

iOS实现一个高性能的跑马灯

效果图 该跑马灯完全通过CATextLayer 实现,轻量级,并且通过 系统的位移动画实现滚动效果,避免了使用displaylink造成的性能瓶颈,使用系统动画,系统自动做了很多性能优化,实现更好的性能,并使用…

java设计模式 -- 工厂模式

1、基本概念 工厂模式(Factory Pattern)是 Java 中最常用的设计模式之一,这种类型的设计模式属于创建型模式,它提供了一种创建对象的最佳方式。 工厂模式提供了一种创建对象的方式,而无需指定要创建的具体类。 工厂…