返回: Pytest权威教程

模块及测试文件中集成doctest测试

编码

使用doctest选项

默认情况下,Pytest按照python doctest模块标准test*.txt模式进行匹配。你也可以通过使用以下命令更改匹配模式:

  1. pytest --doctest-glob='*.rst'

在命令行上。从版本开始2.9,--doctest-glob可以在命令行中多次使用。

3.1版中的新增函数:你可以使用doctest_encodingini选项指定将用于这些doctest文件的编码:

  1. # content of pytest.ini
  2. [pytest]
  3. doctest_encoding = latin1

默认编码为UTF-8。

你还可以在所有python模块(包括常规python测试模块)中从docstrings触发doctests的运行:

  1. pytest --doctest-modules

你可以将这些更改永久保存在项目中,方法是将它们放入pytest.ini文件中,如下所示:

  1. # content of pytest.ini
  2. [pytest]
  3. addopts = --doctest-modules

如果你有一个这样的文本文件:

  1. # content of example.rst
  2. hello this is a doctest
  3. >>> x = 3
  4. >>> x
  5. 3

和另一个这样的:

  1. # content of mymodule.py
  2. def something():
  3. """ a doctest in a docstring
  4. >>> something()
  5. 42
  6. """
  7. return 42

那么你可以在pytest没有命令行选项的情况下调用:

  1. $ pytest
  2. =========================== test session starts ============================
  3. platform linux -- Python 3.x.y,pytest-4.x.y,py-1.x.y,pluggy-0.x.y
  4. cachedir: $PYTHON_PREFIX/.pytest_cache
  5. rootdir: $REGENDOC_TMPDIR,inifile: pytest.ini
  6. collected 1 item
  7. mymodule.py . [100%]
  8. ========================= 1 passed in 0.12 seconds =========================

可以使用getfixture帮助器使用Fixture方法:

  1. # content of example.rst
  2. >>> tmp = getfixture('tmpdir')
  3. >>> ...
  4. >>>

