feat(packer): Allow passing in an instance_profile and custom shell scripts that run after the runner installation #5486
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: "Terraform checks" | |
on: | |
push: | |
branches: | |
- main | |
pull_request: | |
paths: ["**/*.tf", "**/*.hcl", ".github/workflows/terraform.yml"] | |
permissions: | |
contents: read | |
pull-requests: write | |
env: | |
AWS_REGION: eu-west-1 | |
jobs: | |
verify_module: | |
name: Verify module | |
strategy: | |
matrix: | |
terraform: [1.5.6, "latest"] | |
runs-on: ubuntu-latest | |
container: | |
image: hashicorp/terraform:${{ matrix.terraform }} | |
steps: | |
- name: "Checkout" | |
uses: actions/checkout@11bd71901bbe5b1630ceea73d27597364c9af683 # v4.2.2 | |
- name: "Fake zip files" # Validate will fail if it cannot find the zip files | |
run: | | |
touch lambdas/functions/webhook/webhook.zip | |
touch lambdas/functions/control-plane/runners.zip | |
touch lambdas/functions/gh-agent-syncer/runner-binaries-syncer.zip | |
touch lambdas/functions/ami-housekeeper/ami-housekeeper.zip | |
touch lambdas/functions/termination-watcher/termination-watcher.zip | |
- name: terraform init | |
run: terraform init -get -backend=false -input=false | |
- if: contains(matrix.terraform, '1.5.') | |
name: check terraform formatting | |
run: terraform fmt -recursive -check=true -write=false | |
- if: contains(matrix.terraform, 'latest') # check formatting for the latest release but avoid failing the build | |
name: check terraform formatting | |
run: terraform fmt -recursive -check=true -write=false | |
continue-on-error: true | |
- name: validate terraform | |
run: terraform validate | |
- if: contains(matrix.terraform, '1.5.') | |
name: Fix for actions/cache on alpine | |
run: apk add --no-cache tar | |
continue-on-error: true | |
- if: contains(matrix.terraform, '1.5.') | |
uses: actions/cache@ab5e6d0c87105b4c9c2047343972218f562e4319 # v4.0.1 | |
name: Cache TFLint plugin dir | |
with: | |
path: ~/.tflint.d/plugins | |
key: tflint-${{ hashFiles('.tflint.hcl') }} | |
- if: contains(matrix.terraform, '1.5.') | |
name: Setup TFLint | |
uses: terraform-linters/setup-tflint@19a52fbac37dacb22a09518e4ef6ee234f2d4987 # v4.0.0 | |
with: | |
github_token: ${{ secrets.GITHUB_TOKEN }} | |
- if: contains(matrix.terraform, '1.5.') | |
name: Run TFLint | |
run: | | |
tflint --init -c ${GITHUB_WORKSPACE}/.tflint.hcl | |
tflint -c ${GITHUB_WORKSPACE}/.tflint.hcl --var-file ${GITHUB_WORKSPACE}/.github/lint/tflint.tfvars | |
verify_modules: | |
name: Verify modules | |
strategy: | |
fail-fast: false | |
matrix: | |
terraform: [1.5.6, "latest"] | |
module: | |
[ | |
"ami-housekeeper", | |
"download-lambda", | |
"lambda", | |
"multi-runner", | |
"runner-binaries-syncer", | |
"runners", | |
"setup-iam-permissions", | |
"ssm", | |
"termination-watcher", | |
"webhook", | |
] | |
defaults: | |
run: | |
working-directory: modules/${{ matrix.module }} | |
runs-on: ubuntu-latest | |
container: | |
image: hashicorp/terraform:${{ matrix.terraform }} | |
steps: | |
- uses: actions/checkout@11bd71901bbe5b1630ceea73d27597364c9af683 # v4.2.2 | |
- name: terraform init | |
run: terraform init -get -backend=false -input=false | |
- if: contains(matrix.terraform, '1.3.') | |
name: check terraform formatting | |
run: terraform fmt -recursive -check=true -write=false | |
- if: contains(matrix.terraform, 'latest') # check formatting for the latest release but avoid failing the build | |
name: check terraform formatting | |
run: terraform fmt -recursive -check=true -write=false | |
continue-on-error: true | |
- name: validate terraform | |
run: terraform validate | |
- if: contains(matrix.terraform, '1.3.') | |
name: Fix for actions/cache on alpine | |
run: apk add --no-cache tar | |
continue-on-error: true | |
- if: contains(matrix.terraform, '1.3.') | |
uses: actions/cache@v4 | |
name: Cache TFLint plugin dir | |
with: | |
path: ~/.tflint.d/plugins | |
key: tflint-${{ hashFiles('.tflint.hcl') }} | |
- if: contains(matrix.terraform, '1.3.') | |
name: Setup TFLint | |
uses: terraform-linters/setup-tflint@v4 | |
with: | |
github_token: ${{ secrets.GITHUB_TOKEN }} | |
- if: contains(matrix.terraform, '1.3.') | |
name: Run TFLint | |
working-directory: ${{ github.workspace }} | |
run: | | |
tflint --init -c ${GITHUB_WORKSPACE}/.tflint.hcl --chdir modules/${{ matrix.module }} | |
tflint -f compact -c ${GITHUB_WORKSPACE}/.tflint.hcl --var-file ${GITHUB_WORKSPACE}/.github/lint/tflint.tfvars --chdir modules/${{ matrix.module }} | |
verify_examples: | |
name: Verify examples | |
strategy: | |
fail-fast: false | |
matrix: | |
terraform: [1.5.6, "latest"] | |
example: | |
[ | |
"default", | |
"ubuntu", | |
"prebuilt", | |
"arm64", | |
"ephemeral", | |
"termination-watcher", | |
"windows", | |
"multi-runner", | |
] | |
defaults: | |
run: | |
working-directory: examples/${{ matrix.example }} | |
runs-on: ubuntu-latest | |
container: | |
image: hashicorp/terraform:${{ matrix.terraform }} | |
steps: | |
- uses: actions/checkout@11bd71901bbe5b1630ceea73d27597364c9af683 # v4.2.2 | |
- name: terraform init | |
run: terraform init -get -backend=false -input=false | |
- if: contains(matrix.terraform, '1.5.') | |
name: check terraform formatting | |
run: terraform fmt -recursive -check=true -write=false | |
- if: contains(matrix.terraform, 'latest') # check formatting for the latest release but avoid failing the build | |
name: check terraform formatting | |
run: terraform fmt -recursive -check=true -write=false | |
continue-on-error: true | |
- name: validate terraform | |
run: terraform validate | |
- if: contains(matrix.terraform, '1.5.') | |
name: Fix for actions/cache on alpine | |
run: apk add --no-cache tar | |
continue-on-error: true | |
- if: contains(matrix.terraform, '1.5.') | |
uses: actions/cache@v4 | |
name: Cache TFLint plugin dir | |
with: | |
path: ~/.tflint.d/plugins | |
key: tflint-${{ hashFiles('.tflint.hcl') }} | |
- if: contains(matrix.terraform, '1.5.') | |
name: Setup TFLint | |
uses: terraform-linters/setup-tflint@v4 | |
with: | |
github_token: ${{ secrets.GITHUB_TOKEN }} | |
- if: contains(matrix.terraform, '1.5.') | |
name: Run TFLint | |
working-directory: ${{ github.workspace }} | |
run: | | |
tflint --init -c ${GITHUB_WORKSPACE}/.tflint.hcl --chdir modules/${{ matrix.module }} | |
tflint -f compact -c ${GITHUB_WORKSPACE}/.tflint.hcl --var-file ${GITHUB_WORKSPACE}/.github/lint/tflint.tfvars --chdir examples/${{ matrix.example }} |