Pytest官方教程-22-API参考-Configuration Options

目录:

  1. 安装及入门
  2. 使用和调用方法
  3. 原有TestSuite使用方法
  4. 断言的编写和报告
  5. Pytest fixtures:清晰 模块化 易扩展
  6. 使用Marks标记测试用例
  7. Monkeypatching/对模块和环境进行Mock
  8. 使用tmp目录和文件
  9. 捕获stdout及stderr输出
  10. 捕获警告信息
  11. 模块及测试文件中集成doctest测试
  12. skip及xfail: 处理不能成功的测试用例
  13. Fixture方法及测试用例的参数化
  14. 缓存: 使用跨执行状态
  15. unittest.TestCase支持
  16. 运行Nose用例
  17. 经典xUnit风格的setup/teardown
  18. 安装和使用插件
  19. 插件编写
  20. 编写钩子(hook)方法
  21. 运行日志
  22. API参考
    1. 方法(Functions)
    2. 标记(Marks)
    3. 钩子(Hooks)
    4. 装置(Fixtures)
    5. 对象(Objects)
    6. 特殊变量(Special Variables)
    7. 环境变量(Environment Variables)
    8. 配置选项(Configuration Options)
  23. 优质集成实践
  24. 片状测试
  25. Pytest导入机制及sys.path/PYTHONPATH
  26. 配置选项
  27. 示例及自定义技巧
  28. Bash自动补全设置

API参考-Configuration Options

配置选项

这里是一个可以在被写入内置的配置选项的列表pytest.initox.inisetup.cfg 通常位于版本库的根文件。所有选项必须在一个[pytest]部分下([tool:pytest]对于setup.cfg文件)。
警告
的使用setup.cfg是不推荐,除非非常简单的用例。.cfg 文件使用不同的解析器pytest.initox.ini这可能导致难以追踪问题。如果可能,建议使用后面的文件来保存pytest配置。
配置文件选项可以通过使用在命令行中覆盖,-o/--override也可以多次传递。预期的格式是name=value。例如:

pytest -o console_output_style=classic -o cache_dir=/tmp/mycache

addopts
将指定OPTS的命令行参数添加到命令行参数集中,就像它们已由用户指定一样。示例:如果你有此ini文件内容:

# content of pytest.ini
[pytest]
addopts = --maxfail=2 -rf  # exit after 2 failures, report fail info

发行实际意味着:pytest test_hello.py

pytest --maxfail=2 -rf test_hello.py

默认是不添加选项。

cache_dir
设置存储缓存插件内容的目录。默认目录是 .pytest_cacherootdir中创建的。目录可以是相对路径或绝对路径。如果设置相对路径,则相对于rootdir创建目录。另外,path可能包含将被扩展的环境变量。有关缓存插件的更多信息,请参阅缓存:使用跨testrun状态

confcutdir
设置向上搜索conftest.py文件的目录。默认情况下,pytest将停止conftest.py从项目的pytest.ini/ tox.ini/ 向上搜索文件(setup.cfg如果有),或者直到文件系统根目录。

console_output_style
运行测试时设置控制台输出样式:

  • classic:经典的pytest输出。
  • progress:喜欢经典的pytest输出,但带有进度指示器。
  • count:像进度一样,但随着测试完成次数而不是百分比显示进度。
    默认值为progress,但classic如果你愿意,或者新模式导致意外问题,你可以回退到:
# content of pytest.ini
[pytest]
console_output_style = classic

doctest_encoding
用于解码带有文档字符串的文本文件的默认编码。 看看pytest如何处理doctests

doctest_optionflags
标准doctest模块中的一个或多个doctest标志名称。 看看pytest如何处理doctests

empty_parameter_set_mark
允许在参数化中为空参数选择操作

  • skip 使用空参数跳过测试(默认)
  • xfail 使用空参数标记测试为xfail(run = False)
  • fail_at_collect 如果parametrize收集空参数集,则引发异常
# content of pytest.ini
[pytest]
empty_parameter_set_mark = xfail

注意
计划xfail在将来的版本中更改此选项的默认值,因为这被认为不易出错, 有关详细信息,请参阅#3155

filterwarnings
设置应为匹配的警告采取的过滤器和操作的列表。默认情况下,测试会话期间发出的所有警告都将在测试会话结束时显示在摘要中。

# content of pytest.ini
[pytest]
filterwarnings =
 error
 ignore::DeprecationWarning

这告诉pytest忽略弃用警告并将所有其他警告变为错误。有关更多信息,请参阅警告捕获

junit_family
版本4.2中的新功能。
配置生成的JUnit XML文件的格式。可能的选择是:

  • xunit1(或legacy):生成旧样式输出,与xunit 1.0格式兼容。这是默认值
  • xunit2:生成xunit 2.0样式输出
    哪个应该与最新的Jenkins版本更兼容。
[pytest]
junit_family = xunit2

junit_suite_name
要设置根测试套件xml项的名称,可以junit_suite_name在配置文件中配置该选项:

[pytest]
junit_suite_name = my_suite

log_cli_date_format
设置一个time.strftime()兼容的字符串,该字符串将在格式化实时日志记录的日期时使用。

[pytest]
log_cli_date_format = %Y-%m-%d %H:%M:%S

有关更多信息,请参阅实时日志

log_cli_format
设置logging用于格式化实时日志记录消息的兼容字符串。

[pytest]
log_cli_format = %(asctime)s %(levelname)s %(message)s

有关更多信息,请参阅实时日志

log_cli_level
设置应为实时日志记录捕获的最小日志消息级别。可以使用整数值或级别的名称。

[pytest]
log_cli_level = INFO

有关更多信息,请参阅实时日志

