轻松声明可选测试(即默认情况下不运行的测试)
pytest-optional-tests的Python项目详细描述
提供使用pytest标记的可选测试的简单声明。 可选测试仅在通过配置文件或命令请求时运行 行。
动机
某些测试类不应在每次调用测试时运行。 定义只在特定情况下运行的测试通常很有用 请求的,例如速度慢、需要网络访问的测试,或 只在特定环境下工作。
Pytest提供了基于测试名称(-k)和 基于标记(-m)筛选测试两种机制都不能 默认情况下很容易支持某些测试。例如,人们可以 用@pytest.mark.network来修饰测试,但通过 默认情况下,需要一个标记表达式,如-m“not network” 每次召唤。当 有很多标记。
这个插件允许用户声明某些标记是 “可选标记”当测试用可选标记修饰时, 默认情况下跳过测试。测试可以用多个 标记,包括多个可选标记。可选测试可以是 在pytest ini文件或命令行中启用。
用法
可选标记必须使用与 标记选项例如:
[pytest] optional_tests: slow: slow tests network: network tests bug: regression tests against previous bugs
不应使用标记属性声明可选标记, 即使使用pytest的strict模式。
可选的测试修饰符是pytest标记,语义是 完全相同。
如果一个测试用多个可选标记修饰,则该测试将 在请求任何标记时执行。例如:
@pytest.mark.network @pytest.mark.slow def test_slow_network_function(): ...
如果可选的慢速或网络 要求进行测试。
可在INICFG中请求可选测试:
[pytest] optional_tests: slow: slow tests network: network tests bug: regression tests against previous bugs run_optional_tests=network,slow
或在命令行中:
pytest --run-option-tests=network,slow
贡献
我们非常欢迎您的贡献。测试可以用tox运行,请确保 在提交请求之前,覆盖范围至少保持不变
许可证
根据MIT许可证的条款分发
问题
如果您遇到任何问题,请file an issue连同详细说明。
这个pytest插件是用Cookiecutter和@hackebrot的cookiecutter-pytest-plugin模板生成的。