CICD: Trigger the GitHub Actions pull request workflow by branch name… #20
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
name: "PR: Run all tests" | |
on: | |
# git push origin master:tlim_testpr --force | |
# will trigger a full PR test on the master branch: | |
# https://github.com/StackExchange/dnscontrol/actions/workflows/pr_test.yml?query=branch%3Atlim_testpr | |
push: | |
branches: | |
- 'tlim_testpr' | |
pull_request: | |
workflow_dispatch: | |
env: | |
cache-key: 1639697695 #Change to force cache reset `pwsh > Get-Date -UFormat %s` | |
go-mod-path: /go/pkg/mod | |
BIND_DOMAIN: example.com | |
jobs: | |
build: | |
runs-on: ubuntu-latest | |
env: | |
TEST_RESULTS: "/tmp/test-results" | |
steps: | |
- uses: actions/checkout@v4 | |
with: | |
fetch-depth: 0 | |
- name: Set up Go | |
uses: actions/setup-go@v4 | |
with: | |
go-version: stable | |
- name: restore_cache | |
uses: actions/[email protected] | |
with: | |
key: linux-go-${{ hashFiles('go.sum') }}-${{ env.cache-key }} | |
restore-keys: linux-go-${{ hashFiles('go.sum') }}-${{ env.cache-key }} | |
path: ${{ env.go-mod-path }} | |
- run: mkdir -p "$TEST_RESULTS" | |
- name: Run unit tests | |
run: | | |
go install gotest.tools/gotestsum@latest | |
gotestsum --junitfile ${TEST_RESULTS}/gotestsum-report.xml -- $PACKAGE_NAMES | |
- name: Enforce Go Formatted Code | |
run: "[ `go fmt ./... | wc -l` -eq 0 ]" | |
- uses: actions/[email protected] | |
with: | |
path: "/tmp/test-results" | |
# Stringer is needed because .goreleaser includes "go generate ./..." | |
- name: Install stringer | |
run: | | |
go install golang.org/x/tools/cmd/stringer@latest | |
- | |
id: build_binaries_tagged | |
name: Build binaries (if tagged) | |
if: github.ref_type == 'tag' | |
uses: goreleaser/goreleaser-action@v5 | |
with: | |
distribution: goreleaser | |
version: latest | |
args: build | |
- | |
id: build_binaries_not_tagged | |
name: Build binaries (not tagged) | |
if: github.ref_type != 'tag' | |
uses: goreleaser/goreleaser-action@v5 | |
with: | |
args: build --snapshot | |
integration-test-providers: | |
needs: build | |
runs-on: ubuntu-latest | |
outputs: | |
integration_test_providers: ${{ steps.get_integration_test_providers.outputs.integration_test_providers }} | |
steps: | |
- name: Set Integration Test Providers | |
id: get_integration_test_providers | |
shell: pwsh | |
run: | | |
$Providers = @() | |
$EnvContext = ConvertFrom-Json -InputObject $env:ENV_CONTEXT | |
$VarsContext = ConvertFrom-Json -InputObject $env:VARS_CONTEXT | |
$SecretsContext = ConvertFrom-Json -InputObject $env:SECRETS_CONTEXT | |
ConvertFrom-Json -InputObject $env:PROVIDERS | ForEach-Object { | |
if(($null -ne $EnvContext."$($_)_DOMAIN") -or ($null -ne $VarsContext."$($_)_DOMAIN") -or ($null -ne $SecretsContext."$($_)_DOMAIN")) { | |
$Providers += $_ | |
} | |
} | |
Write-Host "Integration test providers: $Providers" | |
echo "integration_test_providers=$(ConvertTo-Json -InputObject $Providers -Compress)" >> $env:GITHUB_OUTPUT | |
env: | |
PROVIDERS: "['AZURE_DNS','BIND','CLOUDFLAREAPI','CLOUDNS','DIGITALOCEAN','GANDI_V5','GCLOUD','HEDNS','HEXONET','INWX','NAMEDOTCOM','NS1','POWERDNS','ROUTE53','TRANSIP']" | |
ENV_CONTEXT: ${{ toJson(env) }} | |
VARS_CONTEXT: ${{ toJson(vars) }} | |
SECRETS_CONTEXT: ${{ toJson(secrets) }} | |
integration-tests: | |
if: github.ref != 'refs/heads/master' && github.ref != 'refs/heads/main' | |
runs-on: ubuntu-latest | |
container: | |
image: golang:1.21 | |
needs: | |
- integration-test-providers | |
env: | |
TEST_RESULTS: "/tmp/test-results" | |
GOTESTSUM_FORMAT: testname | |
# These providers will be tested if the env variable is set. | |
# Set it to the domain name to use during the test. | |
AZURE_DNS_DOMAIN: ${{ vars.AZURE_DNS_DOMAIN }} | |
BIND_DOMAIN: ${{ vars.BIND_DOMAIN }} | |
CLOUDFLAREAPI_DOMAIN: ${{ vars.CLOUDFLAREAPI_DOMAIN }} | |
CLOUDNS_DOMAIN: ${{ vars.CLOUDNS_DOMAIN }} | |
CSCGLOBAL_DOMAIN: ${{ vars.CSCGLOBAL_DOMAIN }} | |
DIGITALOCEAN_DOMAIN: ${{ vars.DIGITALOCEAN_DOMAIN }} | |
GANDI_V5_DOMAIN: ${{ vars.GANDI_V5_DOMAIN }} | |
GCLOUD_DOMAIN: ${{ vars.GCLOUD_DOMAIN }} | |
HEDNS_DOMAIN: ${{ vars.HEDNS_DOMAIN }} | |
HEXONET_DOMAIN: ${{ vars.HEXONET_DOMAIN }} | |
NAMEDOTCOM_DOMAIN: ${{ vars.NAMEDOTCOM_DOMAIN }} | |
NS1_DOMAIN: ${{ vars.NS1_DOMAIN }} | |
POWERDNS_DOMAIN: ${{ vars.POWERDNS_DOMAIN }} | |
ROUTE53_DOMAIN: ${{ vars.ROUTE53_DOMAIN }} | |
TRANSIP_DOMAIN: ${{ vars.TRANSIP_DOMAIN }} | |
# The above providers have additional env variables they | |
# need for credentials and such. | |
AZURE_DNS_CLIENT_ID: ${{ secrets.AZURE_DNS_CLIENT_ID }} | |
AZURE_DNS_CLIENT_SECRET: ${{ secrets.AZURE_DNS_CLIENT_SECRET }} | |
AZURE_DNS_RESOURCE_GROUP: ${{ secrets.AZURE_DNS_RESOURCE_GROUP }} | |
AZURE_DNS_SUBSCRIPTION_ID: ${{ secrets.AZURE_DNS_SUBSCRIPTION_ID }} | |
AZURE_DNS_TENANT_ID: ${{ secrets.AZURE_DNS_TENANT_ID }} | |
CLOUDFLAREAPI_ACCOUNTID: ${{ secrets.CLOUDFLAREAPI_ACCOUNTID }} | |
CLOUDFLAREAPI_TOKEN: ${{ secrets.CLOUDFLAREAPI_TOKEN }} | |
CLOUDNS_AUTH_ID: ${{ secrets.CLOUDNS_AUTH_ID }} | |
CLOUDNS_AUTH_PASSWORD: ${{ secrets.CLOUDNS_AUTH_PASSWORD }} | |
CSCGLOBAL_APIKEY: ${{ secrets.CSCGLOBAL_APIKEY }} | |
CSCGLOBAL_USERTOKEN: ${{ secrets.CSCGLOBAL_USERTOKEN }} | |
DIGITALOCEAN_TOKEN: ${{ secrets.DIGITALOCEAN_TOKEN }} | |
GANDI_V5_APIKEY: ${{ secrets.GANDI_V5_APIKEY }} | |
GCLOUD_EMAIL: ${{ secrets.GCLOUD_EMAIL }} | |
GCLOUD_PRIVATEKEY: ${{ secrets.GCLOUD_PRIVATEKEY }} | |
GCLOUD_PROJECT: ${{ secrets.GCLOUD_PROJECT }} | |
GCLOUD_TYPE: ${{ secrets.GCLOUD_TYPE }} | |
HEDNS_PASSWORD: ${{ secrets.HEDNS_PASSWORD }} | |
HEDNS_TOTP_SECRET: ${{ secrets.HEDNS_TOTP_SECRET }} | |
HEDNS_USERNAME: ${{ secrets.HEDNS_USERNAME }} | |
HEXONET_ENTITY: ${{ secrets.HEXONET_ENTITY }} | |
HEXONET_PW: ${{ secrets.HEXONET_PW }} | |
HEXONET_UID: ${{ secrets.HEXONET_UID }} | |
NAMEDOTCOM_KEY: ${{ secrets.NAMEDOTCOM_KEY }} | |
NAMEDOTCOM_URL: ${{ secrets.NAMEDOTCOM_URL }} | |
NAMEDOTCOM_USER: ${{ secrets.NAMEDOTCOM_USER }} | |
NS1_TOKEN: ${{ secrets.NS1_TOKEN }} | |
POWERDNS_APIKEY: ${{ secrets.POWERDNS_APIKEY }} | |
POWERDNS_APIURL: ${{ secrets.POWERDNS_APIURL }} | |
POWERDNS_SERVERNAME: ${{ secrets.POWERDNS_SERVERNAME }} | |
ROUTE53_KEY: ${{ secrets.ROUTE53_KEY }} | |
ROUTE53_KEY_ID: ${{ secrets.ROUTE53_KEY_ID }} | |
TRANSIP_ACCOUNT_NAME: ${{ secrets.TRANSIP_ACCOUNT_NAME }} | |
TRANSIP_PRIVATE_KEY: ${{ secrets.TRANSIP_PRIVATE_KEY }} | |
concurrency: | |
group: ${{ github.workflow }}-${{ matrix.provider }} | |
strategy: | |
fail-fast: false | |
matrix: | |
provider: ${{ fromJson(needs.integration-test-providers.outputs.integration_test_providers )}} | |
steps: | |
- uses: actions/checkout@v4 | |
- run: mkdir -p "$TEST_RESULTS" | |
- name: restore_cache | |
uses: actions/[email protected] | |
with: | |
key: linux-go-${{ hashFiles('go.sum') }}-${{ env.cache-key }} | |
restore-keys: linux-go-${{ hashFiles('go.sum') }}-${{ env.cache-key }} | |
path: ${{ env.go-mod-path }} | |
- name: Run integration tests for ${{ matrix.provider }} provider | |
run: |- | |
go install gotest.tools/gotestsum@latest | |
if [ -n "$${{ matrix.provider }}_DOMAIN" ] ; then | |
gotestsum --junitfile ${TEST_RESULTS}/gotestsum-report.xml -- -timeout 30m -v -verbose -provider ${{ matrix.provider }} -cfworkers=false | |
else | |
echo "Skip test for ${{ matrix.provider }} provider" | |
fi | |
working-directory: integrationTest | |
- uses: actions/[email protected] | |
with: | |
path: "/tmp/test-results" | |
# release: | |
# if: # GitHub does not currently support regular expressions inside if conditions | |
## (github.ref == 'refs/tags//v[0-9]+(\.[0-9]+)*(-.*)*/') && (github.ref != 'refs/heads//.*/') | |
# runs-on: ubuntu-latest | |
# container: | |
# image: golang:${{ env.gover }} | |
# needs: | |
# - build | |
# env: | |
# DOCKERHUB_ACCESS_TOKEN: | |
# DOCKERHUB_USERNAME: | |
# steps: | |
# - uses: actions/checkout@v4 | |
## # 'setup_remote_docker' was not transformed because there is no suitable equivalent in GitHub Actions | |
# - uses: "./.github/actions/docker_check" | |
# with: | |
# docker-password: "${{ secrets.DOCKER_PASSWORD }}" | |
# docker-username: "${{ env.DOCKER_LOGIN }}" | |
# - name: restore_cache | |
# uses: actions/[email protected] | |
# with: | |
# key: linux-go-${{ hashFiles('go.sum') }}-${{ env.cache-key }} | |
# restore-keys: linux-go-${{ hashFiles('go.sum') }}-${{ env.cache-key }} | |
# - name: Install goreleaser | |
# run: go install github.com/goreleaser/goreleaser@latest | |
# - run: goreleaser release | |
# - uses: actions/[email protected] | |
# with: | |
# path: dist | |
# - uses: actions/[email protected] | |
# with: | |
# path: |- | |
# dist/*.rpm | |
# dist/*.deb | |
# upload: | |
# if: # GitHub does not currently support regular expressions inside if conditions | |
## (github.ref == 'refs/tags//v[0-9]+(\.[0-9]+)*(-.*)*/') && (github.ref != 'refs/heads//.*/') | |
# runs-on: ubuntu-latest | |
# container: | |
# image: python:3.10 | |
# needs: | |
# - release | |
# env: | |
# CLOUDSMITH_API_KEY: | |
# CLOUDSMITH_USERNAME: | |
# DOCKER_LOGIN: | |
# DOCKER_PASSWORD: | |
# strategy: | |
# matrix: | |
# arch: | |
# - i386 | |
# - x86_64 | |
# - arm64 | |
# format: | |
# distro: | |
# steps: | |
# - uses: actions/[email protected] | |
# with: | |
# path: "." | |
## # This item has no matching transformer | |
## - cloudsmith_cloudsmith_ensure_api_key: | |
## # This item has no matching transformer | |
## - cloudsmith_cloudsmith_install_cli: | |
## # This item has no matching transformer | |
## - cloudsmith_cloudsmith_publish: | |
# upload_1: | |
# if: # GitHub does not currently support regular expressions inside if conditions | |
## (github.ref == 'refs/tags//v[0-9]+(\.[0-9]+)*(-.*)*/') && (github.ref != 'refs/heads//.*/') | |
# runs-on: ubuntu-latest | |
# container: | |
# image: python:3.10 | |
# needs: | |
# - release | |
# env: | |
# CLOUDSMITH_API_KEY: | |
# CLOUDSMITH_USERNAME: | |
# DOCKER_LOGIN: | |
# DOCKER_PASSWORD: | |
# strategy: | |
# matrix: | |
# arch: | |
# - i386 | |
# - amd64 | |
# - arm64 | |
# format: | |
# distro: | |
# steps: | |
# - uses: actions/[email protected] | |
# with: | |
# path: "." | |
## # This item has no matching transformer | |
## - cloudsmith_cloudsmith_ensure_api_key: | |
## # This item has no matching transformer | |
## - cloudsmith_cloudsmith_install_cli: | |
## # This item has no matching transformer | |
## - cloudsmith_cloudsmith_publish: |