From f10eafbf0101cffe25cf9ebd6174b55820d2b814 Mon Sep 17 00:00:00 2001 From: phvalguima Date: Wed, 16 Oct 2024 21:19:52 +0200 Subject: [PATCH] [DPE-5667] Move away from ops_test's wait_for_idle to wait_until (#479) Moves the CI run for `test_storage.py` to use `wait_until`. Closes #476 --- tests/integration/ha/test_storage.py | 72 ++++++++++++++++++++-------- 1 file changed, 52 insertions(+), 20 deletions(-) diff --git a/tests/integration/ha/test_storage.py b/tests/integration/ha/test_storage.py index b197514d6..761fc7a7d 100644 --- a/tests/integration/ha/test_storage.py +++ b/tests/integration/ha/test_storage.py @@ -49,11 +49,17 @@ async def test_build_and_deploy(ops_test: OpsTest) -> None: # Relate it to OpenSearch to set up TLS. await ops_test.model.integrate(APP_NAME, TLS_CERTIFICATES_APP_NAME) - await ops_test.model.wait_for_idle( + await wait_until( + ops_test, apps=[TLS_CERTIFICATES_APP_NAME, APP_NAME], - status="active", + apps_statuses=["active"], + units_statuses=["active"], timeout=1000, idle_period=IDLE_PERIOD, + wait_for_exact_units={ + TLS_CERTIFICATES_APP_NAME: 1, + my_charm: 1, + }, ) assert len(ops_test.model.applications[APP_NAME].units) == 1 @@ -74,11 +80,16 @@ async def test_storage_reuse_after_scale_down( # scale up to 2 units await ops_test.model.applications[app].add_unit(count=1) - await ops_test.model.wait_for_idle( + await wait_until( + ops_test, apps=[app], - status="active", + apps_statuses=["active"], + units_statuses=["active"], timeout=1000, - wait_for_exact_units=2, + idle_period=IDLE_PERIOD, + wait_for_exact_units={ + app: 2, + }, ) writes_result = await c_writes.stop() @@ -94,12 +105,16 @@ async def test_storage_reuse_after_scale_down( # scale-down to 1 await ops_test.model.applications[app].destroy_unit(f"{app}/{unit_id}") - await ops_test.model.wait_for_idle( - # app status will not be active because after scaling down not all shards are assigned + await wait_until( + ops_test, apps=[app], + apps_statuses=["active"], + units_statuses=["active"], timeout=1000, - wait_for_exact_units=1, idle_period=IDLE_PERIOD, + wait_for_exact_units={ + app: 1, + }, ) # add unit with storage attached @@ -109,12 +124,16 @@ async def test_storage_reuse_after_scale_down( return_code, _, _ = await ops_test.juju(*add_unit_cmd.split()) assert return_code == 0, "Failed to add unit with storage" - await ops_test.model.wait_for_idle( + await wait_until( + ops_test, apps=[app], - status="active", + apps_statuses=["active"], + units_statuses=["active"], timeout=1000, - wait_for_exact_units=2, idle_period=IDLE_PERIOD, + wait_for_exact_units={ + app: 2, + }, ) # check the storage of the new unit @@ -156,11 +175,15 @@ async def test_storage_reuse_after_scale_to_zero( # give some time for removing each unit time.sleep(60) - await ops_test.model.wait_for_idle( - # app status will not be active because after scaling down not all shards are assigned + await wait_until( + ops_test, apps=[app], + apps_statuses=["active", "blocked"], timeout=1000, - wait_for_exact_units=0, + idle_period=IDLE_PERIOD, + wait_for_exact_units={ + app: 0, + }, ) # scale up again @@ -170,11 +193,16 @@ async def test_storage_reuse_after_scale_to_zero( assert return_code == 0, f"Failed to add unit with storage {storage_ids[unit_id]}" await ops_test.model.wait_for_idle(apps=[app], timeout=1000) - await ops_test.model.wait_for_idle( + await wait_until( + ops_test, apps=[app], - status="active", + apps_statuses=["active"], + units_statuses=["active"], timeout=1000, - wait_for_exact_units=len(unit_ids), + idle_period=IDLE_PERIOD, + wait_for_exact_units={ + app: len(unit_ids), + }, ) # check if data is also imported @@ -206,12 +234,16 @@ async def test_storage_reuse_in_new_cluster_after_app_removal( if len(unit_ids) < 3: await ops_test.model.applications[app].add_unit(count=3 - len(unit_ids)) - await ops_test.model.wait_for_idle( + await wait_until( + ops_test, apps=[app], - status="active", + apps_statuses=["active"], + units_statuses=["active"], timeout=1000, - wait_for_exact_units=3, idle_period=IDLE_PERIOD, + wait_for_exact_units={ + app: 3, + }, ) else: # wait for enough data to be written