mirror of
https://github.com/ysoftdevs/terraform-aws-eks.git
synced 2026-03-11 21:11:32 +01:00
fix: Updated code and version requirements to work with Terraform 0.15 (#1165)
This commit is contained in:
82
.github/workflows/lint.yml
vendored
82
.github/workflows/lint.yml
vendored
@@ -1,82 +0,0 @@
|
||||
name: Lint
|
||||
on: [push, pull_request]
|
||||
|
||||
jobs:
|
||||
tflint:
|
||||
name: TFLint
|
||||
runs-on: ubuntu-latest
|
||||
steps:
|
||||
- uses: actions/checkout@master
|
||||
- name: TFLint
|
||||
uses: docker://wata727/tflint
|
||||
|
||||
fmt:
|
||||
name: Code Format
|
||||
runs-on: ubuntu-latest
|
||||
container:
|
||||
image: hashicorp/terraform:latest
|
||||
steps:
|
||||
- uses: actions/checkout@master
|
||||
- run: terraform fmt --recursive -check=true
|
||||
|
||||
docs:
|
||||
name: Docs
|
||||
runs-on: ubuntu-latest
|
||||
steps:
|
||||
- uses: actions/checkout@master
|
||||
- uses: actions/setup-python@v2
|
||||
- name: Install terraform-docs
|
||||
run: |
|
||||
# Get the download url of the latest version of terraform-docs
|
||||
tf_docs_download_url=$(curl -s https://api.github.com/repos/terraform-docs/terraform-docs/releases/latest | jq -rc '.assets[] | select( .name | contains("linux-amd64")).browser_download_url')
|
||||
mkdir -p $GITHUB_WORKSPACE/bin
|
||||
curl -Lo $GITHUB_WORKSPACE/bin/terraform-docs $tf_docs_download_url
|
||||
chmod +x $GITHUB_WORKSPACE/bin/terraform-docs
|
||||
echo "$GITHUB_WORKSPACE/bin" >> $GITHUB_PATH
|
||||
- name: Check Docs
|
||||
uses: pre-commit/action@v2.0.0
|
||||
with:
|
||||
extra_args: --show-diff-on-failure --all-files terraform_docs
|
||||
|
||||
validate:
|
||||
name: Validate
|
||||
runs-on: ubuntu-latest
|
||||
container:
|
||||
image: hashicorp/terraform:0.12.29
|
||||
steps:
|
||||
- uses: actions/checkout@master
|
||||
- name: Validate Code
|
||||
env:
|
||||
AWS_REGION: 'us-east-1'
|
||||
TF_WARN_OUTPUT_ERRORS: 1
|
||||
TF_VAR_vpc_id: 'vpc-123456'
|
||||
TF_VAR_subnets: '["subnet-12345a"]'
|
||||
TF_VAR_workers_ami_id: 'ami-123456'
|
||||
TF_VAR_cluster_name: 'test_cluster'
|
||||
run: |
|
||||
terraform init
|
||||
terraform validate
|
||||
- name: Validate Examples
|
||||
run: |
|
||||
for example in $(find examples -maxdepth 1 -mindepth 1 -type d); do
|
||||
cd $example
|
||||
terraform init
|
||||
terraform validate
|
||||
cd -
|
||||
done
|
||||
|
||||
minimum:
|
||||
name: Minimum version check
|
||||
runs-on: ubuntu-latest
|
||||
container:
|
||||
image: hashicorp/terraform:0.12.9
|
||||
steps:
|
||||
- uses: actions/checkout@master
|
||||
- name: Validate Code
|
||||
env:
|
||||
AWS_REGION: 'us-east-1'
|
||||
TF_WARN_OUTPUT_ERRORS: 1
|
||||
run: |
|
||||
sed -i -e 's/>=/=/' -e 's/ \(\d\+\.\d\+\)"/ \1.0"/' versions.tf
|
||||
terraform init
|
||||
terraform validate -var "region=${AWS_REGION}" -var "vpc_id=vpc-123456" -var "subnets=[\"subnet-12345a\"]" -var "workers_ami_id=ami-123456" -var "cluster_ingress_cidrs=[]" -var "cluster_name=test_cluster"
|
||||
102
.github/workflows/pre-commit.yml
vendored
Normal file
102
.github/workflows/pre-commit.yml
vendored
Normal file
@@ -0,0 +1,102 @@
|
||||
name: Pre-Commit
|
||||
|
||||
on:
|
||||
pull_request:
|
||||
push:
|
||||
branches:
|
||||
- master
|
||||
|
||||
jobs:
|
||||
# Min Terraform version(s)
|
||||
getDirectories:
|
||||
name: Get root directories
|
||||
runs-on: ubuntu-latest
|
||||
steps:
|
||||
- name: Checkout
|
||||
uses: actions/checkout@v2
|
||||
- name: Install Python
|
||||
uses: actions/setup-python@v2
|
||||
- name: Build matrix
|
||||
id: matrix
|
||||
run: |
|
||||
DIRS=$(python -c "import json; import glob; print(json.dumps([x.replace('/versions.tf', '') for x in glob.glob('./**/versions.tf', recursive=True)]))")
|
||||
echo "::set-output name=directories::$DIRS"
|
||||
outputs:
|
||||
directories: ${{ steps.matrix.outputs.directories }}
|
||||
|
||||
preCommitMinVersions:
|
||||
name: Min TF validate
|
||||
needs: getDirectories
|
||||
runs-on: ubuntu-latest
|
||||
strategy:
|
||||
matrix:
|
||||
directory: ${{ fromJson(needs.getDirectories.outputs.directories) }}
|
||||
steps:
|
||||
- name: Checkout
|
||||
uses: actions/checkout@v2
|
||||
- name: Install Python
|
||||
uses: actions/setup-python@v2
|
||||
- name: Terraform min/max versions
|
||||
id: minMax
|
||||
uses: clowdhaus/terraform-min-max@v1.0.1
|
||||
with:
|
||||
directory: ${{ matrix.directory }}
|
||||
- name: Install Terraform v${{ steps.minMax.outputs.minVersion }}
|
||||
uses: hashicorp/setup-terraform@v1
|
||||
with:
|
||||
terraform_version: ${{ steps.minMax.outputs.minVersion }}
|
||||
- name: Install pre-commit dependencies
|
||||
run: pip install pre-commit
|
||||
- name: Execute pre-commit
|
||||
# Run only validate pre-commit check on min version supported
|
||||
if: ${{ matrix.directory != '.' }}
|
||||
run:
|
||||
pre-commit run terraform_validate --color=always --show-diff-on-failure --files ${{ matrix.directory }}/*
|
||||
- name: Execute pre-commit
|
||||
# Run only validate pre-commit check on min version supported
|
||||
if: ${{ matrix.directory == '.' }}
|
||||
run:
|
||||
pre-commit run terraform_validate --color=always --show-diff-on-failure --files $(ls *.tf)
|
||||
|
||||
|
||||
# Max Terraform version
|
||||
getBaseVersion:
|
||||
name: Module max TF version
|
||||
runs-on: ubuntu-latest
|
||||
steps:
|
||||
- name: Checkout
|
||||
uses: actions/checkout@v2
|
||||
- name: Terraform min/max versions
|
||||
id: minMax
|
||||
uses: clowdhaus/terraform-min-max@v1.0.1
|
||||
outputs:
|
||||
minVersion: ${{ steps.minMax.outputs.minVersion }}
|
||||
maxVersion: ${{ steps.minMax.outputs.maxVersion }}
|
||||
|
||||
preCommitMaxVersion:
|
||||
name: Max TF pre-commit
|
||||
runs-on: ubuntu-latest
|
||||
needs: getBaseVersion
|
||||
strategy:
|
||||
fail-fast: false
|
||||
matrix:
|
||||
version:
|
||||
- ${{ needs.getBaseVersion.outputs.maxVersion }}
|
||||
steps:
|
||||
- name: Checkout
|
||||
uses: actions/checkout@v2
|
||||
- name: Install Python
|
||||
uses: actions/setup-python@v2
|
||||
- name: Install Terraform v${{ matrix.version }}
|
||||
uses: hashicorp/setup-terraform@v1
|
||||
with:
|
||||
terraform_version: ${{ matrix.version }}
|
||||
- name: Install pre-commit dependencies
|
||||
run: |
|
||||
pip install pre-commit
|
||||
curl -L "$(curl -s https://api.github.com/repos/terraform-docs/terraform-docs/releases/latest | grep -o -E "https://.+?-v0.12\..+?-linux-amd64" | head -n1)" > terraform-docs && chmod +x terraform-docs && sudo mv terraform-docs /usr/bin/
|
||||
curl -L "$(curl -s https://api.github.com/repos/terraform-linters/tflint/releases/latest | grep -o -E "https://.+?_linux_amd64.zip")" > tflint.zip && unzip tflint.zip && rm tflint.zip && sudo mv tflint /usr/bin/
|
||||
- name: Execute pre-commit
|
||||
# Run all pre-commit checks on max version supported
|
||||
if: ${{ matrix.version == needs.getBaseVersion.outputs.maxVersion }}
|
||||
run: pre-commit run --color=always --show-diff-on-failure --all-files
|
||||
Reference in New Issue
Block a user