From 58c604ca2e777f859455903374e45a419d3d957c Mon Sep 17 00:00:00 2001 From: "renovate[bot]" <29139614+renovate[bot]@users.noreply.github.com> Date: Tue, 11 Jun 2024 12:29:04 +0000 Subject: [PATCH 1/3] Update data-platform-workflows to v13.3.5 (#465) * Update data-platform-workflows to v13.3.5 * Add Allure collection plugin --------- Co-authored-by: renovate[bot] <29139614+renovate[bot]@users.noreply.github.com> Co-authored-by: Carl Csaposs --- .github/workflows/ci.yaml | 6 ++-- .github/workflows/release.yaml | 4 +-- .github/workflows/sync_issue_to_jira.yaml | 2 +- poetry.lock | 34 ++++++++++++++++++----- pyproject.toml | 7 +++-- 5 files changed, 37 insertions(+), 16 deletions(-) diff --git a/.github/workflows/ci.yaml b/.github/workflows/ci.yaml index e5e7353ef7..e303d008a1 100644 --- a/.github/workflows/ci.yaml +++ b/.github/workflows/ci.yaml @@ -22,7 +22,7 @@ on: jobs: lint: name: Lint - uses: canonical/data-platform-workflows/.github/workflows/lint.yaml@v13.2.0 + uses: canonical/data-platform-workflows/.github/workflows/lint.yaml@v13.3.5 unit-test: name: Unit test charm @@ -42,7 +42,7 @@ jobs: build: name: Build charm - uses: canonical/data-platform-workflows/.github/workflows/build_charm.yaml@v13.2.0 + uses: canonical/data-platform-workflows/.github/workflows/build_charm.yaml@v13.3.5 with: cache: true @@ -63,7 +63,7 @@ jobs: - lint - unit-test - build - uses: canonical/data-platform-workflows/.github/workflows/integration_test_charm.yaml@v13.2.0 + uses: canonical/data-platform-workflows/.github/workflows/integration_test_charm.yaml@v13.3.5 with: artifact-prefix: ${{ needs.build.outputs.artifact-prefix }} architecture: ${{ matrix.architecture }} diff --git a/.github/workflows/release.yaml b/.github/workflows/release.yaml index ffc2119371..67a85de416 100644 --- a/.github/workflows/release.yaml +++ b/.github/workflows/release.yaml @@ -24,14 +24,14 @@ jobs: build: name: Build charm - uses: canonical/data-platform-workflows/.github/workflows/build_charm.yaml@v13.2.0 + uses: canonical/data-platform-workflows/.github/workflows/build_charm.yaml@v13.3.5 release: name: Release charm needs: - ci-tests - build - uses: canonical/data-platform-workflows/.github/workflows/release_charm.yaml@v13.2.0 + uses: canonical/data-platform-workflows/.github/workflows/release_charm.yaml@v13.3.5 with: channel: 14/edge artifact-prefix: ${{ needs.build.outputs.artifact-prefix }} diff --git a/.github/workflows/sync_issue_to_jira.yaml b/.github/workflows/sync_issue_to_jira.yaml index 6fbe36ba41..d5b8dd76e5 100644 --- a/.github/workflows/sync_issue_to_jira.yaml +++ b/.github/workflows/sync_issue_to_jira.yaml @@ -9,7 +9,7 @@ on: jobs: sync: name: Sync GitHub issue to Jira - uses: canonical/data-platform-workflows/.github/workflows/sync_issue_to_jira.yaml@v13.2.0 + uses: canonical/data-platform-workflows/.github/workflows/sync_issue_to_jira.yaml@v13.3.5 with: jira-base-url: https://warthogs.atlassian.net jira-project-key: DPE diff --git a/poetry.lock b/poetry.lock index a83bddad16..3492bf9002 100644 --- a/poetry.lock +++ b/poetry.lock @@ -15,6 +15,26 @@ files = [ allure-python-commons = "2.13.5" pytest = ">=4.5.0" +[[package]] +name = "allure-pytest-collection-report" +version = "0.1.0" +description = "" +optional = false +python-versions = "^3.8" +files = [] +develop = false + +[package.dependencies] +allure-pytest = ">=2.13.5" +pytest = "*" + +[package.source] +type = "git" +url = "https://github.com/canonical/data-platform-workflows" +reference = "v13.3.5" +resolved_reference = "4885220b28fecc7ee684b6b59b55c58cbd92995f" +subdirectory = "python/pytest_plugins/allure_pytest_collection_report" + [[package]] name = "allure-python-commons" version = "2.13.5" @@ -1462,8 +1482,8 @@ develop = false [package.source] type = "git" url = "https://github.com/canonical/data-platform-workflows" -reference = "v13.2.0" -resolved_reference = "ba12595b3c9e91b245648a49c82dc181211a5769" +reference = "v13.3.5" +resolved_reference = "4885220b28fecc7ee684b6b59b55c58cbd92995f" subdirectory = "python/pytest_plugins/github_secrets" [[package]] @@ -1500,8 +1520,8 @@ pyyaml = "*" [package.source] type = "git" url = "https://github.com/canonical/data-platform-workflows" -reference = "v13.2.0" -resolved_reference = "ba12595b3c9e91b245648a49c82dc181211a5769" +reference = "v13.3.5" +resolved_reference = "4885220b28fecc7ee684b6b59b55c58cbd92995f" subdirectory = "python/pytest_plugins/pytest_operator_cache" [[package]] @@ -1519,8 +1539,8 @@ pytest = "*" [package.source] type = "git" url = "https://github.com/canonical/data-platform-workflows" -reference = "v13.2.0" -resolved_reference = "ba12595b3c9e91b245648a49c82dc181211a5769" +reference = "v13.3.5" +resolved_reference = "4885220b28fecc7ee684b6b59b55c58cbd92995f" subdirectory = "python/pytest_plugins/pytest_operator_groups" [[package]] @@ -2051,4 +2071,4 @@ files = [ [metadata] lock-version = "2.0" python-versions = "^3.10" -content-hash = "a73b8801ba490c66892f7cc917ab87480a8d29ae7cc37920023499f11536f6cd" +content-hash = "8c03a8baf1c1edabaed0984bac0152801a022f935f26f05c507e7abbf92c5b17" diff --git a/pyproject.toml b/pyproject.toml index ca1805e9de..15cf7b89ce 100644 --- a/pyproject.toml +++ b/pyproject.toml @@ -66,10 +66,10 @@ optional = true [tool.poetry.group.integration.dependencies] pytest = "^8.2.0" -pytest-github-secrets = {git = "https://github.com/canonical/data-platform-workflows", tag = "v13.2.0", subdirectory = "python/pytest_plugins/github_secrets"} +pytest-github-secrets = {git = "https://github.com/canonical/data-platform-workflows", tag = "v13.3.5", subdirectory = "python/pytest_plugins/github_secrets"} pytest-operator = "^0.35.0" -pytest-operator-cache = {git = "https://github.com/canonical/data-platform-workflows", tag = "v13.2.0", subdirectory = "python/pytest_plugins/pytest_operator_cache"} -pytest-operator-groups = {git = "https://github.com/canonical/data-platform-workflows", tag = "v13.2.0", subdirectory = "python/pytest_plugins/pytest_operator_groups"} +pytest-operator-cache = {git = "https://github.com/canonical/data-platform-workflows", tag = "v13.3.5", subdirectory = "python/pytest_plugins/pytest_operator_cache"} +pytest-operator-groups = {git = "https://github.com/canonical/data-platform-workflows", tag = "v13.3.5", subdirectory = "python/pytest_plugins/pytest_operator_groups"} # renovate caret doesn't work: https://github.com/renovatebot/renovate/issues/26940 juju = "<=3.4.0.0" boto3 = "*" @@ -78,6 +78,7 @@ landscape-api-py3 = "^0.9.0" mailmanclient = "^3.3.5" psycopg2-binary = "^2.9.9" allure-pytest = "^2.13.5" +allure-pytest-collection-report = {git = "https://github.com/canonical/data-platform-workflows", tag = "v13.3.5", subdirectory = "python/pytest_plugins/allure_pytest_collection_report"} # Testing tools configuration [tool.coverage.run] From fed95f299b4e9311b58f6c680dde34c42b03a663 Mon Sep 17 00:00:00 2001 From: Carl Csaposs Date: Thu, 13 Jun 2024 08:15:13 +0000 Subject: [PATCH 2/3] Enable ARM integration tests on nightly CI (#491) ARM integration tests were disabled on nightly CI, PR CI, and release CI/CD in #244 to save costs (on GitHub-hosted ARM runners) while waiting for IS-hosted ARM runner stabilization Re-enable GitHub-hosted ARM runners only on nightly CI --- .github/workflows/ci.yaml | 11 ++++++++--- .github/workflows/release.yaml | 4 ++-- .github/workflows/sync_issue_to_jira.yaml | 2 +- poetry.lock | 18 +++++++++--------- pyproject.toml | 8 ++++---- 5 files changed, 24 insertions(+), 19 deletions(-) diff --git a/.github/workflows/ci.yaml b/.github/workflows/ci.yaml index e303d008a1..1c482c4eb5 100644 --- a/.github/workflows/ci.yaml +++ b/.github/workflows/ci.yaml @@ -22,7 +22,7 @@ on: jobs: lint: name: Lint - uses: canonical/data-platform-workflows/.github/workflows/lint.yaml@v13.3.5 + uses: canonical/data-platform-workflows/.github/workflows/lint.yaml@v14.0.0 unit-test: name: Unit test charm @@ -42,7 +42,7 @@ jobs: build: name: Build charm - uses: canonical/data-platform-workflows/.github/workflows/build_charm.yaml@v13.3.5 + uses: canonical/data-platform-workflows/.github/workflows/build_charm.yaml@v14.0.0 with: cache: true @@ -58,12 +58,17 @@ jobs: allure_on_amd64: true architecture: - amd64 + include: + - juju: + agent: 3.1.8 # renovate: latest juju 3 + allure_on_amd64: true + architecture: arm64 name: Integration test charm | ${{ matrix.juju.agent }} | ${{ matrix.architecture }} needs: - lint - unit-test - build - uses: canonical/data-platform-workflows/.github/workflows/integration_test_charm.yaml@v13.3.5 + uses: canonical/data-platform-workflows/.github/workflows/integration_test_charm.yaml@v14.0.0 with: artifact-prefix: ${{ needs.build.outputs.artifact-prefix }} architecture: ${{ matrix.architecture }} diff --git a/.github/workflows/release.yaml b/.github/workflows/release.yaml index 67a85de416..a4fb5d2afc 100644 --- a/.github/workflows/release.yaml +++ b/.github/workflows/release.yaml @@ -24,14 +24,14 @@ jobs: build: name: Build charm - uses: canonical/data-platform-workflows/.github/workflows/build_charm.yaml@v13.3.5 + uses: canonical/data-platform-workflows/.github/workflows/build_charm.yaml@v14.0.0 release: name: Release charm needs: - ci-tests - build - uses: canonical/data-platform-workflows/.github/workflows/release_charm.yaml@v13.3.5 + uses: canonical/data-platform-workflows/.github/workflows/release_charm.yaml@v14.0.0 with: channel: 14/edge artifact-prefix: ${{ needs.build.outputs.artifact-prefix }} diff --git a/.github/workflows/sync_issue_to_jira.yaml b/.github/workflows/sync_issue_to_jira.yaml index d5b8dd76e5..b1d1b02e3b 100644 --- a/.github/workflows/sync_issue_to_jira.yaml +++ b/.github/workflows/sync_issue_to_jira.yaml @@ -9,7 +9,7 @@ on: jobs: sync: name: Sync GitHub issue to Jira - uses: canonical/data-platform-workflows/.github/workflows/sync_issue_to_jira.yaml@v13.3.5 + uses: canonical/data-platform-workflows/.github/workflows/sync_issue_to_jira.yaml@v14.0.0 with: jira-base-url: https://warthogs.atlassian.net jira-project-key: DPE diff --git a/poetry.lock b/poetry.lock index 3492bf9002..1375a3d273 100644 --- a/poetry.lock +++ b/poetry.lock @@ -31,8 +31,8 @@ pytest = "*" [package.source] type = "git" url = "https://github.com/canonical/data-platform-workflows" -reference = "v13.3.5" -resolved_reference = "4885220b28fecc7ee684b6b59b55c58cbd92995f" +reference = "v14.0.0" +resolved_reference = "59afebbfa1a372140df6fc63e7d747cfc013adc5" subdirectory = "python/pytest_plugins/allure_pytest_collection_report" [[package]] @@ -1482,8 +1482,8 @@ develop = false [package.source] type = "git" url = "https://github.com/canonical/data-platform-workflows" -reference = "v13.3.5" -resolved_reference = "4885220b28fecc7ee684b6b59b55c58cbd92995f" +reference = "v14.0.0" +resolved_reference = "59afebbfa1a372140df6fc63e7d747cfc013adc5" subdirectory = "python/pytest_plugins/github_secrets" [[package]] @@ -1520,8 +1520,8 @@ pyyaml = "*" [package.source] type = "git" url = "https://github.com/canonical/data-platform-workflows" -reference = "v13.3.5" -resolved_reference = "4885220b28fecc7ee684b6b59b55c58cbd92995f" +reference = "v14.0.0" +resolved_reference = "59afebbfa1a372140df6fc63e7d747cfc013adc5" subdirectory = "python/pytest_plugins/pytest_operator_cache" [[package]] @@ -1539,8 +1539,8 @@ pytest = "*" [package.source] type = "git" url = "https://github.com/canonical/data-platform-workflows" -reference = "v13.3.5" -resolved_reference = "4885220b28fecc7ee684b6b59b55c58cbd92995f" +reference = "v14.0.0" +resolved_reference = "59afebbfa1a372140df6fc63e7d747cfc013adc5" subdirectory = "python/pytest_plugins/pytest_operator_groups" [[package]] @@ -2071,4 +2071,4 @@ files = [ [metadata] lock-version = "2.0" python-versions = "^3.10" -content-hash = "8c03a8baf1c1edabaed0984bac0152801a022f935f26f05c507e7abbf92c5b17" +content-hash = "5eba2796328eeaad07e90fb8f2beebffedb191089e204af6cf7ff538155e948d" diff --git a/pyproject.toml b/pyproject.toml index 15cf7b89ce..a753a7fd71 100644 --- a/pyproject.toml +++ b/pyproject.toml @@ -66,10 +66,10 @@ optional = true [tool.poetry.group.integration.dependencies] pytest = "^8.2.0" -pytest-github-secrets = {git = "https://github.com/canonical/data-platform-workflows", tag = "v13.3.5", subdirectory = "python/pytest_plugins/github_secrets"} +pytest-github-secrets = {git = "https://github.com/canonical/data-platform-workflows", tag = "v14.0.0", subdirectory = "python/pytest_plugins/github_secrets"} pytest-operator = "^0.35.0" -pytest-operator-cache = {git = "https://github.com/canonical/data-platform-workflows", tag = "v13.3.5", subdirectory = "python/pytest_plugins/pytest_operator_cache"} -pytest-operator-groups = {git = "https://github.com/canonical/data-platform-workflows", tag = "v13.3.5", subdirectory = "python/pytest_plugins/pytest_operator_groups"} +pytest-operator-cache = {git = "https://github.com/canonical/data-platform-workflows", tag = "v14.0.0", subdirectory = "python/pytest_plugins/pytest_operator_cache"} +pytest-operator-groups = {git = "https://github.com/canonical/data-platform-workflows", tag = "v14.0.0", subdirectory = "python/pytest_plugins/pytest_operator_groups"} # renovate caret doesn't work: https://github.com/renovatebot/renovate/issues/26940 juju = "<=3.4.0.0" boto3 = "*" @@ -78,7 +78,7 @@ landscape-api-py3 = "^0.9.0" mailmanclient = "^3.3.5" psycopg2-binary = "^2.9.9" allure-pytest = "^2.13.5" -allure-pytest-collection-report = {git = "https://github.com/canonical/data-platform-workflows", tag = "v13.3.5", subdirectory = "python/pytest_plugins/allure_pytest_collection_report"} +allure-pytest-collection-report = {git = "https://github.com/canonical/data-platform-workflows", tag = "v14.0.0", subdirectory = "python/pytest_plugins/allure_pytest_collection_report"} # Testing tools configuration [tool.coverage.run] From 4fb533b49b51515932a61f5479e934e2638bfce1 Mon Sep 17 00:00:00 2001 From: Marcelo Henrique Neppel Date: Thu, 13 Jun 2024 09:01:32 -0300 Subject: [PATCH 3/3] Handle upgrade of top of the stack Juju leader (#492) Signed-off-by: Marcelo Henrique Neppel --- lib/charms/data_platform_libs/v0/upgrade.py | 13 ++++++++++++- 1 file changed, 12 insertions(+), 1 deletion(-) diff --git a/lib/charms/data_platform_libs/v0/upgrade.py b/lib/charms/data_platform_libs/v0/upgrade.py index ef74644de4..18a58ff09e 100644 --- a/lib/charms/data_platform_libs/v0/upgrade.py +++ b/lib/charms/data_platform_libs/v0/upgrade.py @@ -285,7 +285,7 @@ def restart(self, event) -> None: # Increment this PATCH version before using `charmcraft publish-lib` or reset # to 0 if you are raising the major API version -LIBPATCH = 16 +LIBPATCH = 17 PYDEPS = ["pydantic>=1.10,<2", "poetry-core"] @@ -907,6 +907,17 @@ def _on_upgrade_charm(self, event: UpgradeCharmEvent) -> None: logger.error(e) self.set_unit_failed() return + top_unit_id = self.upgrade_stack[-1] + top_unit = self.charm.model.get_unit(f"{self.charm.app.name}/{top_unit_id}") + if ( + top_unit == self.charm.unit + and self.peer_relation.data[self.charm.unit].get("state") == "recovery" + ): + # While in a rollback and the Juju leader unit is the top unit in the upgrade stack, emit the event + # for this unit to start the rollback. + self.peer_relation.data[self.charm.unit].update({"state": "ready"}) + self.on_upgrade_changed(event) + return self.charm.unit.status = WaitingStatus("other units upgrading first...") self.peer_relation.data[self.charm.unit].update({"state": "ready"})