[DPE-5371]: Storage reuse on a different cluster #2287
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
# Copyright 2023 Canonical Ltd. | |
# See LICENSE file for licensing details. | |
name: Tests | |
concurrency: | |
group: "${{ github.workflow }}-${{ github.ref }}" | |
cancel-in-progress: true | |
on: | |
pull_request: | |
schedule: | |
- cron: "53 0 * * *" # Daily at 00:53 UTC | |
# Triggered on push to branch "main" by .github/workflows/release.yaml | |
workflow_call: | |
jobs: | |
lint: | |
name: Lint | |
uses: canonical/data-platform-workflows/.github/workflows/lint.yaml@v21.0.0 | |
unit-test: | |
name: Unit test charm | |
runs-on: ubuntu-latest | |
timeout-minutes: 10 | |
steps: | |
- name: Checkout | |
uses: actions/checkout@v4 | |
- name: Install tox & poetry | |
run: | | |
pipx install tox | |
pipx install poetry | |
- name: Run tests | |
run: tox run -e unit | |
lib-check: | |
name: Check libraries | |
runs-on: ubuntu-latest | |
timeout-minutes: 5 | |
steps: | |
- name: Checkout | |
uses: actions/checkout@v4 | |
with: | |
fetch-depth: 0 | |
- run: | | |
# Workaround for https://github.com/canonical/charmcraft/issues/1389#issuecomment-1880921728 | |
touch requirements.txt | |
- name: Check libs | |
uses: canonical/charming-actions/check-libraries@2.4.0 | |
with: | |
credentials: ${{ secrets.CHARMHUB_TOKEN }} | |
github-token: ${{ secrets.GITHUB_TOKEN }} | |
use-labels: false | |
fail-build: ${{ github.event_name == 'pull_request' }} | |
check-terraform: | |
name: Check Terraform | |
runs-on: ubuntu-latest | |
defaults: | |
run: | |
working-directory: ./terraform | |
steps: | |
- name: Checkout Repository | |
uses: actions/checkout@v4 | |
- name: Setup Terraform | |
uses: hashicorp/setup-terraform@v3 | |
- name: Initialize Terraform Module | |
run: terraform init | |
- name: Validate Terraform Module | |
run: terraform validate -no-color | |
- name: Validate terraform fmt | |
run: | | |
set +e | |
terraform fmt -recursive -check -diff | |
FMT_STATUS="$?" | |
if [[ "$FMT_STATUS" -ne 0 ]]; then | |
echo "❌ terraform fmt failed" >> "$GITHUB_STEP_SUMMARY" | |
fi | |
exit "$FMT_STATUS" | |
build: | |
strategy: | |
fail-fast: false | |
matrix: | |
path: | |
- . | |
- tests/integration/sharding_tests/application | |
- tests/integration/relation_tests/new_relations/application-charm | |
name: Build charm | |
uses: canonical/data-platform-workflows/.github/workflows/build_charm.yaml@v21.0.0 | |
with: | |
path-to-charm-directory: ${{ matrix.path }} | |
cache: true | |
integration-test: | |
name: Integration test charm | 3.5.3 | |
needs: | |
- lint | |
- unit-test | |
- build | |
uses: canonical/data-platform-workflows/.github/workflows/integration_test_charm.yaml@v21.0.0 | |
with: | |
artifact-prefix: packed-charm-cache-true | |
cloud: lxd | |
juju-agent-version: 3.5.3 # renovate: juju-agent-pin-minor | |
_beta_allure_report: true | |
permissions: | |
contents: write # Needed for Allure Report beta | |
secrets: | |
integration-test: | | |
{ | |
"AWS_ACCESS_KEY": "${{ secrets.AWS_ACCESS_KEY }}", | |
"AWS_SECRET_KEY": "${{ secrets.AWS_SECRET_KEY }}", | |
"GCP_ACCESS_KEY": "${{ secrets.GCP_ACCESS_KEY }}", | |
"GCP_SECRET_KEY": "${{ secrets.GCP_SECRET_KEY }}", | |
} |