百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 编程字典 > 正文

python安装(python安装pip)

toyiye 2024-08-31 02:52 4 浏览 0 评论

目录:

  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参考
  23. 方法(Functions)
  24. 标记(Marks)
  25. 钩子(Hooks)
  26. 装置(Fixtures)
  27. 对象(Objects)
  28. 特殊变量(Special Variables)
  29. 环境变量(Environment Variables)
  30. 配置选项(Configuration Options)
  31. 优质集成实践
  32. 片状测试
  33. Pytest导入机制及sys.path/PYTHONPATH
  34. 配置选项
  35. 示例及自定义技巧
  36. Bash自动补全设置

API参考-Configuration Options

  • 配置选项(Configuration Options)

配置选项

这里是一个可以在被写入内置的配置选项的列表pytest.ini,tox.ini或setup.cfg 通常位于版本库的根文件。所有选项必须在一个[pytest]部分下([tool:pytest]对于setup.cfg文件)。

警告

的使用setup.cfg是不推荐,除非非常简单的用例。.cfg 文件使用不同的解析器pytest.ini,tox.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_cache在rootdir中创建的。目录可以是相对路径或绝对路径。如果设置相对路径,则相对于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只在 从根目录执行时查找testing和doc目录中的测试。

usefixtures

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

[pytest]

usefixtures =

clean_db

xfail_strict

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

[pytest]

xfail_strict = True```

相关推荐

# Python 3 # Python 3字典Dictionary(1)

Python3字典字典是另一种可变容器模型,且可存储任意类型对象。字典的每个键值(key=>value)对用冒号(:)分割,每个对之间用逗号(,)分割,整个字典包括在花括号({})中,格式如...

Python第八课:数据类型中的字典及其函数与方法

Python3字典字典是另一种可变容器模型,且可存储任意类型对象。字典的每个键值...

Python中字典详解(python 中字典)

字典是Python中使用键进行索引的重要数据结构。它们是无序的项序列(键值对),这意味着顺序不被保留。键是不可变的。与列表一样,字典的值可以保存异构数据,即整数、浮点、字符串、NaN、布尔值、列表、数...

Python3.9又更新了:dict内置新功能,正式版十月见面

机器之心报道参与:一鸣、JaminPython3.8的热乎劲还没过去,Python就又双叒叕要更新了。近日,3.9版本的第四个alpha版已经开源。从文档中,我们可以看到官方透露的对dic...

Python3 基本数据类型详解(python三种基本数据类型)

文章来源:加米谷大数据Python中的变量不需要声明。每个变量在使用前都必须赋值,变量赋值以后该变量才会被创建。在Python中,变量就是变量,它没有类型,我们所说的"类型"是变...

一文掌握Python的字典(python字典用法大全)

字典是Python中最强大、最灵活的内置数据结构之一。它们允许存储键值对,从而实现高效的数据检索、操作和组织。本文深入探讨了字典,涵盖了它们的创建、操作和高级用法,以帮助中级Python开发...

超级完整|Python字典详解(python字典的方法或操作)

一、字典概述01字典的格式Python字典是一种可变容器模型,且可存储任意类型对象,如字符串、数字、元组等其他容器模型。字典的每个键值key=>value对用冒号:分割,每个对之间用逗号,...

Python3.9版本新特性:字典合并操作的详细解读

处于测试阶段的Python3.9版本中有一个新特性:我们在使用Python字典时,将能够编写出更可读、更紧凑的代码啦!Python版本你现在使用哪种版本的Python?3.7分?3.5分?还是2.7...

python 自学,字典3(一些例子)(python字典有哪些基本操作)

例子11;如何批量复制字典里的内容2;如何批量修改字典的内容3;如何批量修改字典里某些指定的内容...

Python3.9中的字典合并和更新,几乎影响了所有Python程序员

全文共2837字,预计学习时长9分钟Python3.9正在积极开发,并计划于今年10月发布。2月26日,开发团队发布了alpha4版本。该版本引入了新的合并(|)和更新(|=)运算符,这个新特性几乎...

Python3大字典:《Python3自学速查手册.pdf》限时下载中

最近有人会想了,2022了,想学Python晚不晚,学习python有前途吗?IT行业行业薪资高,发展前景好,是很多求职群里严重的香饽饽,而要进入这个高薪行业,也不是那么轻而易举的,拿信工专业的大学生...

python学习——字典(python字典基本操作)

字典Python的字典数据类型是基于hash散列算法实现的,采用键值对(key:value)的形式,根据key的值计算value的地址,具有非常快的查取和插入速度。但它是无序的,包含的元素个数不限,值...

324页清华教授撰写【Python 3 菜鸟查询手册】火了,小白入门字典

如何入门学习python...

Python3.9中的字典合并和更新,了解一下

全文共2837字,预计学习时长9分钟Python3.9正在积极开发,并计划于今年10月发布。2月26日,开发团队发布了alpha4版本。该版本引入了新的合并(|)和更新(|=)运算符,这个新特性几乎...

python3基础之字典(python中字典的基本操作)

字典和列表一样,也是python内置的一种数据结构。字典的结构如下图:列表用中括号[]把元素包起来,而字典是用大括号{}把元素包起来,只不过字典的每一个元素都包含键和值两部分。键和值是一一对应的...

取消回复欢迎 发表评论:

请填写验证码