GitHub Action
Setup TFLint
A GitHub action that installs a Terraform linter TFLint executable in the PATH.
Required The version of TFLint which will be installed. See TFLint releases page for valid versions.
If version is "latest"
, the action will get the latest version number using Octokit.
Default: "latest"
Used to authenticate requests to the GitHub API to obtain release data from the TFLint repository. Authenticating will increase the API rate limit. Any valid token is supported. No permissions are required.
Default: ${{ github.token }}
To disable authentication, set this value to an empty string (""
). GitHub Enterprise Server tokens will not be accepted by github.com
. GHES users must either:
- Disable authentication
- Provide an API token issued from
github.com
- Apps are the preferred way to authenticate on behalf of an organization
Installs a wrapper script to wrap subsequent calls to tflint
and expose stdout
, stderr
, and exitcode
outputs.
Default: "false"
The following outputs are available when the tflint_wrapper
input is enabled:
stdout
- The output (stdout) produced by the tflint command.stderr
- The error output (stdout) produced by the tflint command.exitcode
- The exit code produced by the tflint command.
name: Lint
on:
push:
branches: [ master ]
pull_request:
jobs:
tflint:
runs-on: ${{ matrix.os }}
strategy:
matrix:
os: [ubuntu-latest, macos-latest, windows-latest]
steps:
- uses: actions/checkout@v3
name: Checkout source code
- uses: actions/cache@v3
name: Cache plugin dir
with:
path: ~/.tflint.d/plugins
key: ${{ matrix.os }}-tflint-${{ hashFiles('.tflint.hcl') }}
- uses: terraform-linters/setup-tflint@v3
name: Setup TFLint
with:
tflint_version: v0.44.1
- name: Show version
run: tflint --version
- name: Init TFLint
run: tflint --init
env:
# https://github.com/terraform-linters/tflint/blob/master/docs/user-guide/plugins.md#avoiding-rate-limiting
GITHUB_TOKEN: ${{ github.token }}
- name: Run TFLint
run: tflint -f compact
- uses: terraform-linters/setup-tflint@v3
or specify it explicitly as
- uses: terraform-linters/setup-tflint@v3
with:
tflint_version: latest
- uses: terraform-linters/setup-tflint@v3
with:
github_token: ${{ secrets.MY_CUSTOM_GITHUB_TOKEN }}
- uses: terraform-linters/setup-tflint@v3
- uses: terraform-linters/tflint-load-config-action@v1
with:
source-repo: me/tflint-config
- run: tflint -f compact
- uses: terraform-linters/setup-tflint@v3
with:
tflint_wrapper: true
- id: tflint
run: tflint -f compact
- run: echo ${{ steps.tflint.outputs.stdout }}
- run: echo ${{ steps.tflint.outputs.stderr }}
- run: echo ${{ steps.tflint.outputs.exitcode }}
This action supports Problem Matchers for --format compact
. You can see annotations in pull requests when TFLint prints issues with the compact
format.
To create a new version:
npm version $inc && git push --follow-tags