mirror of
https://github.com/terraform-aws-modules/terraform-aws-rds-proxy.git
synced 2025-12-16 16:01:11 +00:00
168 lines
6.1 KiB
YAML
168 lines
6.1 KiB
YAML
name: Pre-Commit
|
|
|
|
on:
|
|
pull_request:
|
|
branches:
|
|
- main
|
|
- master
|
|
|
|
env:
|
|
TERRAFORM_DOCS_VERSION: v0.20.0
|
|
TFLINT_VERSION: v0.59.1
|
|
|
|
jobs:
|
|
collectInputs:
|
|
name: Collect workflow inputs
|
|
runs-on: ubuntu-latest
|
|
outputs:
|
|
directories: ${{ steps.dirs.outputs.directories }}
|
|
steps:
|
|
- name: Checkout
|
|
uses: actions/checkout@v5
|
|
|
|
- name: Get root directories
|
|
id: dirs
|
|
uses: clowdhaus/terraform-composite-actions/directories@v1.14.0
|
|
|
|
preCommitMinVersions:
|
|
name: Min TF pre-commit
|
|
needs: collectInputs
|
|
runs-on: ubuntu-latest
|
|
strategy:
|
|
matrix:
|
|
directory: ${{ fromJson(needs.collectInputs.outputs.directories) }}
|
|
steps:
|
|
- name: Install rmz
|
|
uses: jaxxstorm/action-install-gh-release@v2.1.0
|
|
with:
|
|
repo: SUPERCILEX/fuc
|
|
asset-name: x86_64-unknown-linux-gnu-rmz
|
|
rename-to: rmz
|
|
chmod: 0755
|
|
extension-matching: disable
|
|
|
|
# https://github.com/orgs/community/discussions/25678#discussioncomment-5242449
|
|
- name: Delete unnecessary files
|
|
run: |
|
|
formatByteCount() { echo $(numfmt --to=iec-i --suffix=B --padding=7 $1'000'); }
|
|
getAvailableSpace() { echo $(df -a $1 | awk 'NR > 1 {avail+=$4} END {print avail}'); }
|
|
|
|
BEFORE=$(getAvailableSpace)
|
|
|
|
ln -s /opt/hostedtoolcache/SUPERCILEX/x86_64-unknown-linux-gnu-rmz/latest/linux-x64/rmz /usr/local/bin/rmz
|
|
rmz -f /opt/hostedtoolcache/CodeQL &
|
|
rmz -f /opt/hostedtoolcache/Java_Temurin-Hotspot_jdk &
|
|
rmz -f /opt/hostedtoolcache/PyPy &
|
|
rmz -f /opt/hostedtoolcache/Ruby &
|
|
rmz -f /opt/hostedtoolcache/go &
|
|
|
|
wait
|
|
|
|
AFTER=$(getAvailableSpace)
|
|
SAVED=$((AFTER-BEFORE))
|
|
echo "=> Saved $(formatByteCount $SAVED)"
|
|
|
|
- name: Checkout
|
|
uses: actions/checkout@v5
|
|
|
|
- name: Terraform min/max versions
|
|
id: minMax
|
|
uses: clowdhaus/terraform-min-max@v2.1.0
|
|
with:
|
|
directory: ${{ matrix.directory }}
|
|
|
|
- name: Pre-commit Terraform ${{ steps.minMax.outputs.minVersion }}
|
|
# Run only validate pre-commit check on min version supported
|
|
if: ${{ matrix.directory != '.' }}
|
|
uses: clowdhaus/terraform-composite-actions/pre-commit@v1.14.0
|
|
with:
|
|
terraform-version: ${{ steps.minMax.outputs.minVersion }}
|
|
tflint-version: ${{ env.TFLINT_VERSION }}
|
|
args: 'terraform_validate --color=always --show-diff-on-failure --files ${{ matrix.directory }}/*'
|
|
|
|
- name: Pre-commit Terraform ${{ steps.minMax.outputs.minVersion }}
|
|
# Run only validate pre-commit check on min version supported
|
|
if: ${{ matrix.directory == '.' }}
|
|
uses: clowdhaus/terraform-composite-actions/pre-commit@v1.14.0
|
|
with:
|
|
terraform-version: ${{ steps.minMax.outputs.minVersion }}
|
|
tflint-version: ${{ env.TFLINT_VERSION }}
|
|
args: 'terraform_validate --color=always --show-diff-on-failure --files $(ls *.tf)'
|
|
|
|
preCommitMaxVersion:
|
|
name: Max TF pre-commit
|
|
runs-on: ubuntu-latest
|
|
needs: collectInputs
|
|
steps:
|
|
- name: Install rmz
|
|
uses: jaxxstorm/action-install-gh-release@v2.1.0
|
|
with:
|
|
repo: SUPERCILEX/fuc
|
|
asset-name: x86_64-unknown-linux-gnu-rmz
|
|
rename-to: rmz
|
|
chmod: 0755
|
|
extension-matching: disable
|
|
|
|
# https://github.com/orgs/community/discussions/25678#discussioncomment-5242449
|
|
- name: Delete unnecessary files
|
|
run: |
|
|
formatByteCount() { echo $(numfmt --to=iec-i --suffix=B --padding=7 $1'000'); }
|
|
getAvailableSpace() { echo $(df -a $1 | awk 'NR > 1 {avail+=$4} END {print avail}'); }
|
|
|
|
BEFORE=$(getAvailableSpace)
|
|
|
|
ln -s /opt/hostedtoolcache/SUPERCILEX/x86_64-unknown-linux-gnu-rmz/latest/linux-x64/rmz /usr/local/bin/rmz
|
|
rmz -f /opt/hostedtoolcache/CodeQL &
|
|
rmz -f /opt/hostedtoolcache/Java_Temurin-Hotspot_jdk &
|
|
rmz -f /opt/hostedtoolcache/PyPy &
|
|
rmz -f /opt/hostedtoolcache/Ruby &
|
|
rmz -f /opt/hostedtoolcache/go &
|
|
sudo rmz -f /usr/local/lib/android &
|
|
|
|
if [[ ${{ github.repository }} == terraform-aws-modules/terraform-aws-security-group ]]; then
|
|
sudo rmz -f /usr/share/dotnet &
|
|
sudo rmz -f /usr/local/.ghcup &
|
|
sudo apt-get -qq remove -y 'azure-.*'
|
|
sudo apt-get -qq remove -y 'cpp-.*'
|
|
sudo apt-get -qq remove -y 'dotnet-runtime-.*'
|
|
sudo apt-get -qq remove -y 'google-.*'
|
|
sudo apt-get -qq remove -y 'libclang-.*'
|
|
sudo apt-get -qq remove -y 'libllvm.*'
|
|
sudo apt-get -qq remove -y 'llvm-.*'
|
|
sudo apt-get -qq remove -y 'mysql-.*'
|
|
sudo apt-get -qq remove -y 'postgresql-.*'
|
|
sudo apt-get -qq remove -y 'php.*'
|
|
sudo apt-get -qq remove -y 'temurin-.*'
|
|
sudo apt-get -qq remove -y kubectl firefox mono-devel
|
|
sudo apt-get -qq autoremove -y
|
|
sudo apt-get -qq clean
|
|
fi
|
|
|
|
wait
|
|
|
|
AFTER=$(getAvailableSpace)
|
|
SAVED=$((AFTER-BEFORE))
|
|
echo "=> Saved $(formatByteCount $SAVED)"
|
|
|
|
- name: Checkout
|
|
uses: actions/checkout@v5
|
|
with:
|
|
ref: ${{ github.event.pull_request.head.ref }}
|
|
repository: ${{github.event.pull_request.head.repo.full_name}}
|
|
|
|
- name: Terraform min/max versions
|
|
id: minMax
|
|
uses: clowdhaus/terraform-min-max@v2.1.0
|
|
|
|
- name: Hide template dir
|
|
# Special to this repo, we don't want to check this dir
|
|
if: ${{ github.repository == 'terraform-aws-modules/terraform-aws-security-group' }}
|
|
run: rm -rf modules/_templates
|
|
|
|
- name: Pre-commit Terraform ${{ steps.minMax.outputs.maxVersion }}
|
|
uses: clowdhaus/terraform-composite-actions/pre-commit@v1.14.0
|
|
with:
|
|
terraform-version: ${{ steps.minMax.outputs.maxVersion }}
|
|
tflint-version: ${{ env.TFLINT_VERSION }}
|
|
terraform-docs-version: ${{ env.TERRAFORM_DOCS_VERSION }}
|
|
install-hcledit: true
|