[DPE-6534] Add TF charm and product modules for simple & large deployments #3394
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/lint.yaml@v29.0.0 | |
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 - Validation and Simple Deployment product | |
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 / format / validate TF modules | |
run: | | |
pushd ./terraform | |
for dir in charm/simple_deployment charm/large_deployment product/simple_deployment product/large_deployment; do | |
(cd "${dir}" && terraform init && terraform fmt && terraform validate) | |
done | |
popd | |
- name: run checks - prepare | |
run: | | |
sudo snap install juju --channel=3.6 --classic | |
- 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 - simple deployments product module | |
run: | | |
pushd ./terraform/product/simple_deployment/ | |
terraform apply \ | |
-var='opensearch={"model": "test"}' \ | |
-var='backups-integrator={"config": {"bucket": "test"}}' \ | |
-auto-approve | |
popd | |
- name: Wait for juju deployment | |
run: | | |
# TODO - remove this when juju wait-for starts reporting the up to date status | |
while true; do | |
juju wait-for application opensearch -m test --query='status=="active"' & | |
pid=$! | |
SECONDS=0 | |
while kill -0 $pid 2>/dev/null; do | |
(( SECONDS >= 180 )) && kill $pid && wait $pid 2>/dev/null && break | |
sleep 5 | |
done | |
wait $pid && juju wait-for model test --query='life=="alive" && status=="available"' && exit 0 | |
echo "Retrying..." | |
done | |
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/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' }} | |
build: | |
strategy: | |
fail-fast: false | |
matrix: | |
path: | |
- . | |
- tests/integration/relations/opensearch_provider/application-charm | |
name: Build charm | ${{ matrix.path }} | |
uses: canonical/data-platform-workflows/.github/workflows/build_charm.yaml@v29.0.0 | |
with: | |
path-to-charm-directory: ${{ matrix.path }} | |
integration-test: | |
name: Integration test charm | |
needs: | |
- lint | |
- unit-test | |
- build | |
uses: canonical/data-platform-workflows/.github/workflows/integration_test_charm.yaml@v29.0.0 | |
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 |