【Pytest官方文档翻译及学习】2.1 如何调用pytest

目录

2.1 如何调用pytest

2.1.1 指定要运行的测试

2.1.2 获取有关版本、选项名称、环境变量的帮助

2.1.3 分析测试执行时间

2.1.4 管理加载插件

2.1.5 调用pytest的其他方式


2.1 如何调用pytest

2.1.1 指定要运行的测试

Pytest支持几种从命令行运行和选择测试的方法。、

在模块中运行测试

pytest test_mod.py

在目录中运行测试

pytest testing/

按关键字表达式运行测试

pytest -k 'MyClass and not method'

这将运行包含与给定名称匹配的名称的测试字符串表达式 (不区分大小写),它可以包括使用文件名、类名和函数名作为变量的Python运算符。上面的例子将运行 TestMyClass.test_something 但不是 TestMyClass.test_method_simple。在Windows系统上运行时使用双引号("")而不是单引号('')来表示表达式。

按节点ID运行测试

每个收集到的测试都被分配一个唯一的节点ID(nodeid),该节点ID由模块文件名和后缀组成,后缀包括类名、函数名和由参数化生成的参数,这些部分以双冒号(::)分隔。

要在模块中运行特定测试,请执行以下操作:

pytest test_mod.py::test_func

在命令行中指定测试方法的另一个示例:

pytest test_mod.py::TestClass::test_method

通过标记表达式运行测试

pytest -m slow

将运行所有用@pytest.mark.slow装饰器装饰的测试。

有关详细信息,请参见 marks

从包运行测试

pytest --pyargs pkg.testing

这将导入 pkg.testing 并使用其文件系统位置来查找和运行测试。

2.1.2 获取有关版本、选项名称、环境变量的帮助

pytest --version # shows where pytest was imported from(显示pytest的导入位置)
pytest --fixtures # show available builtin function arguments (显示可用的内置函数参数)
pytest -h | --help # show help on command line and config file options(显示有关命令行和配置文件选项的帮助)

2.1.3 分析测试执行时间

在6.0版中进行了更改。

要获得超过1.0秒的最慢10个测试持续时间的列表:

pytest --durations=10 --durations-min=1.0

默认情况下,pytest不会显示太小(<0.005s)的测试持续时间,除非在命令行上传递-vv。

2.1.4 管理加载插件

早期加载插件(Early loading plugins)

您可以使用-p选项在命令行中显示早期加载插件(内部和外部):

pytest -p mypluginmodule

该选项接收一个name参数,该参数可以是:

  • 完整的模块虚线名称,例如myproject.plugins。此虚线名称必须是可导入的。
  • 插件的入口点名称。这是注册插件时传递给setuptools的名称。例如,要提前加载pytest-cov插件,您可以使用:
pytest -p pytest_cov

禁用插件(Disabling plugins)

要禁用在调用时加载特定插件,请将-p选项与前缀no:一起使用。

示例:要禁用加载插件doctest,该插件负责从文本文件执行doctest测试,请如下调用pytest:

pytest -p no:doctest

2.1.5 调用pytest的其他方式

通过python -m pytest调用pytest

您可以从命令行通过Python解释器调用测试:

python -m pytest [...]

这几乎相当于直接调用命令行脚本pytest[…],只是通过python调用也会将当前目录添加到sys.path中。

从Python代码调用pytest

您可以直接从Python代码中调用pytest:

retcode = pytest.main() 

这就好像您要从命令行调用“pytest”一样。它不会引发SystemExit,而是返回退出代码。您可以传入选项和参数:

retcode = pytest.main(["-x", "mytestdir"])

您可以为pytest.main指定其他插件:

# content of myinvoke.py
import sys
import pytest
class MyPlugin:
    def pytest_sessionfinish(self):
        print("*** test run reporting finishing")
if __name__ == "__main__":
    sys.exit(pytest.main(["-qq"], plugins=[MyPlugin()]))

运行它将显示添加了MyPlugin并调用:

$ python myinvoke.py 
*** test run reporting finishing

注:

调用pytest.main()将导入测试及其导入的任何模块。由于python导入系统的缓存机制,从同一进程对pytest.main()进行后续调用不会反映调用之间对这些文件的更改。因此,不建议从同一进程多次调用pytest.main()(例如,为了重新运行测试)。

  • 26
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
pytest是一个功能强大的Python测试框架,它提供了丰富的功能和灵活的配置选项,使得编写和运行测试变得更加简单和高效。下面是pytest中文文档的介绍: 1. pytest简介:介绍pytest的基本概念和特点,以及为什么选择使用pytest进行测试。 2. 安装和配置:详细说明如何安装pytest,并提供了一些常见的配置选项,如自定义测试目录、设置断言等。 3. 编写测试用例:介绍如何编写pytest的测试用例,包括使用装饰器标记测试函数、使用断言进行结果验证等。 4. 运行测试:说明如何运行pytest测试,包括命令行选项、运行指定目录或文件、使用pytest.ini文件进行配置等。 5. 断言和失败信息:介绍pytest中的断言机制,包括常用的断言方法和自定义断言,以及如何处理测试失败时的信息输出。 6. 用例组织和执行顺序:讲解如何组织测试用例,包括使用测试类、测试模块、测试目录等方式,并说明pytest的执行顺序。 7. 用例参数化:介绍如何使用pytest的参数化功能,通过一组参数运行多次相同的测试用例。 8. 用例标记和过滤:说明如何使用pytest的标记功能,对测试用例进行分类和过滤,以及如何使用标记来运行指定的测试用例。 9. 夹具(Fixture):详细介绍pytest的夹具概念和使用方法,包括夹具的作用域、自动使用夹具、夹具之间的依赖关系等。 10. 插件扩展:介绍如何使用pytest的插件机制,扩展pytest的功能,如自定义报告、自定义命令行选项等。 以上是pytest中文文档的主要内容,你可以通过阅读文档来深入了解pytest的使用方法和技巧。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值