mirror of
https://github.com/StackExchange/dnscontrol.git
synced 2025-12-09 13:46:07 +08:00
Bumps [actions/checkout](https://github.com/actions/checkout) from 5 to 6. <details> <summary>Release notes</summary> <p><em>Sourced from <a href="https://github.com/actions/checkout/releases">actions/checkout's releases</a>.</em></p> <blockquote> <h2>v6.0.0</h2> <h2>What's Changed</h2> <ul> <li>Update README to include Node.js 24 support details and requirements by <a href="https://github.com/salmanmkc"><code>@salmanmkc</code></a> in <a href="https://redirect.github.com/actions/checkout/pull/2248">actions/checkout#2248</a></li> <li>Persist creds to a separate file by <a href="https://github.com/ericsciple"><code>@ericsciple</code></a> in <a href="https://redirect.github.com/actions/checkout/pull/2286">actions/checkout#2286</a></li> <li>v6-beta by <a href="https://github.com/ericsciple"><code>@ericsciple</code></a> in <a href="https://redirect.github.com/actions/checkout/pull/2298">actions/checkout#2298</a></li> <li>update readme/changelog for v6 by <a href="https://github.com/ericsciple"><code>@ericsciple</code></a> in <a href="https://redirect.github.com/actions/checkout/pull/2311">actions/checkout#2311</a></li> </ul> <p><strong>Full Changelog</strong>: <a href="https://github.com/actions/checkout/compare/v5.0.0...v6.0.0">https://github.com/actions/checkout/compare/v5.0.0...v6.0.0</a></p> <h2>v6-beta</h2> <h2>What's Changed</h2> <p>Updated persist-credentials to store the credentials under <code>$RUNNER_TEMP</code> instead of directly in the local git config.</p> <p>This requires a minimum Actions Runner version of <a href="https://github.com/actions/runner/releases/tag/v2.329.0">v2.329.0</a> to access the persisted credentials for <a href="https://docs.github.com/en/actions/tutorials/use-containerized-services/create-a-docker-container-action">Docker container action</a> scenarios.</p> <h2>v5.0.1</h2> <h2>What's Changed</h2> <ul> <li>Port v6 cleanup to v5 by <a href="https://github.com/ericsciple"><code>@ericsciple</code></a> in <a href="https://redirect.github.com/actions/checkout/pull/2301">actions/checkout#2301</a></li> </ul> <p><strong>Full Changelog</strong>: <a href="https://github.com/actions/checkout/compare/v5...v5.0.1">https://github.com/actions/checkout/compare/v5...v5.0.1</a></p> </blockquote> </details> <details> <summary>Changelog</summary> <p><em>Sourced from <a href="https://github.com/actions/checkout/blob/main/CHANGELOG.md">actions/checkout's changelog</a>.</em></p> <blockquote> <h1>Changelog</h1> <h2>V6.0.0</h2> <ul> <li>Persist creds to a separate file by <a href="https://github.com/ericsciple"><code>@ericsciple</code></a> in <a href="https://redirect.github.com/actions/checkout/pull/2286">actions/checkout#2286</a></li> <li>Update README to include Node.js 24 support details and requirements by <a href="https://github.com/salmanmkc"><code>@salmanmkc</code></a> in <a href="https://redirect.github.com/actions/checkout/pull/2248">actions/checkout#2248</a></li> </ul> <h2>V5.0.1</h2> <ul> <li>Port v6 cleanup to v5 by <a href="https://github.com/ericsciple"><code>@ericsciple</code></a> in <a href="https://redirect.github.com/actions/checkout/pull/2301">actions/checkout#2301</a></li> </ul> <h2>V5.0.0</h2> <ul> <li>Update actions checkout to use node 24 by <a href="https://github.com/salmanmkc"><code>@salmanmkc</code></a> in <a href="https://redirect.github.com/actions/checkout/pull/2226">actions/checkout#2226</a></li> </ul> <h2>V4.3.1</h2> <ul> <li>Port v6 cleanup to v4 by <a href="https://github.com/ericsciple"><code>@ericsciple</code></a> in <a href="https://redirect.github.com/actions/checkout/pull/2305">actions/checkout#2305</a></li> </ul> <h2>V4.3.0</h2> <ul> <li>docs: update README.md by <a href="https://github.com/motss"><code>@motss</code></a> in <a href="https://redirect.github.com/actions/checkout/pull/1971">actions/checkout#1971</a></li> <li>Add internal repos for checking out multiple repositories by <a href="https://github.com/mouismail"><code>@mouismail</code></a> in <a href="https://redirect.github.com/actions/checkout/pull/1977">actions/checkout#1977</a></li> <li>Documentation update - add recommended permissions to Readme by <a href="https://github.com/benwells"><code>@benwells</code></a> in <a href="https://redirect.github.com/actions/checkout/pull/2043">actions/checkout#2043</a></li> <li>Adjust positioning of user email note and permissions heading by <a href="https://github.com/joshmgross"><code>@joshmgross</code></a> in <a href="https://redirect.github.com/actions/checkout/pull/2044">actions/checkout#2044</a></li> <li>Update README.md by <a href="https://github.com/nebuk89"><code>@nebuk89</code></a> in <a href="https://redirect.github.com/actions/checkout/pull/2194">actions/checkout#2194</a></li> <li>Update CODEOWNERS for actions by <a href="https://github.com/TingluoHuang"><code>@TingluoHuang</code></a> in <a href="https://redirect.github.com/actions/checkout/pull/2224">actions/checkout#2224</a></li> <li>Update package dependencies by <a href="https://github.com/salmanmkc"><code>@salmanmkc</code></a> in <a href="https://redirect.github.com/actions/checkout/pull/2236">actions/checkout#2236</a></li> </ul> <h2>v4.2.2</h2> <ul> <li><code>url-helper.ts</code> now leverages well-known environment variables by <a href="https://github.com/jww3"><code>@jww3</code></a> in <a href="https://redirect.github.com/actions/checkout/pull/1941">actions/checkout#1941</a></li> <li>Expand unit test coverage for <code>isGhes</code> by <a href="https://github.com/jww3"><code>@jww3</code></a> in <a href="https://redirect.github.com/actions/checkout/pull/1946">actions/checkout#1946</a></li> </ul> <h2>v4.2.1</h2> <ul> <li>Check out other refs/* by commit if provided, fall back to ref by <a href="https://github.com/orhantoy"><code>@orhantoy</code></a> in <a href="https://redirect.github.com/actions/checkout/pull/1924">actions/checkout#1924</a></li> </ul> <h2>v4.2.0</h2> <ul> <li>Add Ref and Commit outputs by <a href="https://github.com/lucacome"><code>@lucacome</code></a> in <a href="https://redirect.github.com/actions/checkout/pull/1180">actions/checkout#1180</a></li> <li>Dependency updates by <a href="https://github.com/dependabot"><code>@dependabot</code></a>- <a href="https://redirect.github.com/actions/checkout/pull/1777">actions/checkout#1777</a>, <a href="https://redirect.github.com/actions/checkout/pull/1872">actions/checkout#1872</a></li> </ul> <h2>v4.1.7</h2> <ul> <li>Bump the minor-npm-dependencies group across 1 directory with 4 updates by <a href="https://github.com/dependabot"><code>@dependabot</code></a> in <a href="https://redirect.github.com/actions/checkout/pull/1739">actions/checkout#1739</a></li> <li>Bump actions/checkout from 3 to 4 by <a href="https://github.com/dependabot"><code>@dependabot</code></a> in <a href="https://redirect.github.com/actions/checkout/pull/1697">actions/checkout#1697</a></li> <li>Check out other refs/* by commit by <a href="https://github.com/orhantoy"><code>@orhantoy</code></a> in <a href="https://redirect.github.com/actions/checkout/pull/1774">actions/checkout#1774</a></li> <li>Pin actions/checkout's own workflows to a known, good, stable version. by <a href="https://github.com/jww3"><code>@jww3</code></a> in <a href="https://redirect.github.com/actions/checkout/pull/1776">actions/checkout#1776</a></li> </ul> <h2>v4.1.6</h2> <ul> <li>Check platform to set archive extension appropriately by <a href="https://github.com/cory-miller"><code>@cory-miller</code></a> in <a href="https://redirect.github.com/actions/checkout/pull/1732">actions/checkout#1732</a></li> </ul> <h2>v4.1.5</h2> <ul> <li>Update NPM dependencies by <a href="https://github.com/cory-miller"><code>@cory-miller</code></a> in <a href="https://redirect.github.com/actions/checkout/pull/1703">actions/checkout#1703</a></li> <li>Bump github/codeql-action from 2 to 3 by <a href="https://github.com/dependabot"><code>@dependabot</code></a> in <a href="https://redirect.github.com/actions/checkout/pull/1694">actions/checkout#1694</a></li> <li>Bump actions/setup-node from 1 to 4 by <a href="https://github.com/dependabot"><code>@dependabot</code></a> in <a href="https://redirect.github.com/actions/checkout/pull/1696">actions/checkout#1696</a></li> <li>Bump actions/upload-artifact from 2 to 4 by <a href="https://github.com/dependabot"><code>@dependabot</code></a> in <a href="https://redirect.github.com/actions/checkout/pull/1695">actions/checkout#1695</a></li> </ul> <!-- raw HTML omitted --> </blockquote> <p>... (truncated)</p> </details> <details> <summary>Commits</summary> <ul> <li><a href="1af3b93b68"><code>1af3b93</code></a> update readme/changelog for v6 (<a href="https://redirect.github.com/actions/checkout/issues/2311">#2311</a>)</li> <li><a href="71cf2267d8"><code>71cf226</code></a> v6-beta (<a href="https://redirect.github.com/actions/checkout/issues/2298">#2298</a>)</li> <li><a href="069c695914"><code>069c695</code></a> Persist creds to a separate file (<a href="https://redirect.github.com/actions/checkout/issues/2286">#2286</a>)</li> <li><a href="ff7abcd0c3"><code>ff7abcd</code></a> Update README to include Node.js 24 support details and requirements (<a href="https://redirect.github.com/actions/checkout/issues/2248">#2248</a>)</li> <li>See full diff in <a href="https://github.com/actions/checkout/compare/v5...v6">compare view</a></li> </ul> </details> <br /> [](https://docs.github.com/en/github/managing-security-vulnerabilities/about-dependabot-security-updates#about-compatibility-scores) Dependabot will resolve any conflicts with this PR as long as you don't alter it yourself. You can also trigger a rebase manually by commenting `@dependabot rebase`. [//]: # (dependabot-automerge-start) [//]: # (dependabot-automerge-end) --- <details> <summary>Dependabot commands and options</summary> <br /> You can trigger Dependabot actions by commenting on this PR: - `@dependabot rebase` will rebase this PR - `@dependabot recreate` will recreate this PR, overwriting any edits that have been made to it - `@dependabot merge` will merge this PR after your CI passes on it - `@dependabot squash and merge` will squash and merge this PR after your CI passes on it - `@dependabot cancel merge` will cancel a previously requested merge and block automerging - `@dependabot reopen` will reopen this PR if it is closed - `@dependabot close` will close this PR and stop Dependabot recreating it. You can achieve the same result by closing it manually - `@dependabot show <dependency name> ignore conditions` will show all of the ignore conditions of the specified dependency - `@dependabot ignore this major version` will close this PR and stop Dependabot creating any more for this major version (unless you reopen the PR or upgrade to it yourself) - `@dependabot ignore this minor version` will close this PR and stop Dependabot creating any more for this minor version (unless you reopen the PR or upgrade to it yourself) - `@dependabot ignore this dependency` will close this PR and stop Dependabot creating any more for this dependency (unless you reopen the PR or upgrade to it yourself) </details> Signed-off-by: dependabot[bot] <support@github.com> Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com> Co-authored-by: Tom Limoncelli <6293917+tlimoncelli@users.noreply.github.com>
217 lines
9.4 KiB
YAML
217 lines
9.4 KiB
YAML
name: "PR: Run INTEGRATION tests"
|
|
|
|
# When will this pipeline be activated?
|
|
# 1. On any pull-request, or if someone pushes to a branch called
|
|
# "tlim_testpr".
|
|
on:
|
|
pull_request:
|
|
workflow_dispatch:
|
|
# Want to trigger all the tests without making a PR?
|
|
# Run: git push origin main:tlim_testpr --force
|
|
# This will trigger a full PR test on the main branch.
|
|
# See https://github.com/StackExchange/dnscontrol/actions/workflows/pr_integration_tests.yml?query=branch%3Atlim_testpr
|
|
push:
|
|
branches:
|
|
- 'tlim_testpr'
|
|
|
|
# Environment Variables
|
|
env:
|
|
# cache-key: Change to force cache reset `pwsh > Get-Date -UFormat %s`
|
|
cache-key: 1639697695
|
|
# go-mod-path: Where go-mod writes temp files
|
|
go-mod-path: /go/pkg/mod
|
|
# BIND_DOMAIN: BIND is the one providers that we always test. By
|
|
# defining this here, we know it will always be set.
|
|
BIND_DOMAIN: example.com
|
|
|
|
jobs:
|
|
|
|
# integration-test-providers: Determine which providers have a _DOMAIN variable set.
|
|
# That variable enables testing for the provider. The results are
|
|
# stored in a JSON blob stashed in # needs.integration-test-providers.outputs.integration_test_providers
|
|
# where integration-tests can pick it up.
|
|
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: "['AXFRDDNS', 'AXFRDDNS_DNSSEC', 'AZURE_DNS','BIND','BUNNY_DNS','CLOUDFLAREAPI','CLOUDNS','CNR','DIGITALOCEAN','FORTIGATE','GANDI_V5','GCLOUD','HEDNS','HEXONET','HUAWEICLOUD','INWX','JOKER','MYTHICBEASTS', 'NAMEDOTCOM','NS1','POWERDNS','ROUTE53','SAKURACLOUD','TRANSIP']"
|
|
ENV_CONTEXT: ${{ toJson(env) }}
|
|
VARS_CONTEXT: ${{ toJson(vars) }}
|
|
SECRETS_CONTEXT: ${{ toJson(secrets) }}
|
|
|
|
# integration-tests: Run the integration tests on any provider listed
|
|
# in needs.integration-test-providers.outputs.integration_test_providers.
|
|
integration-tests:
|
|
if: github.ref != 'refs/heads/master' && github.ref != 'refs/heads/main'
|
|
runs-on: ubuntu-latest
|
|
container:
|
|
image: golang:1.25
|
|
needs:
|
|
- integration-test-providers
|
|
env:
|
|
TEST_RESULTS: "/tmp/test-results"
|
|
GOTESTSUM_FORMAT: testname
|
|
|
|
# PROVIDER DOMAIN LIST
|
|
# These providers will be tested if the env variable is set.
|
|
# Set it to the domain name to use during the test.
|
|
AXFRDDNS_DOMAIN: ${{ vars.AXFRDDNS_DOMAIN }}
|
|
AXFRDDNS_DNSSEC_DOMAIN: ${{ vars.AXFRDDNS_DNSSEC_DOMAIN }}
|
|
AZURE_DNS_DOMAIN: ${{ vars.AZURE_DNS_DOMAIN }}
|
|
BIND_DOMAIN: ${{ vars.BIND_DOMAIN }}
|
|
BUNNY_DNS_DOMAIN: ${{ vars.BUNNY_DNS_DOMAIN }}
|
|
CLOUDFLAREAPI_DOMAIN: ${{ vars.CLOUDFLAREAPI_DOMAIN }}
|
|
CLOUDNS_DOMAIN: ${{ vars.CLOUDNS_DOMAIN }}
|
|
CNR_DOMAIN: ${{ vars.CNR_DOMAIN }}
|
|
CSCGLOBAL_DOMAIN: ${{ vars.CSCGLOBAL_DOMAIN }}
|
|
DIGITALOCEAN_DOMAIN: ${{ vars.DIGITALOCEAN_DOMAIN }}
|
|
FORTIGATE_DOMAIN: ${{ vars.FORTIGATE_DOMAIN }}
|
|
GANDI_V5_DOMAIN: ${{ vars.GANDI_V5_DOMAIN }}
|
|
GCLOUD_DOMAIN: ${{ vars.GCLOUD_DOMAIN }}
|
|
HEDNS_DOMAIN: ${{ vars.HEDNS_DOMAIN }}
|
|
HEXONET_DOMAIN: ${{ vars.HEXONET_DOMAIN }}
|
|
HUAWEICLOUD_DOMAIN: ${{ vars.HUAWEICLOUD_DOMAIN }}
|
|
JOKER_DOMAIN: ${{ vars.JOKER_DOMAIN }}
|
|
MYTHICBEASTS_DOMAIN: ${{ vars.MYTHICBEASTS_DOMAIN }}
|
|
NAMEDOTCOM_DOMAIN: ${{ vars.NAMEDOTCOM_DOMAIN }}
|
|
NS1_DOMAIN: ${{ vars.NS1_DOMAIN }}
|
|
POWERDNS_DOMAIN: ${{ vars.POWERDNS_DOMAIN }}
|
|
ROUTE53_DOMAIN: ${{ vars.ROUTE53_DOMAIN }}
|
|
SAKURACLOUD_DOMAIN: ${{ vars.SAKURACLOUD_DOMAIN }}
|
|
TRANSIP_DOMAIN: ${{ vars.TRANSIP_DOMAIN }}
|
|
|
|
# PROVIDER SECRET LIST
|
|
# The above providers have additional env variables they
|
|
# need for credentials and such.
|
|
#
|
|
AXFRDDNS_MASTER: ${{ secrets.AXFRDDNS_MASTER }}
|
|
AXFRDDNS_NAMESERVERS: ${{ secrets.AXFRDDNS_NAMESERVERS }}
|
|
AXFRDDNS_TRANSFER_KEY: ${{ secrets.AXFRDDNS_TRANSFER_KEY }}
|
|
AXFRDDNS_TRANSFER_MODE: ${{ secrets.AXFRDDNS_TRANSFER_MODE }}
|
|
AXFRDDNS_UPDATE_KEY: ${{ secrets.AXFRDDNS_UPDATE_KEY }}
|
|
AXFRDDNS_UPDATE_MODE: ${{ secrets.AXFRDDNS_UPDATE_MODE }}
|
|
#
|
|
AXFRDDNS_DNSSEC_MASTER: ${{ secrets.AXFRDDNS_DNSSEC_MASTER }}
|
|
AXFRDDNS_DNSSEC_NAMESERVERS: ${{ secrets.AXFRDDNS_DNSSEC_NAMESERVERS }}
|
|
AXFRDDNS_DNSSEC_TRANSFER_KEY: ${{ secrets.AXFRDDNS_DNSSEC_TRANSFER_KEY }}
|
|
AXFRDDNS_DNSSEC_TRANSFER_MODE: ${{ secrets.AXFRDDNS_DNSSEC_TRANSFER_MODE }}
|
|
AXFRDDNS_DNSSEC_UPDATE_KEY: ${{ secrets.AXFRDDNS_DNSSEC_UPDATE_KEY }}
|
|
AXFRDDNS_DNSSEC_UPDATE_MODE: ${{ secrets.AXFRDDNS_DNSSEC_UPDATE_MODE }}
|
|
#
|
|
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 }}
|
|
#
|
|
BUNNY_DNS_API_KEY: ${{ secrets.BUNNY_DNS_API_KEY }}
|
|
#
|
|
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 }}
|
|
#
|
|
CNR_UID: ${{ secrets.CNR_UID }}
|
|
CNR_PW: ${{ secrets.CNR_PW }}
|
|
CNR_ENTITY: ${{ secrets.CNR_ENTITY }}
|
|
#
|
|
DIGITALOCEAN_TOKEN: ${{ secrets.DIGITALOCEAN_TOKEN }}
|
|
#
|
|
FORTIGATE_API_KEY: ${{ secrets.FORTIGATE_API_KEY }}
|
|
FORTIGATE_VDOM: ${{ secrets.FORTIGATE_VDOM }}
|
|
FORTIGATE_HOST: ${{ secrets.FORTIGATE_HOST }}
|
|
#
|
|
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 }}
|
|
#
|
|
HUAWEICLOUD_REGION: ${{ secrets.HUAWEICLOUD_REGION }}
|
|
HUAWEICLOUD_KEY_ID: ${{ secrets.HUAWEICLOUD_KEY_ID }}
|
|
HUAWEICLOUD_KEY: ${{ secrets.HUAWEICLOUD_KEY }}
|
|
#
|
|
JOKER_USERNAME: ${{ secrets.JOKER_USERNAME }}
|
|
JOKER_PASSWORD: ${{ secrets.JOKER_PASSWORD }}
|
|
#
|
|
MYTHICBEASTS_KEYID: ${{ secrets.MYTHICBEASTS_KEYID }}
|
|
MYTHICBEASTS_SECRET: ${{ secrets.MYTHICBEASTS_SECRET }}
|
|
#
|
|
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 }}
|
|
#
|
|
SAKURACLOUD_ACCESS_TOKEN: ${{ secrets.SAKURACLOUD_ACCESS_TOKEN }}
|
|
SAKURACLOUD_ACCESS_TOKEN_SECRET: ${{ secrets.SAKURACLOUD_ACCESS_TOKEN_SECRET }}
|
|
#
|
|
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@v6
|
|
- run: mkdir -p "$TEST_RESULTS"
|
|
- name: restore_cache
|
|
uses: actions/cache@v4.3.0
|
|
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 -profile ${{ matrix.provider }} -cfworkers=false
|
|
else
|
|
echo "Skip test for ${{ matrix.provider }} provider"
|
|
fi
|
|
working-directory: integrationTest
|
|
- uses: actions/upload-artifact@v5.0.0
|
|
with:
|
|
name: integration-tests-${{ matrix.provider }}
|
|
path: ${{ env.TEST_RESULTS }}
|