18

我正在使用 pytest 和 pytest-xdist 进行并行测试运行。在运行测试时,它似乎不-s支持将标准输出传递到终端的选项。有没有办法做到这一点?我意识到这可能会导致来自不同进程的输出在终端中混乱,但我可以接受。

4

2 回答 2

11

我找到了一种解决方法,虽然不是一个完整的解决方案。通过将 stdout 重定向到 stderr,可以显示打印语句的输出。这可以通过一行 Python 代码来完成:

sys.stdout = sys.stderr

如果放在 conftest.py 中,它适用于所有测试。

于 2016-05-13T13:10:43.067 回答
0

我使用了以下代码:

# conftest.py
import _pytest.capture

def get_capman(plugin_manager):
    capman_list = filter(lambda p: isinstance(p, _pytest.capture.CaptureManager), plugin_manager._plugins)
    return capman_list[0] if len(capman_list) == 1 else None


def get_xdist_slave(plugin_manager):
    # TODO: have no idea how to check isinstance "__channelexec__.SlaveInteractor"
    slave_list = filter(lambda p: hasattr(p, 'slaveid'), plugin_manager._plugins)
    return slave_list[0] if len(slave_list) == 1 else None


def is_remote_xdist_session(plugin_manager):
    return get_xdist_slave(plugin_manager) is not None


def pytest_configure(config):
    if is_remote_xdist_session(config.pluginmanager) and get_capman(config.pluginmanager) is not None:
        capman = get_capman(config.pluginmanager)
        capman._method = "no"
        capman.reset_capturings()
        capman.init_capturings()

将其插入到 conftest.py

主要是要确保它是远程会话,我们必须重新配置 CaptureManager 实例。一个未解决的问题是如何检查远程对象是否具有“ __channelexec__.SlaveInteractor”类型。

于 2014-12-29T09:59:27.043 回答