此外,在执行文本doctest文件时,支持[使用类,模块或项目中的Fixture。

标准doctest模块提供了一些设置标志来配置doctest测试的严格性。在pytest中,你可以使用配置文件启用这些标志。要使pytest忽略尾随空格并忽略冗长的异常堆栈跟踪,你只需编写:

  1. [pytest]
  2. doctest_optionflags= NORMALIZE_WHITESPACE IGNORE_EXCEPTION_DETAIL

pytest还引入了新的选项,允许doctests在Python 2和Python 3中运行不变:

  • ALLOW_UNICODE:启用时,u前缀将从预期doctest输出中的unicode字符串中删除。
  • ALLOW_BYTES:启用时,b前缀将从预期doctest输出中的字节字符串中删除。

与任何其他选项标志一样,可以pytest.ini使用doctest_optionflagsini选项启用这些标志:

  1. [pytest]
  2. doctest_optionflags = ALLOW_UNICODE ALLOW_BYTES

或者,可以通过doc测试本身中的内联注释启用它:

  1. # content of example.rst
  2. >>> get_unicode_greeting() # doctest: +ALLOW_UNICODE
  3. 'Hello'

默认情况下,pytest仅报告给定doctest的第一次失败。如果你想在即使遇到故障时继续测试,请执行以下操作:

  1. pytest --doctest-modules --doctest-continue-on-failure

3.0版中的新函数。

doctest_namespace Fixture方法可用于注入到项目中,你的文档测试运行的命名空间。它旨在用于你自己的Fixture方法中,以提供将它们与上下文一起使用的测试。

doctest_namespace是一个标准dict对象,你可以将要放置在doctest命名空间中的对象放入其中:

  1. # content of conftest.py
  2. import numpy
  3. @pytest.fixture(autouse=True)
  4. def add_np(doctest_namespace):
  5. doctest_namespace['np'] = numpy

然后可以直接在你的doctests中使用它:

  1. # content of numpy.py
  2. def arange():
  3. """
  4. >>> a = np.arange(10)
  5. >>> len(a)
  6. 10
  7. """
  8. pass

请注意,与正常情况一样conftest.py,在conftest所在的目录树中发现了fixture。意味着如果将doctest与源代码放在一起,则相关的conftest.py需要位于同一目录下。在同级目录树中不会发现Fixtures!

输出格式

3.0版中的新函数。

你可以通过使用选项标准文档测试模块格式的一个更改失败你的文档测试diff的输出格式(见doctest.REPORT_UDIFF):

  1. pytest --doctest-modules --doctest-report none
  2. pytest --doctest-modules --doctest-report udiff
  3. pytest --doctest-modules --doctest-report cdiff
  4. pytest --doctest-modules --doctest-report ndiff
  5. pytest --doctest-modules --doctest-report only_first_failure

pytest-specific 特性

Pytest权威教程11-模块及测试文件中集成doctest测试的更多相关文章

  1. Pytest权威教程(官方教程翻译)

    Pytest权威教程01-安装及入门 Pytest权威教程02-Pytest 使用及调用方法 Pytest权威教程03-原有TestSuite的执行方法 Pytest权威教程04-断言的编写和报告 P ...

  2. Pytest权威教程08-使用tmp目录和文件

    目录 使用tmp目录和文件 tmp_path Fixture方法 tmp_path_factory Fixture方法 tmpdir Fixture方法 tmpdir_factory Fixture方 ...

  3. Pytest权威教程07-Monkeypatching,对模块和环境进行Mock

    目录 Monkeypatching,对模块和环境进行Mock 简单示例如: 猴子补丁方法 Monkeypatching 返回对象: 构建mock类 全局补丁示例如:阻止"requests&q ...

  4. Pytest权威教程23-不稳定测试

    目录 不稳定测试用例处理 为什么不稳定测试是个问题 潜在的根本原因 Pytest特性 其他一般策略 相关研究 相关资源 返回: Pytest权威教程 不稳定测试用例处理 "不稳定" ...

  5. Pytest权威教程04-断言的编写和报告

    目录 断言的编写和报告 使用assert语句进行断言 异常断言 警示断言 使用上下文对比 自定义断言对比信息 高级断言内省 返回: Pytest权威教程 断言的编写和报告 使用assert语句进行断言 ...

  6. Pytest权威教程05-Pytest fixtures:清晰 模块化 易扩展

    目录 Pytest fixtures:清晰 模块化 易扩展 Fixtures作为函数参数使用 Fixtures: 依赖注入的主要例子 conftest.py: 共享fixture函数 共享测试数据 生 ...

  7. Pytest权威教程12-跳过(Skip)及预期失败(xFail): 处理不能成功的测试用例

    目录 跳过(Skip)及预期失败(xFail): 处理不能成功的测试用例 Skip跳过用例 xFail:将测试函数标记为预期失败 Skip/xFail参数设置 返回: Pytest权威教程 跳过(Sk ...

  8. Pytest权威教程25-配置

    目录 配置 命令行选项和配置文件设置 初始化:确定ROOTDIR和INIFILE 寻找rootdir 如何更改命令行选项默认值 内置的配置文件选项 返回: Pytest权威教程 配置 命令行选项和配置 ...

  9. Pytest权威教程24-Pytest导入机制及系统路径

    目录 Pytest导入机制和sys.path/PYTHONPATH 包中的测试脚本及conftest.py文件 独立测试模块及conftest.py文件 调用通过python -m pytest调用p ...

随机推荐

  1. (八) Docker 部署 mongodb

    参考并感谢 官方文档 https://hub.docker.com/_/mongo 下载mongo镜像(不带tag标签则表示下载latest版本) docker pull mongo 启动 mongo ...

  2. Ubuntu 下安装 OpenSSH Server

    Ubuntu 下安装 OpenSSH Server 是无比轻松的一件事情,需要的命令只有一条: sudo apt-get install openssh-server (查看返回的结果,如果没有出错, ...

  3. 织梦dedecms是什么?

    织梦dedecms是什么?DedeCms是织梦内容管理系统(DedeCms)的简称, 以简单.实用.开源而闻名,是国内最知名的PHP开源网站管理系统,也是使用用户最多的PHP类CMS系统; DedeC ...

  4. Awesome Mac OS Command Line 中文翻译

    awesome-macos-command-line 收集了很多有趣的 Mac 终端命令. 看了一遍后,发现帮助很大. 见识许多没有使用过的命令,加深了对 Mac 的认识. 所以翻译成了中文,共享给其 ...

  5. 智表(ZCELL)插件产品选型说明书,市场主流插件对比,帮您选型

    智表(ZCELL)插件产品选型说明书,市场主流插件对比,帮您选型. 说明书下载:地址 一.    我们为什么需要智表插件产品 客户早已养成EXCEL中的操作习惯,BS架构下,普通的网页交互,与客户习惯 ...

  6. 使用tmux管理终端的窗口

    教程参考这里: http://louiszhai.github.io/2017/09/30/tmux/

  7. EhLib使用全攻略

    使用 TDBSumList 组件   还记得以前有朋友问过这样一个问题:在 DBGrid 下如何像 Excel 一样能够做统计计算,实话说,使用 DBGrid 来做的话着实不易,不过现在有了这个咚咚, ...

  8. UTF-8 中文编码范围

    主流的匹配字符有两种 [\u4e00-\u9fa5]和[\u2E80-\u9FFF],后者范围更广,包括了日韩地区的汉字 import re pattern = re.compile("[\ ...

  9. 交互式计算引擎MOLAP篇

    交互式计算引擎MOLAP篇 摘自:<大数据技术体系详解:原理.架构与实践> MOLAP是一种通过预计算cube方式加速查询的OLAP引擎,它的核心思想是“空间换时间”,典型代表包括Drui ...

  10. 批处理引擎MapReduce应用案例

    批处理引擎MapReduce应用案例 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. MapReduce能够解决的问题有一个共同特点:任务可以被分解为多个子问题,且这些子问题相对独立 ...