diff --git a/.github/workflows/ci.yaml b/.github/workflows/ci.yaml index 558e87d2b4..bfe179ab72 100644 --- a/.github/workflows/ci.yaml +++ b/.github/workflows/ci.yaml @@ -24,7 +24,7 @@ on: jobs: lint: name: Lint - uses: canonical/data-platform-workflows/.github/workflows/lint.yaml@v21.0.1 + uses: canonical/data-platform-workflows/.github/workflows/lint.yaml@v22.0.0 unit-test: name: Unit test charm @@ -46,7 +46,7 @@ jobs: build: name: Build charm - uses: canonical/data-platform-workflows/.github/workflows/build_charm.yaml@v21.0.1 + uses: canonical/data-platform-workflows/.github/workflows/build_charm.yaml@v22.0.0 with: cache: true @@ -55,16 +55,16 @@ jobs: fail-fast: false matrix: juju: - - agent: 2.9.50 # renovate: juju-agent-pin-minor + - agent: 2.9.51 # renovate: juju-agent-pin-minor libjuju: ==2.9.49.0 # renovate: latest libjuju 2 allure_on_amd64: false - - agent: 3.4.5 # renovate: juju-agent-pin-minor + - agent: 3.4.6 # renovate: juju-agent-pin-minor allure_on_amd64: true architecture: - amd64 include: - juju: - agent: 3.4.5 # renovate: juju-agent-pin-minor + agent: 3.4.6 # renovate: juju-agent-pin-minor allure_on_amd64: true architecture: arm64 name: Integration | ${{ matrix.juju.agent }} | ${{ matrix.architecture }} @@ -72,7 +72,7 @@ jobs: - lint - unit-test - build - uses: canonical/data-platform-workflows/.github/workflows/integration_test_charm.yaml@v21.0.1 + uses: canonical/data-platform-workflows/.github/workflows/integration_test_charm.yaml@v22.0.0 with: artifact-prefix: ${{ needs.build.outputs.artifact-prefix }} architecture: ${{ matrix.architecture }} diff --git a/.github/workflows/cla-check.yml b/.github/workflows/cla-check.yml index ec8abbf995..f0590d5b65 100644 --- a/.github/workflows/cla-check.yml +++ b/.github/workflows/cla-check.yml @@ -6,7 +6,7 @@ on: jobs: cla-check: - runs-on: ubuntu-22.04 + runs-on: ubuntu-24.04 steps: - name: Check if Canonical's Contributor License Agreement has been signed uses: canonical/has-signed-canonical-cla@v1 diff --git a/.github/workflows/lib-check.yaml b/.github/workflows/lib-check.yaml index 7316f45a53..6176c25cad 100644 --- a/.github/workflows/lib-check.yaml +++ b/.github/workflows/lib-check.yaml @@ -26,17 +26,6 @@ jobs: uses: actions/checkout@v4 with: fetch-depth: 0 - - name: Set up environment - run: | - pipx install tox - pipx install poetry - pipx inject poetry poetry-plugin-export - # TODO: Remove after https://github.com/python-poetry/poetry/pull/5980 is closed - poetry config warnings.export false - - name: Generate requirements - run: | - tox run -e build-wrapper - mv requirements-last-build.txt requirements.txt - name: Check libs uses: canonical/charming-actions/check-libraries@2.6.3 with: diff --git a/.github/workflows/release.yaml b/.github/workflows/release.yaml index f29a1c8791..0ae1955217 100644 --- a/.github/workflows/release.yaml +++ b/.github/workflows/release.yaml @@ -34,17 +34,6 @@ jobs: uses: actions/checkout@v4 with: fetch-depth: 0 - - name: Set up environment - run: | - pipx install tox - pipx install poetry - pipx inject poetry poetry-plugin-export - # TODO: Remove after https://github.com/python-poetry/poetry/pull/5980 is closed - poetry config warnings.export false - - name: Generate requirements - run: | - tox run -e build-wrapper - mv requirements-last-build.txt requirements.txt - name: Release charm libraries uses: canonical/charming-actions/release-libraries@2.6.3 with: @@ -53,14 +42,14 @@ jobs: build: name: Build charm - uses: canonical/data-platform-workflows/.github/workflows/build_charm.yaml@v21.0.1 + uses: canonical/data-platform-workflows/.github/workflows/build_charm.yaml@v22.0.0 release: name: Release charm needs: - ci-tests - build - uses: canonical/data-platform-workflows/.github/workflows/release_charm.yaml@v21.0.1 + uses: canonical/data-platform-workflows/.github/workflows/release_charm.yaml@v22.0.0 with: channel: 14/edge artifact-prefix: ${{ needs.build.outputs.artifact-prefix }} diff --git a/.github/workflows/sync_docs.yaml b/.github/workflows/sync_docs.yaml index dcf53ee7c2..4e48da8e3d 100644 --- a/.github/workflows/sync_docs.yaml +++ b/.github/workflows/sync_docs.yaml @@ -10,9 +10,9 @@ on: jobs: sync-docs: name: Sync docs from Discourse - uses: canonical/data-platform-workflows/.github/workflows/sync_docs.yaml@v21.0.1 + uses: canonical/data-platform-workflows/.github/workflows/sync_docs.yaml@v22.0.0 with: - reviewers: a-velasco,izmalk + reviewers: a-velasco permissions: contents: write # Needed to push branch & tag pull-requests: write # Needed to create PR diff --git a/CONTRIBUTING.md b/CONTRIBUTING.md index d974f1ce59..30d41cfae8 100644 --- a/CONTRIBUTING.md +++ b/CONTRIBUTING.md @@ -49,7 +49,7 @@ microk8s config > ~/.kube/config Build the charm in this git repository using: ```shell -tox run -e build-dev +charmcraftcache pack ``` ### Deploy diff --git a/charmcraft.yaml b/charmcraft.yaml index d5c215aaea..38ca40857f 100644 --- a/charmcraft.yaml +++ b/charmcraft.yaml @@ -1,4 +1,4 @@ -type: "charm" +type: charm bases: - name: ubuntu channel: "22.04" @@ -8,24 +8,23 @@ bases: architectures: [arm64] parts: charm: - override-pull: | - craftctl default - if [[ ! -f requirements.txt ]] - then - echo 'ERROR: Use "tox run -e build-dev" instead of calling "charmcraft pack" directly' >&2 - exit 1 - fi - override-build: | - rustup default stable - craftctl default - charm-strict-dependencies: true build-snaps: - - rustup/latest/stable + - rustup build-packages: - libffi-dev - libssl-dev - pkg-config - libpq-dev + override-build: | + rustup default stable + + # Convert subset of poetry.lock to requirements.txt + curl -sSL https://install.python-poetry.org | python3 - + /root/.local/bin/poetry export --only main,charm-libs --output requirements.txt + + craftctl default + charm-strict-dependencies: true + charm-requirements: [requirements.txt] libpq: build-packages: - libpq-dev diff --git a/docs/how-to/h-restore-backup.md b/docs/how-to/h-restore-backup.md index e22e34e2e8..8556634144 100644 --- a/docs/how-to/h-restore-backup.md +++ b/docs/how-to/h-restore-backup.md @@ -10,12 +10,19 @@ This is a guide on how to restore a locally made backup. To restore a backup that was made from a *different* cluster, (i.e. cluster migration via restore), see [How to migrate cluster using backups](/t/charmed-postgresql-k8s-how-to-migrate-clusters/9598?channel=14/stable). - ## Prerequisites - Deployments have been [scaled-down](/t/charmed-postgresql-k8s-how-to-manage-units/9592?channel=14/stable) to a single PostgreSQL unit (scale it up after the backup is restored) - Access to S3 storage - [Configured settings for S3 storage](/t/charmed-postgresql-k8s-how-to-configure-s3/9595?channel=14/stable) - [Existing backups in your S3-storage](/t/charmed-postgresql-k8s-how-to-create-and-list-backups/9596?channel=14/stable) +- [Point-in-time recovery](#point-in-time-recovery) requires the following PostgreSQL charm revisions: + - 435+ for `arm64` + - 436+ for `amd64` + +## Summary +* [List backups](#list-backups) +* [Point-in-time recovery](#point-in-time-recovery) +* [Restore backup](#restore-backup) --- @@ -27,15 +34,46 @@ juju run postgresql-k8s/leader list-backups This should show your available backups like in the sample output below: ```shell - backups: |- - backup-id | backup-type | backup-status - ---------------------------------------------------- - YYYY-MM-DDTHH:MM:SSZ | physical | finished +list-backups: |- + Storage bucket name: canonical-postgres + Backups base path: /test/backup/ + + backup-id | action | ... | timeline + --------------------------------------------------------------------------- + 2024-07-22T13:11:56Z | full backup | ... | 1 + 2024-07-22T14:12:45Z | incremental backup | ... | 1 + 2024-07-22T15:34:24Z | restore | ... | 2 + 2024-07-22T16:26:48Z | incremental backup | ... | 2 + 2024-07-22T17:17:59Z | full | ... | 2 + 2024-07-22T18:05:32Z | restore | ... | 3 ``` + +Below is a complete list of parameters shown for each backup/restore operation: +* `backup-id`: unique identifier of the backup. +* `action`: indicates the action performed by the user through one of the charm action; can be any of full backup, incremental backup, differential backup or restore. +* `status`: either finished (successfully) or failed. +* `reference-backup-id` +* `LSN start/stop`: a database specific number (or timestamp) to identify its state. +* `start-time`: records start of the backup operation. +* `finish-time`: records end of the backup operation. +* `backup-path`: path of the backup related files in the S3 repository. +* `timeline`: number which identifies different branches in the database transactions history; every time a restore or PITR is made, this number is incremented by 1. + +## Point-in-time recovery +Point-in-time recovery (PITR) is a PostgreSQL feature that enables restorations to the database state at specific points in time. + +After performing a PITR in a PostgreSQL cluster, a new timeline is created to track from the point to where the database was restored. They can be tracked via the `timeline` parameter in the `list-backups` output. + ## Restore backup -To restore a backup from that list, run the `restore` command and pass the corresponding `backup-id`: +To restore a backup from that list, run the `restore` command and pass the parameter corresponding to the backup type. + +When the user needs to restore a specific backup that was made, they can use the `backup-id` that is listed in the `list-backups` output. ```shell juju run postgresql-k8s/leader restore backup-id=YYYY-MM-DDTHH:MM:SSZ ``` +However, if the user needs to restore to a specific point in time between different backups (e.g. to restore only specific transactions made between those backups), they can use the `restore-to-time` parameter to pass a timestamp related to the moment they want to restore. + ```shell +juju run postgresql-k8s/leader restore restore-to-time="YYYY-MM-DDTHH:MM:SSZ" +``` Your restore will then be in progress. \ No newline at end of file diff --git a/docs/overview.md b/docs/overview.md index 853c6c828b..5db79d55fd 100644 --- a/docs/overview.md +++ b/docs/overview.md @@ -90,8 +90,7 @@ PostgreSQL is a trademark or registered trademark of PostgreSQL Global Developme | 2 | h-enable-plugins-extensions | [Enable plugins/extensions](/t/10907) | | 1 | reference | [Reference]() | | 2 | r-overview | [Overview](/t/13977) | -| 2 | r-releases | [Release Notes]() | -| 3 | r-all-releases | [All releases](/t/11872) | +| 2 | r-releases | [Release Notes](/t/11872) | | 3 | r-revision-381-382 | [Revision 381/382](/t/15442) | | 3 | r-revision-280-281 | [Revision 280/281](/t/14068) | | 3 | r-revision-193 | [Revision 193](/t/13208) | diff --git a/docs/reference/r-all-releases.md b/docs/reference/r-all-releases.md deleted file mode 100644 index 12657010b8..0000000000 --- a/docs/reference/r-all-releases.md +++ /dev/null @@ -1,30 +0,0 @@ -# Release Notes - -Here you will find release notes for major revisions of this charm that are available in the [Charmhub `stable` channel](https://juju.is/docs/juju/channel#heading--risk). - -To see **all** charm revisions, check the [Charmed PostgreSQL K8s Releases page](https://github.com/canonical/postgresql-k8s-operator/releases) on GitHub. - -## At a glance - -The table below is a high-level overview of the architectures and integrations that are supported by each charm revision. - -| Revision | PostgreSQL | amd64 | arm64 | [TLS encryption](/t/9685)* | [Monitoring (COS, Grafana)](/t/10600) | [Tracing (Tempo K8s)](/t/14521) | -|:--------:|:-----:|:-----:|:-----:|:--------------------:|:---------------:|:--------------------:| -| [382](/t/15442) | 14.12 | :heavy_multiplication_x: | :white_check_mark: | :white_check_mark: | :white_check_mark: | :white_check_mark: | -| [381](/t/15442) | 14.12 | :white_check_mark: | :heavy_multiplication_x: | :white_check_mark: | :white_check_mark: | :white_check_mark: | -| [281](/t/14068) | 14.11 | :white_check_mark: | :heavy_multiplication_x: | :white_check_mark: | :white_check_mark: | :white_check_mark: | -| [280](/t/14068) | 14.11 | :heavy_multiplication_x: | :white_check_mark: | :white_check_mark: | :white_check_mark: | :white_check_mark: | -| [193](/t/13208) | 14.10 | :white_check_mark: | :heavy_multiplication_x: | :white_check_mark: | :white_check_mark: | :heavy_multiplication_x: | -| [177](/t/12668) | 14.9 | :white_check_mark: | :heavy_multiplication_x: | :heavy_multiplication_x: | :white_check_mark: | :heavy_multiplication_x: | -| [158](/t/11874) | 14.9 | :white_check_mark: | :heavy_multiplication_x: | :heavy_multiplication_x: | :white_check_mark: | :heavy_multiplication_x: | -| [73](/t/11873) | 14.7 | :white_check_mark: | :heavy_multiplication_x: | :heavy_multiplication_x: | :heavy_multiplication_x: | :heavy_multiplication_x: | - - -**TLS encryption***: Support for **`v2` or higher** of the [`tls-certificates` interface](https://charmhub.io/tls-certificates-interface/libraries/tls_certificates). This means that you can integrate with [modern TLS charms](https://charmhub.io/topics/security-with-x-509-certificates). - -For more details about a particular revision, refer to its dedicated Release Notes page. -For more details about each feature/interface, refer to their dedicated How-To guide. - -### Plugins/extensions - -For a list of all plugins supported for each revision, see the reference page [Plugins/extensions](/t/10945). \ No newline at end of file diff --git a/docs/reference/r-releases.md b/docs/reference/r-releases.md new file mode 100644 index 0000000000..95759d91d6 --- /dev/null +++ b/docs/reference/r-releases.md @@ -0,0 +1,65 @@ +# Release Notes + +This page provides high-level overviews of the dependencies and features that are supported by each revision in every stable release. + +To learn more about the different release tracks and channels, see the [Juju documentation about channels](https://juju.is/docs/juju/channel#heading--risk). + +To see all releases and commits, check the [Charmed PostgreSQL Releases page on GitHub](https://github.com/canonical/postgresql-k8s-operator/releases). + +## Dependencies and supported features + +For a given release, this table shows: +* The PostgreSQL version packaged inside +* The minimum Juju version required to reliably operate **all** features of the release + > This charm still supports older versions of Juju down to 2.9. See the [Juju section of the system requirements](/t/) for more details +* Support for specific features + +| Revision | PostgreSQL version | Juju version | [TLS encryption](/t/9685)* | [COS monitoring](/t/10600) | [Minor version upgrades](/t/) | [Cross-regional async replication](/t/) | [Point-in-time recovery](/t/) +|:---:|:---:|:---:|:---:|:---:|:---:|:---:|:---:| +| [381], [382] | 14.12 | `3.4.5+` | ![check] | ![check] | ![check] | ![check] | ![check] | +| [280], [281] | 14.11 | `3.1.8+` | ![check] | ![check] | ![check] | ![check] | +| [193] | 14.10 | `3.1.7+` | ![check] | ![check] | ![check] | ![check] | +| [177] | 14.9 | `3.1.6+` | | ![check] | ![check] | +| [158] | 14.9 | `3.1.5+` | | ![check] | ![check] | +| [73] | 14.7 | `2.9.32+` | | | + + +**TLS encryption***: Support for **`v2` or higher** of the [`tls-certificates` interface](https://charmhub.io/tls-certificates-interface/libraries/tls_certificates). This means that you can integrate with [modern TLS charms](https://charmhub.io/topics/security-with-x-509-certificates). + +For more details about a particular revision, refer to its dedicated Release Notes page. +For more details about each feature/interface, refer to their dedicated How-To guide. + +## Architecture and base +One release may come with more than one revision. This is because each revision is built for a specific combination of hardware architecture and base (Ubuntu version). + +| Release | amd64 | arm64 | Ubuntu 22.04 LTS +|:--------:|:-----:|:-----:|:-----:| +|[382] | | ![check] | ![check] | +|[381] | ![check] | | ![check] | +|[281] |![check]| | ![check] | +|[280] | | ![check]| ![check] | +|[193] | ![check]| | ![check] | +|[177] |![check]| | ![check] | +|[158] |![check]| | ![check] | +|[73] |![check]| | ![check] | + +## Plugins/extensions + +For a list of all plugins supported for each revision, see the reference page [Plugins/extensions](/t/10945). + +[note] + Our release notes are an ongoing work in progress. If there is any additional information about releases that you would like to see or suggestions for other improvements, don't hesitate to contact us on [Matrix ](https://matrix.to/#/#charmhub-data-platform:ubuntu.com) or [leave a comment](https://discourse.charmhub.io/t/charmed-postgresql-reference-release-notes/11875). +[/note] + + +[382]: /t/15442 +[381]: /t/15442 +[281]: /t/14068 +[280]: /t/14068 +[193]: /t/13208 +[177]: /t/12668 +[158]: /t/11874 +[73]: /t/11873 + + +[check]: https://img.icons8.com/color/20/checkmark--v1.png \ No newline at end of file diff --git a/docs/reference/r-revision-381-382.md b/docs/reference/r-revision-381-382.md index 3e59304da9..5b8d325f04 100644 --- a/docs/reference/r-revision-381-382.md +++ b/docs/reference/r-revision-381-382.md @@ -11,7 +11,6 @@ Due to the newly added support for `arm64` architecture, the PostgreSQL K8s char * Revision 381 is built for `amd64` on Ubuntu 22.04 LTS * Revision 382 is built for `arm64` on Ubuntu 22.04 LTS - To make sure you deploy for the right architecture, we recommend setting an [architecture constraint](https://juju.is/docs/juju/constraint#heading--arch) for your entire juju model. Otherwise, it can be done at deploy time with the `--constraints` flag: @@ -74,20 +73,44 @@ where `` can be `amd64` or `arm64`. If you are jumping over several stable revisions, check [previous release notes][All revisions] before upgrading. +## Requirements and compatibility +This charm revision features the following changes in dependencies: +* (increased) The minimum Juju version required to reliably operate **all** features of the release is `v3.4.5` + > You can upgrade to this revision on Juju `v2.9.50+`, but it will not support newer features like cross-regional asynchronous replication, point-in-time recovery, and modern TLS certificate charm integrations. +* (increased) PostgreSQL version 14.12 + See the [system requirements] for more details about Juju versions and other software and hardware prerequisites. -## Dependencies -This revision was explicitly tested with the following dependencies: -* `microk8s v.1.31` - Channel `strict/stable` -* `data-integrator` - Revision 41 -* `indico` - Revision 213 -* `discourse-k8s` - Revision 124 -* `postgresql-test-app` - Revision 239 -* `s3-integrator` - Revision 31 +### Integration tests +Below are the charm integrations tested with this revision on different Juju environments and architectures: * Juju `v.2.9.50` on `amd64` - * `tls-certificates-operator` - Channel `legacy/stable`, Revision 22 -* Juju `v.3.4.5` on `amd64` and `arm64` - * `self-signed-certificates` - Channel `latest/stable`, Revision 155 +* Juju `v.3.4.5` on `amd64` and `arm64` + +#### Juju `v.2.9.50` on `amd64` + +| Software | Version | +|-----|-----| +| [tls-certificates-operator] | `rev 22`, `legacy/stable` | + +#### Juju `v.3.4.5` on `amd64` and `arm64` + +| Software | Version | +|-----|-----| +| [self-signed-certificates] | `rev 155`, `latest/stable` | + +#### All +| Software | Version | +|-----|-----| +| [microk8s] | `v.1.31`, `strict/stable` | +| [indico] | `rev 213` | +| [discourse-k8s] | `rev 124` | +| [data-integrator] | `rev 41` | +| [s3-integrator] | `rev 31` | +| [postgresql-test-app] | `rev 239` | + +See the [`/lib/charms` directory on GitHub] for more details about all supported libraries. + +See the [`metadata.yaml` file on GitHub] for a full list of supported interfaces. ## Packaging @@ -98,12 +121,8 @@ This charm is based on the Charmed PostgreSQL K8s [rock image]. It packages: * [pgBackRest `v.2.48`] * [prometheus-postgres-exporter `v.0.12.1`] -See the [`/lib/charms` directory on GitHub] for more details about all supported libraries.
-See the [`metadata.yaml` file on GitHub] for a full list of supported interfaces. - ## Dependencies and automations - -This section contains some technical details about the charm's contents and dependencies. +[details=This section contains a list of updates to libs, dependencies, actions, and workflows.] * Updated canonical/charming-actions action to v2.6.3 ([PR #673](https://github.com/canonical/postgresql-k8s-operator/pull/673)) * Updated data-platform-workflows to v21.0.1 ([PR #660](https://github.com/canonical/postgresql-k8s-operator/pull/660)) @@ -120,21 +139,21 @@ This section contains some technical details about the charm's contents and depe * Updated postgresql lib ([PR #546](https://github.com/canonical/postgresql-k8s-operator/pull/546)) * Bumped coverage ([PR #623](https://github.com/canonical/postgresql-k8s-operator/pull/623)) * Test service patch lib update ([PR #624](https://github.com/canonical/postgresql-k8s-operator/pull/624)) +[/details] - + [All revisions]: /t/11872 [system requirements]: /t/11744 - + [`/lib/charms` directory on GitHub]: https://github.com/canonical/postgresql-k8s-operator/tree/main/lib/charms [`metadata.yaml` file on GitHub]: https://github.com/canonical/postgresql-k8s-operator/blob/main/metadata.yaml - + [14/stable channel]: https://charmhub.io/postgresql?channel=14/stable - + [`charmed-postgresql` packaging]: https://github.com/canonical/charmed-postgresql-rock - [rock image]: ghcr.io/canonical/charmed-postgresql@sha256:7ef86a352c94e2a664f621a1cc683d7a983fd86e923d98c32b863f717cb1c173 [postgresql `v.14.12`]: https://launchpad.net/ubuntu/+source/postgresql-14/14.12-0ubuntu0.22.04.1 @@ -143,7 +162,20 @@ This section contains some technical details about the charm's contents and depe [pgBackRest `v.2.48`]: https://launchpad.net/~data-platform/+archive/ubuntu/pgbackrest [prometheus-postgres-exporter `v.0.12.1`]: https://launchpad.net/~data-platform/+archive/ubuntu/postgres-exporter - - + +[juju]: https://juju.is/docs/juju/ +[lxd]: https://documentation.ubuntu.com/lxd/en/latest/ +[nextcloud]: https://charmhub.io/nextcloud +[mailman3-core]: https://charmhub.io/mailman3-core +[data-integrator]: https://charmhub.io/data-integrator +[s3-integrator]: https://charmhub.io/s3-integrator +[postgresql-test-app]: https://charmhub.io/postgresql-test-app +[discourse-k8s]: https://charmhub.io/discourse-k8s +[indico]: https://charmhub.io/indico +[microk8s]: https://charmhub.io/microk8s +[tls-certificates-operator]: https://charmhub.io/tls-certificates-operator +[self-signed-certificates]: https://charmhub.io/self-signed-certificates + + [amd64]: https://img.shields.io/badge/amd64-darkgreen [arm64]: https://img.shields.io/badge/arm64-blue \ No newline at end of file diff --git a/poetry.lock b/poetry.lock index d66c68e287..95c5e23923 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 = "v21.0.1" -resolved_reference = "06f252ea079edfd055cee236ede28c237467f9b0" +reference = "v22.0.0" +resolved_reference = "da2da4b1e4469b5ed8f9187981fe2d747f8ee129" subdirectory = "python/pytest_plugins/allure_pytest_collection_report" [[package]] @@ -162,17 +162,17 @@ typecheck = ["mypy"] [[package]] name = "boto3" -version = "1.35.24" +version = "1.35.31" description = "The AWS SDK for Python" optional = false python-versions = ">=3.8" files = [ - {file = "boto3-1.35.24-py3-none-any.whl", hash = "sha256:97fcc1a14cbc759e4ba9535ced703a99fcf652c9c4b8dfcd06f292c80551684b"}, - {file = "boto3-1.35.24.tar.gz", hash = "sha256:be7807f30f26d6c0057e45cfd09dad5968e664488bf4f9138d0bb7a0f6d8ed40"}, + {file = "boto3-1.35.31-py3-none-any.whl", hash = "sha256:2e9af74d10d8af7610a8d8468d2914961f116912a024fce17351825260385a52"}, + {file = "boto3-1.35.31.tar.gz", hash = "sha256:8c593af260c4ea3eb6f079c09908f94494ca2222aa4e40a7ff490fab1cee8b39"}, ] [package.dependencies] -botocore = ">=1.35.24,<1.36.0" +botocore = ">=1.35.31,<1.36.0" jmespath = ">=0.7.1,<2.0.0" s3transfer = ">=0.10.0,<0.11.0" @@ -181,13 +181,13 @@ crt = ["botocore[crt] (>=1.21.0,<2.0a0)"] [[package]] name = "botocore" -version = "1.35.24" +version = "1.35.31" description = "Low-level, data-driven core of boto 3." optional = false python-versions = ">=3.8" files = [ - {file = "botocore-1.35.24-py3-none-any.whl", hash = "sha256:eb9ccc068255cc3d24c36693fda6aec7786db05ae6c2b13bcba66dce6a13e2e3"}, - {file = "botocore-1.35.24.tar.gz", hash = "sha256:1e59b0f14f4890c4f70bd6a58a634b9464bed1c4c6171f87c8795d974ade614b"}, + {file = "botocore-1.35.31-py3-none-any.whl", hash = "sha256:4cee814875bc78656aef4011d3d6b2231e96f53ea3661ee428201afb579d5c31"}, + {file = "botocore-1.35.31.tar.gz", hash = "sha256:f7bfa910cf2cbcc8c2307c1cf7b93495d614c2d699883417893e0a337fe4eb63"}, ] [package.dependencies] @@ -428,13 +428,13 @@ files = [ [[package]] name = "cosl" -version = "0.0.34" +version = "0.0.36" description = "Utils for COS Lite charms" optional = false python-versions = ">=3.8" files = [ - {file = "cosl-0.0.34-py3-none-any.whl", hash = "sha256:f083ddb7f0a2d008bbc9a58a783e5df497e81e628861e4fd161cb5b83bccc0d7"}, - {file = "cosl-0.0.34.tar.gz", hash = "sha256:2faf097ecfc77fa58c95c91ddb7076813c608d6b32e2a8ce4ecf41b8bcd56e06"}, + {file = "cosl-0.0.36-py3-none-any.whl", hash = "sha256:14798e01827a93d830fe4e4254e5f8838a4a7e0c83f861c94c06754c198c2a1d"}, + {file = "cosl-0.0.36.tar.gz", hash = "sha256:4c986b0fce7d905609ba89a557791b00d8a4708c46f805d3a6c3cc593f47fae6"}, ] [package.dependencies] @@ -611,12 +611,12 @@ dev = ["PyTest", "PyTest-Cov", "bump2version (<1)", "sphinx (<2)", "tox"] [[package]] name = "durationpy" -version = "0.7" +version = "0.8" description = "Module for converting between datetime.timedelta and Go's Duration strings." optional = false python-versions = "*" files = [ - {file = "durationpy-0.7.tar.gz", hash = "sha256:8447c43df4f1a0b434e70c15a38d77f5c9bd17284bfc1ff1d430f233d5083732"}, + {file = "durationpy-0.8.tar.gz", hash = "sha256:e90941562e260bdb0e2244cd9eee9be5b3aa0efc0557fca754f36d18fe080f9d"}, ] [[package]] @@ -700,13 +700,13 @@ files = [ [[package]] name = "httpcore" -version = "1.0.5" +version = "1.0.6" description = "A minimal low-level HTTP client." optional = false python-versions = ">=3.8" files = [ - {file = "httpcore-1.0.5-py3-none-any.whl", hash = "sha256:421f18bac248b25d310f3cacd198d55b8e6125c107797b609ff9b7a6ba7991b5"}, - {file = "httpcore-1.0.5.tar.gz", hash = "sha256:34a38e2f9291467ee3b44e89dd52615370e152954ba21721378a87b2960f7a61"}, + {file = "httpcore-1.0.6-py3-none-any.whl", hash = "sha256:27b59625743b85577a8c0e10e55b50b5368a4f2cfe8cc7bcfa9cf00829c2682f"}, + {file = "httpcore-1.0.6.tar.gz", hash = "sha256:73f6dbd6eb8c21bbf7ef8efad555481853f5f6acdeaff1edb0694289269ee17f"}, ] [package.dependencies] @@ -717,7 +717,7 @@ h11 = ">=0.13,<0.15" asyncio = ["anyio (>=4.0,<5.0)"] http2 = ["h2 (>=3,<5)"] socks = ["socksio (==1.*)"] -trio = ["trio (>=0.22.0,<0.26.0)"] +trio = ["trio (>=0.22.0,<1.0)"] [[package]] name = "httpx" @@ -1378,13 +1378,13 @@ files = [ [[package]] name = "prompt-toolkit" -version = "3.0.47" +version = "3.0.48" description = "Library for building powerful interactive command lines in Python" optional = false python-versions = ">=3.7.0" files = [ - {file = "prompt_toolkit-3.0.47-py3-none-any.whl", hash = "sha256:0d7bfa67001d5e39d02c224b663abc33687405033a8c422d0d675a5a13361d10"}, - {file = "prompt_toolkit-3.0.47.tar.gz", hash = "sha256:1e1b29cb58080b1e69f207c893a1a7bf16d127a5c30c9d17a25a5d77792e5360"}, + {file = "prompt_toolkit-3.0.48-py3-none-any.whl", hash = "sha256:f49a827f90062e411f1ce1f854f2aedb3c23353244f8108b89283587397ac10e"}, + {file = "prompt_toolkit-3.0.48.tar.gz", hash = "sha256:d6623ab0477a80df74e646bdbc93621143f5caf104206aa29294d53de1a03d90"}, ] [package.dependencies] @@ -1754,8 +1754,8 @@ develop = false [package.source] type = "git" url = "https://github.com/canonical/data-platform-workflows" -reference = "v21.0.1" -resolved_reference = "06f252ea079edfd055cee236ede28c237467f9b0" +reference = "v22.0.0" +resolved_reference = "da2da4b1e4469b5ed8f9187981fe2d747f8ee129" subdirectory = "python/pytest_plugins/github_secrets" [[package]] @@ -1777,13 +1777,13 @@ dev = ["pre-commit", "pytest-asyncio", "tox"] [[package]] name = "pytest-operator" -version = "0.36.0" +version = "0.37.0" description = "Fixtures for Operators" optional = false python-versions = "*" files = [ - {file = "pytest_operator-0.36.0-py3-none-any.whl", hash = "sha256:edab65d9d80b19fc85acddeda4a1fd3bb55a781f43ffbb6e9c4002aeeada6ad2"}, - {file = "pytest_operator-0.36.0.tar.gz", hash = "sha256:041eeabd4c9590614f78b7568c74b0d42f768815a6b5c183da8ccfc23345bea9"}, + {file = "pytest_operator-0.37.0-py3-none-any.whl", hash = "sha256:da5f6f527115c70676c29a0f5422551b066f9693ff3cbcf968b6b1cd93eaf33c"}, + {file = "pytest_operator-0.37.0.tar.gz", hash = "sha256:9c03202c31e8434ac3fee21b955b32f64c7b9b440ab7bb4b2a51321cb23489da"}, ] [package.dependencies] @@ -1809,8 +1809,8 @@ pyyaml = "*" [package.source] type = "git" url = "https://github.com/canonical/data-platform-workflows" -reference = "v21.0.1" -resolved_reference = "06f252ea079edfd055cee236ede28c237467f9b0" +reference = "v22.0.0" +resolved_reference = "da2da4b1e4469b5ed8f9187981fe2d747f8ee129" subdirectory = "python/pytest_plugins/pytest_operator_cache" [[package]] @@ -1828,8 +1828,8 @@ pytest = "*" [package.source] type = "git" url = "https://github.com/canonical/data-platform-workflows" -reference = "v21.0.1" -resolved_reference = "06f252ea079edfd055cee236ede28c237467f9b0" +reference = "v22.0.0" +resolved_reference = "da2da4b1e4469b5ed8f9187981fe2d747f8ee129" subdirectory = "python/pytest_plugins/pytest_operator_groups" [[package]] @@ -2101,29 +2101,29 @@ pyasn1 = ">=0.1.3" [[package]] name = "ruff" -version = "0.6.7" +version = "0.6.8" description = "An extremely fast Python linter and code formatter, written in Rust." optional = false python-versions = ">=3.7" files = [ - {file = "ruff-0.6.7-py3-none-linux_armv6l.whl", hash = "sha256:08277b217534bfdcc2e1377f7f933e1c7957453e8a79764d004e44c40db923f2"}, - {file = "ruff-0.6.7-py3-none-macosx_10_12_x86_64.whl", hash = "sha256:c6707a32e03b791f4448dc0dce24b636cbcdee4dd5607adc24e5ee73fd86c00a"}, - {file = "ruff-0.6.7-py3-none-macosx_11_0_arm64.whl", hash = "sha256:533d66b7774ef224e7cf91506a7dafcc9e8ec7c059263ec46629e54e7b1f90ab"}, - {file = "ruff-0.6.7-py3-none-manylinux_2_17_aarch64.manylinux2014_aarch64.whl", hash = "sha256:17a86aac6f915932d259f7bec79173e356165518859f94649d8c50b81ff087e9"}, - {file = "ruff-0.6.7-py3-none-manylinux_2_17_armv7l.manylinux2014_armv7l.whl", hash = "sha256:b3f8822defd260ae2460ea3832b24d37d203c3577f48b055590a426a722d50ef"}, - {file = "ruff-0.6.7-py3-none-manylinux_2_17_i686.manylinux2014_i686.whl", hash = "sha256:9ba4efe5c6dbbb58be58dd83feedb83b5e95c00091bf09987b4baf510fee5c99"}, - {file = "ruff-0.6.7-py3-none-manylinux_2_17_ppc64.manylinux2014_ppc64.whl", hash = "sha256:525201b77f94d2b54868f0cbe5edc018e64c22563da6c5c2e5c107a4e85c1c0d"}, - {file = "ruff-0.6.7-py3-none-manylinux_2_17_ppc64le.manylinux2014_ppc64le.whl", hash = "sha256:8854450839f339e1049fdbe15d875384242b8e85d5c6947bb2faad33c651020b"}, - {file = "ruff-0.6.7-py3-none-manylinux_2_17_s390x.manylinux2014_s390x.whl", hash = "sha256:2f0b62056246234d59cbf2ea66e84812dc9ec4540518e37553513392c171cb18"}, - {file = "ruff-0.6.7-py3-none-manylinux_2_17_x86_64.manylinux2014_x86_64.whl", hash = "sha256:6b1462fa56c832dc0cea5b4041cfc9c97813505d11cce74ebc6d1aae068de36b"}, - {file = "ruff-0.6.7-py3-none-musllinux_1_2_aarch64.whl", hash = "sha256:02b083770e4cdb1495ed313f5694c62808e71764ec6ee5db84eedd82fd32d8f5"}, - {file = "ruff-0.6.7-py3-none-musllinux_1_2_armv7l.whl", hash = "sha256:0c05fd37013de36dfa883a3854fae57b3113aaa8abf5dea79202675991d48624"}, - {file = "ruff-0.6.7-py3-none-musllinux_1_2_i686.whl", hash = "sha256:f49c9caa28d9bbfac4a637ae10327b3db00f47d038f3fbb2195c4d682e925b14"}, - {file = "ruff-0.6.7-py3-none-musllinux_1_2_x86_64.whl", hash = "sha256:a0e1655868164e114ba43a908fd2d64a271a23660195017c17691fb6355d59bb"}, - {file = "ruff-0.6.7-py3-none-win32.whl", hash = "sha256:a939ca435b49f6966a7dd64b765c9df16f1faed0ca3b6f16acdf7731969deb35"}, - {file = "ruff-0.6.7-py3-none-win_amd64.whl", hash = "sha256:590445eec5653f36248584579c06252ad2e110a5d1f32db5420de35fb0e1c977"}, - {file = "ruff-0.6.7-py3-none-win_arm64.whl", hash = "sha256:b28f0d5e2f771c1fe3c7a45d3f53916fc74a480698c4b5731f0bea61e52137c8"}, - {file = "ruff-0.6.7.tar.gz", hash = "sha256:44e52129d82266fa59b587e2cd74def5637b730a69c4542525dfdecfaae38bd5"}, + {file = "ruff-0.6.8-py3-none-linux_armv6l.whl", hash = "sha256:77944bca110ff0a43b768f05a529fecd0706aac7bcce36d7f1eeb4cbfca5f0f2"}, + {file = "ruff-0.6.8-py3-none-macosx_10_12_x86_64.whl", hash = "sha256:27b87e1801e786cd6ede4ada3faa5e254ce774de835e6723fd94551464c56b8c"}, + {file = "ruff-0.6.8-py3-none-macosx_11_0_arm64.whl", hash = "sha256:cd48f945da2a6334f1793d7f701725a76ba93bf3d73c36f6b21fb04d5338dcf5"}, + {file = "ruff-0.6.8-py3-none-manylinux_2_17_aarch64.manylinux2014_aarch64.whl", hash = "sha256:677e03c00f37c66cea033274295a983c7c546edea5043d0c798833adf4cf4c6f"}, + {file = "ruff-0.6.8-py3-none-manylinux_2_17_armv7l.manylinux2014_armv7l.whl", hash = "sha256:9f1476236b3eacfacfc0f66aa9e6cd39f2a624cb73ea99189556015f27c0bdeb"}, + {file = "ruff-0.6.8-py3-none-manylinux_2_17_i686.manylinux2014_i686.whl", hash = "sha256:6f5a2f17c7d32991169195d52a04c95b256378bbf0de8cb98478351eb70d526f"}, + {file = "ruff-0.6.8-py3-none-manylinux_2_17_ppc64.manylinux2014_ppc64.whl", hash = "sha256:5fd0d4b7b1457c49e435ee1e437900ced9b35cb8dc5178921dfb7d98d65a08d0"}, + {file = "ruff-0.6.8-py3-none-manylinux_2_17_ppc64le.manylinux2014_ppc64le.whl", hash = "sha256:f8034b19b993e9601f2ddf2c517451e17a6ab5cdb1c13fdff50c1442a7171d87"}, + {file = "ruff-0.6.8-py3-none-manylinux_2_17_s390x.manylinux2014_s390x.whl", hash = "sha256:6cfb227b932ba8ef6e56c9f875d987973cd5e35bc5d05f5abf045af78ad8e098"}, + {file = "ruff-0.6.8-py3-none-manylinux_2_17_x86_64.manylinux2014_x86_64.whl", hash = "sha256:6ef0411eccfc3909269fed47c61ffebdcb84a04504bafa6b6df9b85c27e813b0"}, + {file = "ruff-0.6.8-py3-none-musllinux_1_2_aarch64.whl", hash = "sha256:007dee844738c3d2e6c24ab5bc7d43c99ba3e1943bd2d95d598582e9c1b27750"}, + {file = "ruff-0.6.8-py3-none-musllinux_1_2_armv7l.whl", hash = "sha256:ce60058d3cdd8490e5e5471ef086b3f1e90ab872b548814e35930e21d848c9ce"}, + {file = "ruff-0.6.8-py3-none-musllinux_1_2_i686.whl", hash = "sha256:1085c455d1b3fdb8021ad534379c60353b81ba079712bce7a900e834859182fa"}, + {file = "ruff-0.6.8-py3-none-musllinux_1_2_x86_64.whl", hash = "sha256:70edf6a93b19481affd287d696d9e311388d808671bc209fb8907b46a8c3af44"}, + {file = "ruff-0.6.8-py3-none-win32.whl", hash = "sha256:792213f7be25316f9b46b854df80a77e0da87ec66691e8f012f887b4a671ab5a"}, + {file = "ruff-0.6.8-py3-none-win_amd64.whl", hash = "sha256:ec0517dc0f37cad14a5319ba7bba6e7e339d03fbf967a6d69b0907d61be7a263"}, + {file = "ruff-0.6.8-py3-none-win_arm64.whl", hash = "sha256:8d3bb2e3fbb9875172119021a13eed38849e762499e3cfde9588e4b4d70968dc"}, + {file = "ruff-0.6.8.tar.gz", hash = "sha256:a5bf44b1aa0adaf6d9d20f86162b34f7c593bfedabc51239953e446aefc8ce18"}, ] [[package]] @@ -2502,4 +2502,4 @@ type = ["pytest-mypy"] [metadata] lock-version = "2.0" python-versions = "^3.10" -content-hash = "b8042c33a97d0fb9dfc1235b88833494091686331e032ce0518e0f61da51b5be" +content-hash = "7b5a756349eddc9ff9c848cae57703eb57f9918f24eb04af560ed61b369578c0" diff --git a/pyproject.toml b/pyproject.toml index 54a784f11e..b98916a659 100644 --- a/pyproject.toml +++ b/pyproject.toml @@ -8,11 +8,11 @@ package-mode = false python = "^3.10" ops = "^2.17.0" cryptography = "^43.0.1" -boto3 = "^1.35.24" +boto3 = "^1.35.31" pgconnstr = "^1.0.1" requests = "^2.32.3" tenacity = "^9.0.0" -cosl = "^0.0.34" +cosl = "^0.0.36" pydantic = "^1.10.18" poetry-core = "^1.9.0" jsonschema = "^4.23.0" @@ -39,7 +39,7 @@ opentelemetry-exporter-otlp-proto-http = "1.21.0" optional = true [tool.poetry.group.format.dependencies] -ruff = "^0.6.7" +ruff = "^0.6.8" [tool.poetry.group.lint] optional = true @@ -64,15 +64,15 @@ optional = true [tool.poetry.group.integration.dependencies] lightkube = "^0.15.4" pytest = "^8.3.3" -pytest-github-secrets = {git = "https://github.com/canonical/data-platform-workflows", tag = "v21.0.1", subdirectory = "python/pytest_plugins/github_secrets"} -pytest-operator = "^0.36.0" -pytest-operator-cache = {git = "https://github.com/canonical/data-platform-workflows", tag = "v21.0.1", subdirectory = "python/pytest_plugins/pytest_operator_cache"} -pytest-operator-groups = {git = "https://github.com/canonical/data-platform-workflows", tag = "v21.0.1", subdirectory = "python/pytest_plugins/pytest_operator_groups"} -allure-pytest-collection-report = {git = "https://github.com/canonical/data-platform-workflows", tag = "v21.0.1", subdirectory = "python/pytest_plugins/allure_pytest_collection_report"} +pytest-github-secrets = {git = "https://github.com/canonical/data-platform-workflows", tag = "v22.0.0", subdirectory = "python/pytest_plugins/github_secrets"} +pytest-operator = "^0.37.0" +pytest-operator-cache = {git = "https://github.com/canonical/data-platform-workflows", tag = "v22.0.0", subdirectory = "python/pytest_plugins/pytest_operator_cache"} +pytest-operator-groups = {git = "https://github.com/canonical/data-platform-workflows", tag = "v22.0.0", subdirectory = "python/pytest_plugins/pytest_operator_groups"} +allure-pytest-collection-report = {git = "https://github.com/canonical/data-platform-workflows", tag = "v22.0.0", subdirectory = "python/pytest_plugins/allure_pytest_collection_report"} # renovate caret doesn't work: https://github.com/renovatebot/renovate/issues/26940 juju = "<=3.5.2.0" psycopg2-binary = "^2.9.9" -boto3 = "^1.35.24" +boto3 = "^1.35.31" tenacity = "^9.0.0" allure-pytest = "^2.13.5" diff --git a/tests/integration/ha_tests/test_self_healing.py b/tests/integration/ha_tests/test_self_healing.py index 4fae6c3e9c..5610ab0f91 100644 --- a/tests/integration/ha_tests/test_self_healing.py +++ b/tests/integration/ha_tests/test_self_healing.py @@ -52,7 +52,7 @@ MEDIAN_ELECTION_TIME = 10 -@pytest.mark.group(1) +@pytest.mark.group("ha_tests") @pytest.mark.abort_on_fail async def test_build_and_deploy(ops_test: OpsTest) -> None: """Build and deploy three unit of PostgreSQL.""" @@ -78,7 +78,7 @@ async def test_build_and_deploy(ops_test: OpsTest) -> None: await ops_test.model.wait_for_idle(status="active", timeout=1000, raise_on_error=False) -@pytest.mark.group(1) +@pytest.mark.group("ha_tests") @pytest.mark.parametrize("process", DB_PROCESSES) @pytest.mark.parametrize("signal", ["SIGTERM", pytest.param("SIGKILL", marks=markers.juju2)]) async def test_interruption_db_process( @@ -113,7 +113,7 @@ async def test_interruption_db_process( await is_cluster_updated(ops_test, primary_name) -@pytest.mark.group(1) +@pytest.mark.group("ha_tests") @pytest.mark.parametrize("process", DB_PROCESSES) async def test_freeze_db_process( ops_test: OpsTest, process: str, continuous_writes, primary_start_timeout @@ -156,7 +156,7 @@ async def test_freeze_db_process( await is_cluster_updated(ops_test, primary_name) -@pytest.mark.group(1) +@pytest.mark.group("ha_tests") @pytest.mark.unstable @pytest.mark.parametrize("process", DB_PROCESSES) @pytest.mark.parametrize("signal", ["SIGTERM", "SIGKILL"]) @@ -222,7 +222,7 @@ async def test_full_cluster_restart( await check_writes(ops_test) -@pytest.mark.group(1) +@pytest.mark.group("ha_tests") async def test_forceful_restart_without_data_and_transaction_logs( ops_test: OpsTest, continuous_writes, @@ -309,7 +309,7 @@ async def test_forceful_restart_without_data_and_transaction_logs( await is_cluster_updated(ops_test, primary_name) -@pytest.mark.group(1) +@pytest.mark.group("ha_tests") @markers.amd64_only async def test_network_cut( ops_test: OpsTest, continuous_writes, primary_start_timeout, chaos_mesh @@ -374,7 +374,7 @@ async def test_network_cut( await is_cluster_updated(ops_test, primary_name) -@pytest.mark.group(2) +@pytest.mark.group("scaling_to_zero") async def test_scaling_to_zero(ops_test: OpsTest, continuous_writes) -> None: """Scale the database to zero units and scale up again.""" # Deploy applications diff --git a/tests/integration/test_backups.py b/tests/integration/test_backups.py index a896212c98..47c6e4d426 100644 --- a/tests/integration/test_backups.py +++ b/tests/integration/test_backups.py @@ -101,7 +101,7 @@ async def cloud_configs(ops_test: OpsTest, github_secrets) -> None: bucket_object.delete() -@pytest.mark.group(1) +@pytest.mark.group("AWS") @pytest.mark.abort_on_fail async def test_backup_aws(ops_test: OpsTest, cloud_configs: Tuple[Dict, Dict]) -> None: """Build and deploy two units of PostgreSQL in AWS and then test the backup and restore actions.""" @@ -205,7 +205,7 @@ async def test_backup_aws(ops_test: OpsTest, cloud_configs: Tuple[Dict, Dict]) - ) -@pytest.mark.group(2) +@pytest.mark.group("GCP") @pytest.mark.abort_on_fail async def test_backup_gcp(ops_test: OpsTest, cloud_configs: Tuple[Dict, Dict]) -> None: """Build and deploy two units of PostgreSQL in GCP and then test the backup and restore actions.""" @@ -236,7 +236,7 @@ async def test_backup_gcp(ops_test: OpsTest, cloud_configs: Tuple[Dict, Dict]) - ) -@pytest.mark.group(2) +@pytest.mark.group("GCP") async def test_restore_on_new_cluster(ops_test: OpsTest, github_secrets) -> None: """Test that is possible to restore a backup to another PostgreSQL cluster.""" previous_database_app_name = f"{DATABASE_APP_NAME}-gcp" @@ -327,7 +327,7 @@ async def test_restore_on_new_cluster(ops_test: OpsTest, github_secrets) -> None connection.close() -@pytest.mark.group(2) +@pytest.mark.group("GCP") async def test_invalid_config_and_recovery_after_fixing_it( ops_test: OpsTest, cloud_configs: Tuple[Dict, Dict] ) -> None: @@ -388,7 +388,7 @@ async def test_invalid_config_and_recovery_after_fixing_it( ) -@pytest.mark.group(2) +@pytest.mark.group("GCP") async def test_delete_pod(ops_test: OpsTest, github_secrets) -> None: logger.info("Getting original backup config") database_app_name = f"new-{DATABASE_APP_NAME}" diff --git a/tests/integration/test_backups_pitr.py b/tests/integration/test_backups_pitr.py index ade01f18ef..61e71cc97a 100644 --- a/tests/integration/test_backups_pitr.py +++ b/tests/integration/test_backups_pitr.py @@ -296,7 +296,7 @@ async def pitr_backup_operations( ) -@pytest.mark.group(1) +@pytest.mark.group("AWS") @pytest.mark.abort_on_fail async def test_pitr_backup_aws(ops_test: OpsTest, cloud_configs: Tuple[Dict, Dict]) -> None: """Build and deploy two units of PostgreSQL in AWS and then test PITR backup and restore actions.""" @@ -316,7 +316,7 @@ async def test_pitr_backup_aws(ops_test: OpsTest, cloud_configs: Tuple[Dict, Dic ) -@pytest.mark.group(2) +@pytest.mark.group("GCP") @pytest.mark.abort_on_fail async def test_pitr_backup_gcp(ops_test: OpsTest, cloud_configs: Tuple[Dict, Dict]) -> None: """Build and deploy two units of PostgreSQL in GCP and then test PITR backup and restore actions.""" diff --git a/tests/integration/test_tls.py b/tests/integration/test_tls.py index aefa33b220..c7e54642b4 100644 --- a/tests/integration/test_tls.py +++ b/tests/integration/test_tls.py @@ -192,7 +192,12 @@ async def test_mattermost_db(ops_test: OpsTest) -> None: async with ops_test.fast_forward(): # Deploy and check Mattermost user and database existence. relation_id = await deploy_and_relate_application_with_postgresql( - ops_test, "mattermost-k8s", MATTERMOST_APP_NAME, APPLICATION_UNITS, status="waiting", base="ubuntu@20.04" + ops_test, + "mattermost-k8s", + MATTERMOST_APP_NAME, + APPLICATION_UNITS, + status="waiting", + base="ubuntu@20.04", ) await check_database_creation(ops_test, "mattermost") diff --git a/tox.ini b/tox.ini index 5ea93b8562..caa8806442 100644 --- a/tox.ini +++ b/tox.ini @@ -18,24 +18,6 @@ set_env = allowlist_externals = poetry -[testenv:build-{production,dev,wrapper}] -# Wrap `charmcraft pack` -pass_env = - CI - GH_TOKEN -allowlist_externals = - {[testenv]allowlist_externals} - charmcraft - charmcraftcache - mv -commands_pre = - poetry export --only main,charm-libs --output requirements.txt -commands = - build-production: charmcraft pack {posargs} - build-dev: charmcraftcache pack {posargs} -commands_post = - mv requirements.txt requirements-last-build.txt - [testenv:format] description = Apply coding style standards to code commands_pre = @@ -81,12 +63,7 @@ pass_env = CI GITHUB_OUTPUT SECRETS_FROM_GITHUB -allowlist_externals = - {[testenv:build-wrapper]allowlist_externals} commands_pre = poetry install --only integration --no-root - {[testenv:build-wrapper]commands_pre} commands = poetry run pytest -v --tb native --log-cli-level=INFO -s --ignore={[vars]tests_path}/unit/ {posargs} -commands_post = - {[testenv:build-wrapper]commands_post}