Skip to content

Canary Build & Test #892

Canary Build & Test

Canary Build & Test #892

Workflow file for this run

# Terraform Provider testing workflow.
name: Canary Build & Test
# This GitHub action runs your tests for each pull request.
on:
schedule:
- cron: "0 0 * * *" # Run at 12AM UTC, every day
# Testing only needs permissions to read the repository contents.
permissions:
contents: read
jobs:
# Ensure project builds before running testing matrix
build:
name: Build
runs-on: ubuntu-latest
timeout-minutes: 5
steps:
- uses: actions/checkout@v4
- uses: actions/setup-go@v5
with:
go-version-file: "go.mod"
cache: true
- run: go build -v .
# Run acceptance tests in a matrix with Terraform CLI versions
test:
name: Terraform Provider Acceptance Tests
needs:
- build
runs-on: [self-hosted, jammy, x64]
timeout-minutes: 60
strategy:
fail-fast: false
matrix:
terraform:
- "1.9.*"
include:
- cloud: "lxd"
cloud-channel: "5.21/stable"
juju-channel: "2.9/stable"
lxd-channel: "5.21/stable"
- cloud: "microk8s"
cloud-channel: "1.28-strict/stable"
juju-channel: "3.1/stable"
lxd-channel: "5.21/stable"
- cloud: "lxd"
cloud-channel: "5.21/stable"
juju-channel: "3/stable"
lxd-channel: "5.21/stable"
- cloud: "microk8s"
cloud-channel: "1.28-strict/stable"
juju-channel: "3/stable"
lxd-channel: "5.21/stable"
steps:
- uses: actions/checkout@v4
- uses: actions/setup-go@v5
with:
go-version-file: "go.mod"
cache: true
- uses: hashicorp/setup-terraform@v3
with:
terraform_version: ${{ matrix.terraform }}
terraform_wrapper: false
- name: Setup operator environment
uses: charmed-kubernetes/actions-operator@main
with:
provider: ${{ matrix.cloud }}
channel: ${{ matrix.cloud-channel }}
juju-channel: ${{ matrix.juju-channel }}
lxd-channel: ${{ matrix.lxd-channel }}
- name: "Set environment to configure provider"
# language=bash
run: |
CONTROLLER=$(juju whoami --format yaml | yq .controller)
echo "JUJU_AGENT_VERSION=$(juju show-controller | yq .$CONTROLLER.details.agent-version |tr -d '"')" >> $GITHUB_ENV
echo "JUJU_CONTROLLER_ADDRESSES=$(juju show-controller | yq .$CONTROLLER.details.api-endpoints | yq -r '. | join(",")')" >> $GITHUB_ENV
echo "JUJU_USERNAME=$(juju show-controller | yq .$CONTROLLER.account.user)" >> $GITHUB_ENV
echo "JUJU_PASSWORD=$(cat ~/.local/share/juju/accounts.yaml | yq .controllers.$CONTROLLER.password)" >> $GITHUB_ENV
echo "JUJU_CA_CERT<<EOF" >> $GITHUB_ENV
juju show-controller | yq .$CONTROLLER.details.ca-cert >> $GITHUB_ENV
echo "EOF" >> $GITHUB_ENV
- env:
TF_ACC: "1"
TEST_CLOUD: ${{ matrix.cloud }}
run: go test -parallel 10 -timeout 40m -v -cover ./internal/provider/