Skip to content

feat: Adding GHA workflow for UAT Test Suite #39

feat: Adding GHA workflow for UAT Test Suite

feat: Adding GHA workflow for UAT Test Suite #39

Workflow file for this run

name: terratests-uat-suite
on:
pull_request:
workflow_dispatch:
jobs:
setup-tests:
name: Setup UAT Tests
runs-on: ubuntu-latest
env:
EQUINIX_API_ENDPOINT: "https://uatapi.equinix.com"
steps:
- name: Check out code into the Go module directory
uses: actions/checkout@v4
with:
ref: ${{ github.event.pull_request.head.sha || github.ref }}
- name: Set up Go
uses: actions/setup-go@v5
with:
go-version-file: './go.mod'
id: go
- name: Get dependencies
run: |
go mod download
- uses: hashicorp/setup-terraform@v3
with:
terraform_version: ${{ matrix.terraform }}
terraform_wrapper: false
- name: Setup Variables Files
env:
GH_TOKEN: ${{ secrets.SECRET_TOKEN }}
run: |
secret_names=$(gh api repos/equinix/terraform-equinix-fabric/actions/secrets | \
jq -r '.secrets[].name | select(startswith("TEST_DATA_UAT"))')
echo "::GITHUB_OUTPUT name=secret_names::$secret_names"
for secret_name in $secret_names; do
if [[ "$secret_name" == *"PORT_CONNECTION_PORT_ZSIDE"* ]]; then
secret_n=$(gh api repos/equinix/terraform-equinix-fabric/actions/secrets/$secret_name)
secret_name=$(echo "$secret_n" | jq -r '.name')
echo "secret_name = ${{ env.secret_name }}"
SECRET_VALUE=${{ secrets[env.secret_name] }}
echo "SECRET_VALUE = $SECRET_VALUE"
echo "$SECRET_VALUE" >> ./examples/port-2-port-connection/terraform.tfvars.json
echo "Variable Files Transferred"
fi
done
- name: Run Go Tests
run:
go test ./tests/uat -v -coverprofile coverage_uat_modules.txt -covermode=atomic -count 1 -parallel 8 -timeout 180m
- name: Upload test coverage to Codecov
if: ${{ always() }}
uses: codecov/codecov-action@v3
with:
token: ${{ secrets.CODECOV_TOKEN }}
files: ./coverage_uat_modules.txt