[DPE-3654] Peer cluster data stored in a secret #3301
Workflow file for this run
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 2024 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: | |
outputs: | |
artifact-prefix: | |
description: build_charm.yaml `artifact-prefix` output | |
value: ${{ jobs.build.outputs.artifact-prefix }} | |
jobs: | |
lint: | |
name: Lint | |
uses: canonical/data-platform-workflows/.github/workflows/[email protected] | |
unit-test: | |
name: Unit test charm | |
runs-on: ubuntu-22.04 | |
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 | |
promtool: | |
runs-on: ubuntu-22.04 | |
steps: | |
- name: Checkout repo | |
uses: actions/checkout@v4 | |
# prometheus snap includes promtool | |
- name: Install prometheus snap | |
run: sudo snap install prometheus | |
- name: Check validity of prometheus alert rules | |
run: | | |
promtool check rules src/alert_rules/prometheus/*.yaml | |
- name: Run unit tests for prometheus alert rules | |
run: | | |
promtool test rules tests/unit/test_alert_rules/*.yaml | |
terraform-test: | |
name: Terraform - Lint and Simple Deployment | |
runs-on: ubuntu-22.04 | |
timeout-minutes: 120 | |
steps: | |
- name: Checkout repo | |
uses: actions/checkout@v4 | |
with: | |
fetch-depth: 0 | |
- name: Install terraform snap | |
run: | | |
sudo snap install terraform --channel=latest/stable --classic | |
- name: lint charm module | |
run: | | |
pushd ./terraform | |
terraform init | |
terraform fmt | |
terraform validate | |
pushd ./tests | |
terraform init | |
terraform fmt | |
terraform validate | |
popd | |
popd | |
- name: run checks - prepare | |
run: | | |
sudo snap install juju --channel=3.6/beta --classic | |
sudo snap install juju-wait --channel=latest/stable --classic | |
sudo snap install jq | |
- name: LXD setup | |
run: | | |
sudo snap refresh lxd --channel=latest/stable | |
sudo adduser "$USER" 'lxd' | |
# `newgrp` does not work in GitHub Actions; use `sg` instead | |
sg 'lxd' -c "lxd waitready" | |
sg 'lxd' -c "lxd init --auto" | |
sg 'lxd' -c "lxc network set lxdbr0 ipv6.address none" | |
sudo iptables -F FORWARD | |
sudo iptables -P FORWARD ACCEPT | |
- name: Juju setup | |
run: | | |
sg 'lxd' -c "juju bootstrap 'localhost' --config model-logs-size=10G" | |
juju model-defaults logging-config='<root>=INFO; unit=DEBUG' | |
juju add-model test | |
- name: Terraform deploy | |
run: | | |
pushd ./terraform/tests/ | |
TF_VAR_model_name="test" terraform apply -target null_resource.simple_deployment_juju_wait_deployment -auto-approve | |
popd | |
lib-check: | |
name: Check libraries | |
runs-on: ubuntu-22.04 | |
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/[email protected] | |
with: | |
charmcraft-channel: latest/candidate # TODO: remove after charmcraft 3.3 stable release | |
credentials: ${{ secrets.CHARMHUB_TOKEN }} | |
github-token: ${{ secrets.GITHUB_TOKEN }} | |
use-labels: false | |
fail-build: ${{ github.event_name == 'pull_request' }} | |
build: | |
name: Build charm | |
strategy: | |
fail-fast: false | |
matrix: | |
path: | |
- . | |
- ./tests/integration/relations/opensearch_provider/application-charm/ | |
uses: canonical/data-platform-workflows/.github/workflows/[email protected] | |
with: | |
charmcraft-snap-channel: latest/candidate # TODO: remove after charmcraft 3.3 stable release | |
path-to-charm-directory: ${{ matrix.path }} | |
integration-test: | |
name: Integration test charm | |
needs: | |
- lint | |
- unit-test | |
- build | |
uses: canonical/data-platform-workflows/.github/workflows/[email protected] | |
with: | |
juju-agent-version: 3.6.1 # renovate: juju-agent-pin-minor | |
_beta_allure_report: true | |
artifact-prefix: ${{ needs.build.outputs.artifact-prefix }} | |
cloud: lxd | |
secrets: | |
# GitHub appears to redact each line of a multi-line secret | |
# Avoid putting `{` or `}` on a line by itself so that it doesn't get redacted in logs | |
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 }}", | |
"GCP_SERVICE_ACCOUNT": "${{ secrets.GCP_SERVICE_ACCOUNT }}", } | |
permissions: | |
contents: write |