log_date_format
设置time.strftime()与日志记录捕获格式化日期时将使用的兼容字符串。

[pytest]
log_date_format = %Y-%m-%d %H:%M:%S

有关更多信息,请参阅日志记录

log_file
pytest.ini除了活动的其他日志记录工具之外,还应设置相对于应写入日志消息的文件的文件名。

[pytest]
log_file = logs/pytest-logs.txt

有关更多信息,请参阅日志记录

log_file_date_format
设置time.strftime()在格式化日志文件的日期时将使用的兼容字符串。

[pytest]
log_file_date_format = %Y-%m-%d %H:%M:%S

有关更多信息,请参阅日志记录

log_file_format
设置一个logging兼容的字符串,用于格式化重定向到日志文件的日志消息。

[pytest]
log_file_format = %(asctime)s %(levelname)s %(message)s

有关更多信息,请参阅日志记录

log_file_level
设置应为日志记录文件捕获的最小日志消息级别。可以使用整数值或级别的名称。

[pytest]
log_file_level = INFO

有关更多信息,请参阅日志记录

log_format
设置logging用于格式化捕获的日志消息的兼容字符串。

[pytest]
log_format = %(asctime)s %(levelname)s %(message)s

有关更多信息,请参阅日志记录

log_level
设置应记录捕获的最小日志消息级别。可以使用整数值或级别的名称。

[pytest]
log_level = INFO

有关更多信息,请参阅日志记录

log_print
如果设置为False,将禁用显示失败测试的捕获日志消息。

[pytest]
log_print = False

有关更多信息,请参阅日志记录

markers
使用--strict命令行参数时,只允许使用已知的标记(由代码核心pytest或某些插件定义)。你可以在此设置中列出其他标记,以将其添加到白名单。
你可以列出每行一个标记名称,从选项名称缩进。

[pytest]
markers =
 slow
 serial

minversion
指定运行测试所需的最小pytest版本。

# content of pytest.ini
[pytest]
minversion = 3.0  # will fail if we run with pytest-2.8

norecursedirs
设置目录basename模式以避免在递归测试发现时使用。各个(fnmatch样式)模式应用于目录的基本名称,以决定是否递归到目录。模式匹配字符:

*       matches everything
?       matches any single character
[seq]   matches any character in seq
[!seq]  matches any char not in seq

默认模式是。设置替换默认值。以下是如何避免某些目录的示例:'.*', 'build', 'dist','CVS', '_darcs', '{arch}', '*.egg', 'venv'``norecursedirs

[pytest]
norecursedirs = .svn _build tmp*

这将告诉pytest我们不要查看典型的subversion或sphinx-build目录或任何tmp前缀目录。
此外,pytest将尝试通过激活脚本的存在智能地识别和忽略virtualenv。除非‑‑collect‑in‑virtualenv给出,否则在测试收集期间不会考虑任何被视为虚拟环境根目录的目录。另请注意, norecursedirs优先于‑‑collect‑in‑virtualenv; 例如,如果你打算在virtualenv中使用匹配的基本目录运行测试 ,则除了使用该标志外, '.*'必须覆盖。norecursedirs``‑‑collect‑in‑virtualenv

python_classes
一个或多个名称前缀或glob样式模式,用于确定考虑用于测试集合的类。通过在模式之间添加空格来搜索多个glob模式。默认情况下,pytest会将任何以前缀Test为前缀的类视为测试集合。以下是如何从以下结尾的类中收集测试的示例Suite

[pytest]
python_classes = *Suite

请注意,unittest.TestCase无论此选项如何,始终都会收集派生类,因为unittest自己的集合框架用于收集这些测试。

python_files
一个或多个Glob样式的文件模式,用于确定哪些python文件被视为测试模块。通过在模式之间添加空格来搜索多个glob模式:

[pytest]
python_files = test_*.py check_*.py example_*.py

或者每行一个:

[pytest]
python_files =
 test_*.py
 check_*.py
 example_*.py

默认情况下,匹配的文件test_*.py*_test.py将被视为测试模块。

python_functions
一个或多个名称前缀或glob-patterns,用于确定哪些测试函数和方法被视为测试。通过在模式之间添加空格来搜索多个glob模式。默认情况下,pytest会将任何前缀test为函数的函数视为测试。以下是如何收集以下结尾的测试函数和方法的示例_test

[pytest]
python_functions = *_test

请注意,这对生成在派生类上的方法没有影响,因为自己的集合框架用于收集这些测试。unittest .TestCase``unittest
有关更多详细示例,请参阅更改命名约定

testpaths
当从rootdir目录执行pytest时,如果在命令行中没有给出特定的目录,文件或测试ID,则设置应搜索测试的目录列表。当所有项目测试都在一个已知位置以加速测试收集并避免意外接收不需要的测试时非常有用。

[pytest]
testpaths = testing doc

这告诉pytest只在 从根目录执行时查找testingdoc目录中的测试。

usefixtures
将应用于所有测试功能的灯具列表; 这在语义上与将@pytest.mark.usefixtures标记应用于所有测试函数相同。

[pytest]
usefixtures =
 clean_db

xfail_strict
如果设置为True,则标记为@pytest.mark.xfail实际成功的测试将默认为测试套件失败。有关更多信息,请参阅strict参数

[pytest]
xfail_strict = True```

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 199,519评论 5 468
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 83,842评论 2 376
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 146,544评论 0 330
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 53,742评论 1 271
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 62,646评论 5 359
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,027评论 1 275
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,513评论 3 390
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,169评论 0 254
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,324评论 1 294
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,268评论 2 317
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,299评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 32,996评论 3 315
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,591评论 3 303
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,667评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 30,911评论 1 255
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,288评论 2 345
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 41,871评论 2 341

推荐阅读更多精彩内容