Skip to content

release: create the correct SHA256SUMS file for the public registry #22

release: create the correct SHA256SUMS file for the public registry

release: create the correct SHA256SUMS file for the public registry #22

Workflow file for this run

---
name: test
on:
pull_request:
concurrency:
group: ${{ github.head_ref || github.run_id }}-test
cancel-in-progress: true
jobs:
build:
name: build
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@b4ffde65f46336ab88eb53be808477a3936bae11 # v4.1.1
# Build all provider targets here to ensure they all compile
- uses: actions/setup-go@93397bea11091df50f3d7e59dc26a7711a8bcfbe # v4.1.0
with:
go-version-file: go.mod
- uses: ./.github/actions/build-provider
- run: ls -al ./dist
- name: Upload artifacts
uses: actions/upload-artifact@5d5d22a31266ced268874388b861e4b58bb5c2f3 # v4.3.1
with:
name: test-artifacts
path: dist
if-no-files-found: error
retention-days: 1
overwrite: true
go:
name: go test
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@b4ffde65f46336ab88eb53be808477a3936bae11 # v4.1.1
- uses: actions/setup-go@93397bea11091df50f3d7e59dc26a7711a8bcfbe # v4.1.0
with:
go-version-file: go.mod
- uses: ./.github/actions/build-flight-control
- run: make test-race-detector
go-acceptance:
name: TF_ACC=1 go test
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@b4ffde65f46336ab88eb53be808477a3936bae11 # v4.1.1
- uses: actions/setup-go@93397bea11091df50f3d7e59dc26a7711a8bcfbe # v4.1.0
with:
go-version-file: go.mod
- uses: ./.github/actions/build-provider
with:
target: linux/amd64
- name: TODO(post-publish) Remove implied local mirror install for dev
run: make install
- uses: aws-actions/configure-aws-credentials@e3dd6a429d7300a6a4c196c26e071d42e0343502 # v4.0.2
with:
# The github actions service user creds for this account managed in hashicorp/enos-ci
aws-access-key-id: ${{ secrets.AWS_ACCESS_KEY_ID }}
aws-secret-access-key: ${{ secrets.AWS_SECRET_ACCESS_KEY }}
aws-region: "us-east-1"
role-to-assume: ${{ secrets.AWS_ROLE_ARN }}
role-skip-session-tagging: true
- uses: hashicorp/setup-terraform@v3
with:
terraform_wrapper: false
- name: Create up acceptance target host
working-directory: enos/modules/go-acceptance-test-target
run: |
terraform init
terraform plan -no-color
terraform apply -auto-approve
HOST_IP=$(terraform output instance_public_ip | tr -d \" | tr -d "\n")
echo "host_ip=$HOST_IP" >> "$GITHUB_ENV"
- name: Configure ssh keys
run: |
echo "${{ secrets.ENOS_CI_SSH_KEY }}" > ./internal/plugin/enos-ci-ssh-key.pem
echo "${{ secrets.ENOS_CI_SSH_KEY }}" > ./internal/transport/ssh/enos-ci-ssh-key.pem
chmod 600 ./internal/plugin/enos-ci-ssh-key.pem
chmod 600 ./internal/transport/ssh/enos-ci-ssh-key.pem
- run: make test-acc
env:
ARTIFACTORY_USER: ${{ secrets.ARTIFACTORY_USER }}
ARTIFACTORY_TOKEN: ${{ secrets.ARTIFACTORY_TOKEN }}
ENOS_TRANSPORT_USER: ubuntu
ENOS_TRANSPORT_PRIVATE_KEY_PATH: ./enos-ci-ssh-key.pem
ENOS_TRANSPORT_HOST: ${{ env.host_ip }}
- run: terraform destroy -auto-approve
if: always()
working-directory: enos/modules/go-acceptance-test-target
validate-terraform-examples:
name: terraform validate examples
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@b4ffde65f46336ab88eb53be808477a3936bae11 # v4.1.1
- uses: actions/setup-go@93397bea11091df50f3d7e59dc26a7711a8bcfbe # v4.1.0
with:
go-version-file: go.mod
- uses: ./.github/actions/build-provider
with:
target: linux/amd64
- name: TODO(post-publish) Make sure the example config uses dev_overrides
run: make install
- uses: hashicorp/setup-terraform@v3
- name: Run terraform --chdir=examples/* validate
run: |
terraform -chdir=examples/core init
terraform -chdir=examples/core fmt -check -recursive
terraform -chdir=examples/core validate
terraform -chdir=examples/artifactory init
terraform -chdir=examples/artifactory fmt -check -recursive
terraform -chdir=examples/artifactory validate
scenarios:
name: enos scenario
needs: build
uses: ./.github/workflows/run-sample.yml
secrets: inherit
with:
sample-name: dev
download: test-artifacts
static-analysis:
name: static analysis
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@b4ffde65f46336ab88eb53be808477a3936bae11 # v4.1.1
- uses: actions/setup-go@93397bea11091df50f3d7e59dc26a7711a8bcfbe # v4.1.0
with:
go-version-file: go.mod
- uses: ./.github/actions/build-flight-control
- uses: hashicorp/setup-terraform@v3
with:
# the terraform wrapper will break terraform execution in enos because
# it changes the output to text when we expect it to be JSON.
terraform_wrapper: false
- uses: hashicorp/action-setup-enos@v1
with:
github-token:
${{ secrets.ELEVATED_GITHUB_TOKEN }}
- uses: ./.github/actions/set-up-gofumpt
- uses: ./.github/actions/set-up-golangci-lint
- name: Run make fmt-check
run: make fmt-check
- name: Run make lint
env:
LINT_OUT_FORMAT: github-actions
run: make lint
- name: Check doc delta
run: make check-doc-delta
- name: Lint Github Actions
uses: docker://docker.mirror.hashicorp.services/rhysd/actionlint@sha256:d84eca815fc24f72546ec1f2f416d9500ad3349ce7db098cf7a52256f5fd4384
with:
args: -color
completed-successfully:
if: always()
runs-on: ubuntu-latest
needs:
- build
- go
- go-acceptance
- validate-terraform-examples
- scenarios
- static-analysis
steps:
- id: status
name: Determine status
run: |
results=$(tr -d '\n' <<< '${{ toJSON(needs.*.result) }}')
if ! grep -q -v -E '(failure|cancelled)' <<< "$results"; then
exit 1
fi