feat: Add equinix_fabric_network terraform provider #53
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: Fabric Acceptance Tests | |
# This workflow determines whether a PR comes from an external fork | |
# (which requires approval from us) or from a branch on this repository | |
# (which means it was made by us and can run immediately). Once a PR | |
# is approved, the PR code gains access to secrets referenced in this | |
# workflow. | |
# The 'build' job and subsequent jobs, are executed only when the pull | |
# request is not a draft, regardless of whether it is from an internal | |
# branch or external fork. | |
# Any changes to this job, even from internal contributors, require heavy scrutiny. | |
on: | |
pull_request_target: | |
types: [opened, synchronize, reopened, ready_for_review] | |
paths: | |
- '**fabric**' | |
- '!LICENSE' | |
- '!**.md' | |
- '!website/**' | |
- '!docs/**' | |
- '!.github/ISSUE_TEMPLATE/**' | |
workflow_dispatch: | |
permissions: | |
pull-requests: read | |
contents: read | |
jobs: | |
authorize: | |
if: (github.event_name == 'workflow_dispatch') || (github.event_name == 'pull_request_target' && github.event.pull_request.draft == false) | |
environment: | |
${{ github.event_name == 'pull_request_target' && | |
github.event.pull_request.head.repo.full_name != github.repository && | |
'external' || 'internal' }} | |
runs-on: ubuntu-latest | |
concurrency: | |
group: ${{ github.event_name == 'pull_request_target' && format('fabric-acctest-authorize-pr-{0}', github.event.pull_request.number) || 'fabric-acctest-authorize' }} | |
cancel-in-progress: true | |
steps: | |
- run: true | |
build: | |
name: Build | |
needs: authorize | |
runs-on: ubuntu-latest | |
timeout-minutes: 10 | |
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 | |
- name: Build | |
run: | | |
go build -v . | |
test-PFNV: | |
name: Matrix Test | |
needs: build | |
runs-on: ubuntu-latest | |
env: | |
EQUINIX_API_ENDPOINT: "https://uatapi.equinix.com" | |
timeout-minutes: 240 | |
strategy: | |
fail-fast: false | |
matrix: | |
version: | |
- stable | |
terraform: | |
- '1.5' | |
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 | |
- name: TF Fabric PNFV acceptance tests | |
timeout-minutes: 180 | |
env: | |
TF_ACC: "1" | |
TF_ACC_TERRAFORM_VERSION: ${{ matrix.terraform }} | |
EQUINIX_API_CLIENTID: ${{ secrets.EQUINIX_API_CLIENTID_PNFV }} | |
EQUINIX_API_CLIENTSECRET: ${{ secrets.EQUINIX_API_CLIENTSECRET_PNFV }} | |
METAL_AUTH_TOKEN: ${{ secrets.METAL_AUTH_TOKEN }} | |
run: | | |
go test ./... -v -coverprofile coverage_pnfv.txt -covermode=atomic -count 1 -parallel 8 -run "(PNFV)" -timeout 180m | |
- name: Sweeper PNFV | |
if: ${{ always() }} | |
env: | |
EQUINIX_API_CLIENTID: ${{ secrets.EQUINIX_API_CLIENTID_PNFV }} | |
EQUINIX_API_CLIENTSECRET: ${{ secrets.EQUINIX_API_CLIENTSECRET_PNFV }} | |
METAL_AUTH_TOKEN: ${{ secrets.METAL_AUTH_TOKEN }} | |
SWEEP: "all" #Flag required to define the regions that the sweeper is to be ran in | |
SWEEP_ALLOW_FAILURES: "true" #Enable to allow Sweeper Tests to continue after failures | |
SWEEP_DIR: "./equinix" | |
run: | | |
# Added sweep-run to filter Fabric PNFV test | |
go test ${SWEEP_DIR} -v -timeout 180m -sweep=${SWEEP} -sweep-allow-failures=${SWEEP_ALLOW_FAILURES} -sweep-run=$(grep -o 'AddTestSweepers("[^"]*PNFV"' equinix/resource_fabric_* | cut -d '"' -f2 | paste -s -d, -) | |
- name: Upload coverage to Codecov | |
if: ${{ always() }} | |
uses: codecov/codecov-action@v3 | |
with: | |
token: ${{ secrets.CODECOV_TOKEN }} | |
files: ./coverage_pnfv.txt | |
test-PFCR: | |
name: Matrix Test | |
needs: build | |
runs-on: ubuntu-latest | |
env: | |
EQUINIX_API_ENDPOINT: "https://uatapi.equinix.com" | |
timeout-minutes: 240 | |
strategy: | |
fail-fast: false | |
matrix: | |
version: | |
- stable | |
terraform: | |
- '1.5' | |
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 | |
- name: TF Fabric PFCR acceptance tests | |
timeout-minutes: 180 | |
env: | |
TF_ACC: "1" | |
TF_ACC_TERRAFORM_VERSION: ${{ matrix.terraform }} | |
EQUINIX_API_CLIENTID: ${{ secrets.EQUINIX_API_CLIENTID_PFCR }} | |
EQUINIX_API_CLIENTSECRET: ${{ secrets.EQUINIX_API_CLIENTSECRET_PFCR }} | |
METAL_AUTH_TOKEN: ${{ secrets.METAL_AUTH_TOKEN }} | |
run: | | |
go test ./... -v -coverprofile coverage_pfcr.txt -covermode=atomic -count 1 -parallel 8 -run "(PFCR)" -timeout 180m | |
- name: Sweeper PFCR | |
if: ${{ always() }} | |
env: | |
EQUINIX_API_CLIENTID: ${{ secrets.EQUINIX_API_CLIENTID_PFCR }} | |
EQUINIX_API_CLIENTSECRET: ${{ secrets.EQUINIX_API_CLIENTSECRET_PFCR }} | |
METAL_AUTH_TOKEN: ${{ secrets.METAL_AUTH_TOKEN }} | |
SWEEP: "all" #Flag required to define the regions that the sweeper is to be ran in | |
SWEEP_ALLOW_FAILURES: "true" #Enable to allow Sweeper Tests to continue after failures | |
SWEEP_DIR: "./equinix" | |
run: | | |
# Added sweep-run to filter Fabric PFCR test | |
go test ${SWEEP_DIR} -v -timeout 180m -sweep=${SWEEP} -sweep-allow-failures=${SWEEP_ALLOW_FAILURES} -sweep-run=$(grep -o 'AddTestSweepers("[^"]*PFCR"' equinix/resource_fabric_* | cut -d '"' -f2 | paste -s -d, -) | |
- name: Upload coverage to Codecov | |
if: ${{ always() }} | |
uses: codecov/codecov-action@v3 | |
with: | |
token: ${{ secrets.CODECOV_TOKEN }} | |
files: ./coverage_pfcr.txt |