Fix fixture lookup in pytest_generate_tests

Signed-off-by: Kirill Sosnovskikh <k.sosnovskikh@yadro.com>
This commit is contained in:
k.sosnovskikh 2024-08-20 18:05:34 +03:00
parent 156c32a0cb
commit 65fab7f1c5
2 changed files with 20 additions and 16 deletions

View file

@ -21,7 +21,7 @@ Additionally, `allure-validator` can be added to pre-commit hooks:
# .pre-commit-config.yaml # .pre-commit-config.yaml
repos: repos:
- repo: https://git.frostfs.info/TrueCloudLab/allure-validator - repo: https://git.frostfs.info/TrueCloudLab/allure-validator
rev: 1.0.0 rev: latest
hooks: hooks:
- id: allure-validator - id: allure-validator
args: ["pytest_tests/"] args: ["pytest_tests/"]

View file

@ -133,21 +133,25 @@ def fixtures(ast_fixtures: list[ast.FunctionDef], ast_hooks: list[ast.FunctionDe
for ast_hook in ast_hooks: for ast_hook in ast_hooks:
path = getattr(ast_hook, ATTR_PATH) path = getattr(ast_hook, ATTR_PATH)
for node in ast_hook.body: for node in ast.walk(ast_hook):
if isinstance(node, ast.Expr): if not isinstance(node, ast.Expr):
if parse.decorator(node.value) == PYTEST_METAFUNC_PARAMETRIZE: continue
fixture_names = parse.param_names(node.value.args[0])
for name in fixture_names: if parse.decorator(node.value) != PYTEST_METAFUNC_PARAMETRIZE:
# Dynamic fake fixture continue
fixture = Fixture(
name, fixture_names = parse.param_names(node.value.args[0])
path, for name in fixture_names:
node.lineno, # Dynamic fake fixture
node.col_offset, fixture = Fixture(
args=[], name,
params=["parametrized"], path,
) node.lineno,
fixtures[fixture] = fixture node.col_offset,
args=[],
params=["parametrized"],
)
fixtures[fixture] = fixture
for fixture in fixtures.values(): for fixture in fixtures.values():
for arg in fixture.args: for arg in fixture.args: