From b86bbac3497aef789348d91f15caf3a1746b2352 Mon Sep 17 00:00:00 2001 From: phvalguima Date: Wed, 5 Jun 2024 23:41:13 +0200 Subject: [PATCH] [DPE-4305][DPE-4454] Update to 2.14.0 and adds support for multi versions in small upgrade tests (#315) Update pinning and workload_version to 2.14.0. Also extends integration testing to cover the jump between 2.12, 2.13 and current 2.14. Adds a skip to large deployments upgrade test while waiting for DPE-4528. Accompanying PR to update libs: https://github.com/canonical/opensearch-operator/pull/319 --- lib/charms/opensearch/v0/constants_charm.py | 2 +- .../test_manual_large_deployment_upgrades.py | 2 + .../test_small_deployment_upgrades.py | 106 +++++++++++++++--- workload_version | 2 +- 4 files changed, 92 insertions(+), 20 deletions(-) diff --git a/lib/charms/opensearch/v0/constants_charm.py b/lib/charms/opensearch/v0/constants_charm.py index abda63ef3..4b852daef 100644 --- a/lib/charms/opensearch/v0/constants_charm.py +++ b/lib/charms/opensearch/v0/constants_charm.py @@ -108,7 +108,7 @@ KibanaserverRole = "kibana_server" # Opensearch Snap revision -OPENSEARCH_SNAP_REVISION = 50 # Keep in sync with `workload_version` file +OPENSEARCH_SNAP_REVISION = 51 # Keep in sync with `workload_version` file # User-face Backup ID format OPENSEARCH_BACKUP_ID_FORMAT = "%Y-%m-%dT%H:%M:%SZ" diff --git a/tests/integration/test_manual_large_deployment_upgrades.py b/tests/integration/test_manual_large_deployment_upgrades.py index 418ed75bb..2eaeaf6c0 100644 --- a/tests/integration/test_manual_large_deployment_upgrades.py +++ b/tests/integration/test_manual_large_deployment_upgrades.py @@ -50,6 +50,7 @@ async def c_writes_runner(ops_test: OpsTest, c_writes: ContinuousWrites): logger.info("\n\n\n\nThe writes have been cleared.\n\n\n\n") +@pytest.mark.skip(reason="Fix with DPE-4528") @pytest.mark.runner(["self-hosted", "linux", "X64", "jammy", "xlarge"]) @pytest.mark.group(1) @pytest.mark.abort_on_fail @@ -134,6 +135,7 @@ async def test_large_deployment_deploy_original_charm(ops_test: OpsTest) -> None ) +@pytest.mark.skip(reason="Fix with DPE-4528") @pytest.mark.runner(["self-hosted", "linux", "X64", "jammy", "xlarge"]) @pytest.mark.group(1) @pytest.mark.abort_on_fail diff --git a/tests/integration/test_small_deployment_upgrades.py b/tests/integration/test_small_deployment_upgrades.py index 28190f4d6..366804d64 100644 --- a/tests/integration/test_small_deployment_upgrades.py +++ b/tests/integration/test_small_deployment_upgrades.py @@ -19,10 +19,18 @@ OPENSEARCH_ORIGINAL_CHARM_NAME = "opensearch" -OPENSEARCH_INITIAL_CHANNEL = "2/edge" +OPENSEARCH_CHANNEL = "2/edge" + MACHINE_ID = 0 +VERSION_TO_REVISION = { + "2.13.0": 91, +} +FIRST_VERSION = "2.12.0" +FIRST_REVISION = 90 + + charm = None @@ -54,7 +62,8 @@ async def test_deploy_latest_from_channel(ops_test: OpsTest) -> None: OPENSEARCH_ORIGINAL_CHARM_NAME, application_name=APP_NAME, num_units=3, - channel=OPENSEARCH_INITIAL_CHANNEL, + channel=OPENSEARCH_CHANNEL, + revision=FIRST_REVISION, series=SERIES, ) @@ -73,6 +82,7 @@ async def test_deploy_latest_from_channel(ops_test: OpsTest) -> None: assert len(ops_test.model.applications[APP_NAME].units) == 3 +@pytest.mark.runner(["self-hosted", "linux", "X64", "jammy", "xlarge"]) @pytest.mark.group(1) @pytest.mark.abort_on_fail async def test_upgrade_rollback( @@ -83,7 +93,6 @@ async def test_upgrade_rollback( units = await get_application_units(ops_test, app) leader_id = [u.id for u in units if u.is_leader][0] - application = ops_test.model.applications[APP_NAME] action = await run_action( ops_test, leader_id, @@ -92,14 +101,16 @@ async def test_upgrade_rollback( ) assert action.status == "completed" - logger.info("Build charm locally") - global charm - if not charm: - charm = await ops_test.build_charm(".") + new_rev = list(VERSION_TO_REVISION.values())[-1] async with ops_test.fast_forward(): logger.info("Refresh the charm") - await application.refresh(path=charm) + # due to: https://github.com/juju/python-libjuju/issues/1057 + # application = ops_test.model.applications[APP_NAME] + # await application.refresh( + # revision=new_rev, + # ) + subprocess.check_output(f"juju refresh opensearch --revision={new_rev}".split()) await wait_until( ops_test, @@ -113,17 +124,11 @@ async def test_upgrade_rollback( ) logger.info("Rolling back") - # Facing the same issue as descripted in: - # https://github.com/juju/python-libjuju/issues/924 - # application = ops_test.model.applications[APP_NAME] + # due to: https://github.com/juju/python-libjuju/issues/1057 # await application.refresh( - # switch="ch:pguimaraes-opensearch-upgrade-test", - # channel=OPENSEARCH_INITIAL_CHANNEL, + # revision=rev, # ) - subprocess.check_output( - f"juju refresh {app} --switch {OPENSEARCH_ORIGINAL_CHARM_NAME} " - f"--channel {OPENSEARCH_INITIAL_CHANNEL}".split(), - ) + subprocess.check_output(f"juju refresh opensearch --revision={FIRST_REVISION}".split()) await wait_until( ops_test, @@ -137,6 +142,72 @@ async def test_upgrade_rollback( ) +@pytest.mark.runner(["self-hosted", "linux", "X64", "jammy", "xlarge"]) +@pytest.mark.group(1) +@pytest.mark.abort_on_fail +async def test_upgrade_between_versions( + ops_test: OpsTest, c_writes: ContinuousWrites, c_writes_runner +) -> None: + """Test upgrade from upstream to currently locally built version.""" + app = (await app_name(ops_test)) or APP_NAME + units = await get_application_units(ops_test, app) + leader_id = [u.id for u in units if u.is_leader][0] + + for version, rev in VERSION_TO_REVISION.items(): + logger.info(f"Upgrading to version {version}") + + action = await run_action( + ops_test, + leader_id, + "pre-upgrade-check", + app=app, + ) + assert action.status == "completed" + + async with ops_test.fast_forward(): + logger.info("Refresh the charm") + # due to: https://github.com/juju/python-libjuju/issues/1057 + # application = ops_test.model.applications[APP_NAME] + # await application.refresh( + # revision=rev, + # ) + subprocess.check_output(f"juju refresh opensearch --revision={rev}".split()) + + await wait_until( + ops_test, + apps=[app], + apps_statuses=["blocked"], + units_statuses=["active"], + wait_for_exact_units={ + APP_NAME: 3, + }, + idle_period=IDLE_PERIOD, + ) + + logger.info("Upgrade finished") + # Resume the upgrade + action = await run_action( + ops_test, + leader_id, + "resume-upgrade", + app=app, + ) + logger.info(action) + assert action.status == "completed" + + logger.info("Refresh is over, waiting for the charm to settle") + await wait_until( + ops_test, + apps=[app], + apps_statuses=["active"], + units_statuses=["active"], + wait_for_exact_units={ + APP_NAME: 3, + }, + idle_period=IDLE_PERIOD, + ) + + @pytest.mark.runner(["self-hosted", "linux", "X64", "jammy", "xlarge"]) @pytest.mark.group(1) @pytest.mark.abort_on_fail @@ -178,7 +249,6 @@ async def test_upgrade_to_local( ) logger.info("Upgrade finished") - logger.info(subprocess.check_output("juju status".split())) # Resume the upgrade action = await run_action( ops_test, diff --git a/workload_version b/workload_version index fb2c0766b..edcfe40d1 100644 --- a/workload_version +++ b/workload_version @@ -1 +1 @@ -2.13.0 +2.14.0