运行为鼻子编写的测试

pytest 对运行为编写的测试具有基本支持 nose.

使用

安装 pytest 类型:

python setup.py develop  # make sure tests can import our package
pytest  # instead of 'nosetests'

您应该能够运行鼻子样式的测试并利用pytest的功能。

支持鼻习语

  • 在模块/类/方法级别设置和拆卸

  • Skiptest异常和标记

  • 设置/拆卸修饰符

  • __test__ 模块/类/函数的属性

  • 鼻公用设施的一般用途

不支持的习语/已知问题

  • 统一测试风格 setUp, tearDown, setUpClass, tearDownClass 仅在上识别 unittest.TestCase 类,但不在普通类上。 nose 在普通类上也支持这些方法,但pytest故意不支持。因为鼻子和皮试都支持 setup_class, teardown_class, setup_method, teardown_method 像nose一样复制UnitTest API似乎没有什么用处。但是,如果您认为pytest应该支持普通类上的unittest拼写,请发布 to this issue .

  • 鼻导入具有相同导入路径的测试模块(例如 tests.test_mode )但是不同的文件系统路径(例如 tests/test_mode.pyother/tests/test_mode.py )通过扩展sys.path/import语义。Pytest不这样做,但在 #268 为了增加一些支持。注意 nose2 choose to avoid this sys.path/import hackery .

    如果将conftest.py文件放在项目的根目录中(由pytest确定),则pytest将针对该目录下的代码运行测试“nose-style”,方法是将其添加到 sys.path 而不是根据安装的代码运行。

    如果你运行的话,你可能会发现自己想这么做。 python setup.py install 设置项目,而不是 python setup.py develop 或包管理器的任何等效项。建议在类似tox的虚拟环境中安装with develop,而不是在此模式中安装。

  • 鼻子样式的doctest没有正确收集和执行,而且doctest fixtures也不工作。

  • 无法识别机头配置。

  • yield -从pytest 4.1.0开始,不支持基于的方法。它们基本上与pytest不兼容,因为它们不支持fixture,因为收集和测试执行是分开的。

从鼻子迁移到最火辣

nose2pytest 是一个Python脚本和pytest插件,用于帮助将基于鼻子的测试转换为基于pytest的测试。具体地说,该脚本将nose.tools.assert_*函数调用转换为原始断言语句,同时尽可能保留原始参数的格式。