如何从 pytest 固定装置正确返回列表以用于参数化?

New*_*Guy 5 python fixtures pytest parametrized-testing

我正在尝试构建一个小的 pytest 测试,以确保 redis 中存在所有预期的键。我有一个预期键列表,我将其存储为 YML 文件。测试本身将查询 redis 以确保列表中的每个预期键都存在。

最初,我将此设置为test_keys.py文件中的一个巨大列表。这是这样设置的:

expected_keys = ['key1','key2','key3']
@pytest.mark.parametrize('expected_key', expected_keys)
def test_expected_key(expected_key):
    ...
Run Code Online (Sandbox Code Playgroud)

这有效。由于我想为 redis 环境的其他一些检查复制这种类型的测试,因此我不想将包含几百个键的多个列表放入这些文件中。

我想我可以将它们提取到 YML 文件中并通过装置加载键。

我的夹具看起来像这样:

@pytest.fixture
def expected_keys_fixture():
    with open('expected_keys.yml'), 'r') as f:
        return yaml.safe_load(f)['keys']
Run Code Online (Sandbox Code Playgroud)

YML 看起来像这样:

keys:
  - key1
  - key2
  - key3
Run Code Online (Sandbox Code Playgroud)

我的测试装饰器更改为:

@pytest.mark.parametrize("expected_keys", [
    (pytest.lazy_fixture('expected_keys_fixture'))
])
def test_expected_key(expected_key):
    ...
Run Code Online (Sandbox Code Playgroud)

我正在pytest-lazy-fixture为此使用该软件包。

我在这里expected_keys遇到的问题是现在等于预期键的整个列表。当静态列表在我的测试文件中时,它不再是每个单独的密钥。

我试图按照 Oleh Rybalchenko 的回答建议去做

@pytest.mark.parametrize("expected_keys", pytest.lazy_fixture('expected_keys_fixture')
)
def test_expected_key(expected_key):
    ...
Run Code Online (Sandbox Code Playgroud)

但是,这失败了TypeError: 'LazyFixture' object is not iterable

我知道我只有一个 argname 并且我应该有一个列表,但是文档中的示例将参数传递给fixture()装饰器。我不是。我的列表是由 YML 文件的结果生成的。


问题:如何调整我的装置,以便它一次为parametrize装饰者正确返回一个项目?

Rom*_*rov 10

在同样的情况下,我发现的唯一方法是拒绝夹具并直接调用该函数。

def expected_keys_fixture():
    with open('expected_keys.yml', 'r') as f:
        return yaml.safe_load(f)['keys']


@pytest.mark.parametrize("expected_key",
                         expected_keys_fixture())
def test_expected_key(expected_key):
    assert expected_key in ['key1', 'key2', 'key3']

Run Code Online (Sandbox Code Playgroud)