From e1c957bc1438f86e05e10a38f657fab0138ba7a2 Mon Sep 17 00:00:00 2001 From: phala Date: Wed, 7 Feb 2024 19:02:00 +0100 Subject: [PATCH] Fix Kuadrant check when spokes are missing --- Makefile | 2 +- testsuite/capabilities.py | 21 ++++++++++++++------- testsuite/config/openshift_loader.py | 1 - testsuite/tests/conftest.py | 15 ++++----------- 4 files changed, 19 insertions(+), 20 deletions(-) diff --git a/Makefile b/Makefile index c9554238..5d4c72e1 100644 --- a/Makefile +++ b/Makefile @@ -42,7 +42,7 @@ testsuite/%: FORCE poetry-no-dev test: ## Run all non mgc tests test pytest tests: poetry-no-dev - $(PYTEST) -n4 -m 'not mgc' --dist loadfile $(flags) testsuite + $(PYTEST) -n4 -m 'not mgc' --dist loadfile --enforce $(flags) testsuite authorino: ## Run only authorino related tests authorino: poetry-no-dev diff --git a/testsuite/capabilities.py b/testsuite/capabilities.py index 499a304c..399b91c5 100644 --- a/testsuite/capabilities.py +++ b/testsuite/capabilities.py @@ -10,17 +10,24 @@ @functools.cache def has_kuadrant(): """Returns True, if Kuadrant deployment is present and should be used""" - spokes = weakget(settings)["control_plane"]["spokes"] % {} - - for name, openshift in spokes.items(): - # Try if Kuadrant is deployed - if not openshift.connected: - return False, f"Spoke {name} is not connected" + if spokes := weakget(settings)["control_plane"]["spokes"] % {}: + for name, openshift in spokes.items(): + # Try if Kuadrant is deployed + if not openshift.connected: + return False, f"Spoke {name} is not connected" + project = settings["service_protection"]["system_project"] + kuadrant_openshift = openshift.change_project(project) + kuadrants = kuadrant_openshift.do_action("get", "kuadrant", "-o", "json", parse_output=True) + if len(kuadrants.model["items"]) == 0: + return False, f"Spoke {name} does not have Kuadrant resource in project {project}" + + else: + openshift = settings["service_protection"]["project"] project = settings["service_protection"]["system_project"] kuadrant_openshift = openshift.change_project(project) kuadrants = kuadrant_openshift.do_action("get", "kuadrant", "-o", "json", parse_output=True) if len(kuadrants.model["items"]) == 0: - return False, f"Spoke {name} does not have Kuadrant resource in project {project}" + return False, f"Kuadrant resource is not installed in project {project}" return True, None diff --git a/testsuite/config/openshift_loader.py b/testsuite/config/openshift_loader.py index 8a3b161d..a1e2aa57 100644 --- a/testsuite/config/openshift_loader.py +++ b/testsuite/config/openshift_loader.py @@ -27,7 +27,6 @@ def load(obj, env=None, silent=True, key=None, filename=None): obj["tools"] = tools service_protection = obj.setdefault("service_protection", {}) - inject_client(service_protection, client, "system_project") inject_client(service_protection, client, "project") inject_client(service_protection, client, "project2") diff --git a/testsuite/tests/conftest.py b/testsuite/tests/conftest.py index 83e06199..b8a4df3c 100644 --- a/testsuite/tests/conftest.py +++ b/testsuite/tests/conftest.py @@ -57,14 +57,13 @@ def pytest_runtest_setup(item): skip_or_fail( "Unable to run Standalone only test: Standalone mode is disabled, please use --standalone flag" ) - if "kuadrant_only" in marks: - kuadrant, error = has_kuadrant() - if not kuadrant: - skip_or_fail(f"Unable to locate Kuadrant installation: {error}") if "mgc" in marks: mgc, error = has_mgc() if not mgc: skip_or_fail(f"Unable to locate MGC installation: {error}") + kuadrant, error = has_kuadrant() + if not kuadrant: + skip_or_fail(f"Unable to locate Kuadrant installation: {error}") @pytest.hookimpl(hookwrapper=True) @@ -251,17 +250,11 @@ def module_label(label): @pytest.fixture(scope="module") -def kuadrant(request, testconfig, openshift): +def kuadrant(request): """Returns Kuadrant instance if exists, or None""" if request.config.getoption("--standalone"): return None - # Try if Kuadrant is deployed - kuadrant_openshift = testconfig["service_protection"]["system_project"] - kuadrants = kuadrant_openshift.do_action("get", "kuadrant", "-o", "json", parse_output=True) - if len(kuadrants.model["items"]) == 0: - pytest.fail("Running Kuadrant tests, but Kuadrant resource was not found") - # TODO: Return actual Kuadrant object return True