当我运行所有 pytests 时,我确实希望充分受益于将负载分散到所有 m 个核心 (xdist) 上,但是当我运行其中的一个子集时,几乎总是出于开发/调试目的,在这种情况下,我确实想避免xdist 为:
- 较慢的开始时间
- 无法使用 pdb 调试
例如:调用pytest -k foo
应该有效地运行pytest -n0 -k foo
。请记住,不带参数调用 pytest 不应影响 -n 值。
当我运行所有 pytests 时,我确实希望充分受益于将负载分散到所有 m 个核心 (xdist) 上,但是当我运行其中的一个子集时,几乎总是出于开发/调试目的,在这种情况下,我确实想避免xdist 为:
例如:调用pytest -k foo
应该有效地运行pytest -n0 -k foo
。请记住,不带参数调用 pytest 不应影响 -n 值。
您可以动态添加 option,例如:
conftest.py
import sys
def pytest_cmdline_preparse(args):
if "xdist" in sys.modules and "-k" in args:
for i, arg in enumerate(args):
# remove -n # option
if arg == "-n":
del args[i]
del args[i]
break
# remove -n# option
if re.match(r"-n\d+", arg):
del args[i]
break
args[:] = ["-n0"] + args
这将删除现有的“-n”选项(表单-n #
和-n#
- 您可能不需要两者,具体取决于命令行的外观),并添加“-n0”选项。
更新:
pytest_cmdline_preparse
在当前 (6.x) pytest 版本中已弃用,pytest_load_initial_conftests
可以以相同的方式使用。