forked from github/pre-commit-opentofu
feat: Improve performance during pre-commit --all (-a) run (#327)
This commit is contained in:
parent
a80d3835d4
commit
7e7c91643e
11 changed files with 106 additions and 7 deletions
|
|
@ -55,6 +55,43 @@ function common::parse_cmdline {
|
||||||
done
|
done
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#######################################################################
|
||||||
|
# This is a workaround to improve performance when all files are passed
|
||||||
|
# See: https://github.com/antonbabenko/pre-commit-terraform/issues/309
|
||||||
|
# Arguments:
|
||||||
|
# hook_id (string) hook ID, see `- id` for details in .pre-commit-hooks.yaml file
|
||||||
|
# files (array) filenames to check
|
||||||
|
# Outputs:
|
||||||
|
# Return 0 if `-a|--all` arg was passed to `pre-commit`
|
||||||
|
#######################################################################
|
||||||
|
function common::is_hook_run_on_whole_repo {
|
||||||
|
local -r hook_id="$1"
|
||||||
|
shift 1
|
||||||
|
local -a -r files=("$@")
|
||||||
|
# get directory containing `.pre-commit-hooks.yaml` file
|
||||||
|
local -r root_config_dir="$(dirname "$(dirname "$(realpath "${BASH_SOURCE[0]}")")")"
|
||||||
|
# get included and excluded files from .pre-commit-hooks.yaml file
|
||||||
|
local -r hook_config_block=$(sed -n "/^- id: $hook_id$/,/^$/p" "$root_config_dir/.pre-commit-hooks.yaml")
|
||||||
|
local -r included_files=$(awk '$1 == "files:" {print $2; exit}' <<< "$hook_config_block")
|
||||||
|
local -r excluded_files=$(awk '$1 == "exclude:" {print $2; exit}' <<< "$hook_config_block")
|
||||||
|
# sorted string with the files passed to the hook by pre-commit
|
||||||
|
local -r files_to_check=$(printf '%s\n' "${files[@]}" | sort | tr '\n' ' ')
|
||||||
|
# git ls-files sorted string
|
||||||
|
local all_files_that_can_be_checked
|
||||||
|
|
||||||
|
if [ -z "$excluded_files" ]; then
|
||||||
|
all_files_that_can_be_checked=$(git ls-files | sort | grep -e "$included_files" | tr '\n' ' ')
|
||||||
|
else
|
||||||
|
all_files_that_can_be_checked=$(git ls-files | sort | grep -e "$included_files" | grep -v -e "$excluded_files" | tr '\n' ' ')
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [ "$files_to_check" == "$all_files_that_can_be_checked" ]; then
|
||||||
|
return 0
|
||||||
|
else
|
||||||
|
return 1
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
#######################################################################
|
#######################################################################
|
||||||
# Hook execution boilerplate logic which is common to hooks, that run
|
# Hook execution boilerplate logic which is common to hooks, that run
|
||||||
# on per dir basis.
|
# on per dir basis.
|
||||||
|
|
@ -64,13 +101,23 @@ function common::parse_cmdline {
|
||||||
# 3. Complete hook execution and return exit code
|
# 3. Complete hook execution and return exit code
|
||||||
# Arguments:
|
# Arguments:
|
||||||
# args (string with array) arguments that configure wrapped tool behavior
|
# args (string with array) arguments that configure wrapped tool behavior
|
||||||
|
# hook_id (string) hook ID, see `- id` for details in .pre-commit-hooks.yaml file
|
||||||
# files (array) filenames to check
|
# files (array) filenames to check
|
||||||
#######################################################################
|
#######################################################################
|
||||||
function common::per_dir_hook {
|
function common::per_dir_hook {
|
||||||
local -r args="$1"
|
local -r args="$1"
|
||||||
shift 1
|
local -r hook_id="$2"
|
||||||
|
shift 2
|
||||||
local -a -r files=("$@")
|
local -a -r files=("$@")
|
||||||
|
|
||||||
|
# check is (optional) function defined
|
||||||
|
if [ "$(type -t run_hook_on_whole_repo)" == function ] &&
|
||||||
|
# check is hook run via `pre-commit run --all`
|
||||||
|
common::is_hook_run_on_whole_repo "$hook_id" "${files[@]}"; then
|
||||||
|
run_hook_on_whole_repo "$args"
|
||||||
|
exit 0
|
||||||
|
fi
|
||||||
|
|
||||||
# consume modified files passed from pre-commit so that
|
# consume modified files passed from pre-commit so that
|
||||||
# hook runs against only those relevant directories
|
# hook runs against only those relevant directories
|
||||||
local index=0
|
local index=0
|
||||||
|
|
|
||||||
|
|
@ -1,6 +1,10 @@
|
||||||
#!/usr/bin/env bash
|
#!/usr/bin/env bash
|
||||||
set -eo pipefail
|
set -eo pipefail
|
||||||
|
|
||||||
|
# globals variables
|
||||||
|
# hook ID, see `- id` for details in .pre-commit-hooks.yaml file
|
||||||
|
# shellcheck disable=SC2034 # Unused var.
|
||||||
|
readonly HOOK_ID='infracost_breakdown'
|
||||||
# shellcheck disable=SC2155 # No way to assign to readonly variable in separate lines
|
# shellcheck disable=SC2155 # No way to assign to readonly variable in separate lines
|
||||||
readonly SCRIPT_DIR="$(dirname "$(realpath "${BASH_SOURCE[0]}")")"
|
readonly SCRIPT_DIR="$(dirname "$(realpath "${BASH_SOURCE[0]}")")"
|
||||||
# shellcheck source=_common.sh
|
# shellcheck source=_common.sh
|
||||||
|
|
|
||||||
|
|
@ -1,6 +1,10 @@
|
||||||
#!/usr/bin/env bash
|
#!/usr/bin/env bash
|
||||||
set -eo pipefail
|
set -eo pipefail
|
||||||
|
|
||||||
|
# globals variables
|
||||||
|
# hook ID, see `- id` for details in .pre-commit-hooks.yaml file
|
||||||
|
# shellcheck disable=SC2034 # Unused var.
|
||||||
|
readonly HOOK_ID='terraform_docs'
|
||||||
# shellcheck disable=SC2155 # No way to assign to readonly variable in separate lines
|
# shellcheck disable=SC2155 # No way to assign to readonly variable in separate lines
|
||||||
readonly SCRIPT_DIR="$(dirname "$(realpath "${BASH_SOURCE[0]}")")"
|
readonly SCRIPT_DIR="$(dirname "$(realpath "${BASH_SOURCE[0]}")")"
|
||||||
# shellcheck source=_common.sh
|
# shellcheck source=_common.sh
|
||||||
|
|
|
||||||
|
|
@ -1,6 +1,10 @@
|
||||||
#!/usr/bin/env bash
|
#!/usr/bin/env bash
|
||||||
set -eo pipefail
|
set -eo pipefail
|
||||||
|
|
||||||
|
# globals variables
|
||||||
|
# hook ID, see `- id` for details in .pre-commit-hooks.yaml file
|
||||||
|
# shellcheck disable=SC2034 # Unused var.
|
||||||
|
readonly HOOK_ID='terraform_fmt'
|
||||||
# shellcheck disable=SC2155 # No way to assign to readonly variable in separate lines
|
# shellcheck disable=SC2155 # No way to assign to readonly variable in separate lines
|
||||||
readonly SCRIPT_DIR="$(dirname "$(realpath "${BASH_SOURCE[0]}")")"
|
readonly SCRIPT_DIR="$(dirname "$(realpath "${BASH_SOURCE[0]}")")"
|
||||||
# shellcheck source=_common.sh
|
# shellcheck source=_common.sh
|
||||||
|
|
|
||||||
|
|
@ -2,6 +2,9 @@
|
||||||
|
|
||||||
set -eo pipefail
|
set -eo pipefail
|
||||||
|
|
||||||
|
# globals variables
|
||||||
|
# hook ID, see `- id` for details in .pre-commit-hooks.yaml file
|
||||||
|
readonly HOOK_ID='terraform_providers_lock'
|
||||||
# shellcheck disable=SC2155 # No way to assign to readonly variable in separate lines
|
# shellcheck disable=SC2155 # No way to assign to readonly variable in separate lines
|
||||||
readonly SCRIPT_DIR="$(dirname "$(realpath "${BASH_SOURCE[0]}")")"
|
readonly SCRIPT_DIR="$(dirname "$(realpath "${BASH_SOURCE[0]}")")"
|
||||||
# shellcheck source=_common.sh
|
# shellcheck source=_common.sh
|
||||||
|
|
@ -11,7 +14,7 @@ function main {
|
||||||
common::initialize "$SCRIPT_DIR"
|
common::initialize "$SCRIPT_DIR"
|
||||||
common::parse_cmdline "$@"
|
common::parse_cmdline "$@"
|
||||||
# shellcheck disable=SC2153 # False positive
|
# shellcheck disable=SC2153 # False positive
|
||||||
common::per_dir_hook "${ARGS[*]}" "${FILES[@]}"
|
common::per_dir_hook "${ARGS[*]}" "$HOOK_ID" "${FILES[@]}"
|
||||||
}
|
}
|
||||||
|
|
||||||
#######################################################################
|
#######################################################################
|
||||||
|
|
|
||||||
|
|
@ -2,6 +2,9 @@
|
||||||
|
|
||||||
set -eo pipefail
|
set -eo pipefail
|
||||||
|
|
||||||
|
# globals variables
|
||||||
|
# hook ID, see `- id` for details in .pre-commit-hooks.yaml file
|
||||||
|
readonly HOOK_ID='terraform_tflint'
|
||||||
# shellcheck disable=SC2155 # No way to assign to readonly variable in separate lines
|
# shellcheck disable=SC2155 # No way to assign to readonly variable in separate lines
|
||||||
readonly SCRIPT_DIR="$(dirname "$(realpath "${BASH_SOURCE[0]}")")"
|
readonly SCRIPT_DIR="$(dirname "$(realpath "${BASH_SOURCE[0]}")")"
|
||||||
# shellcheck source=_common.sh
|
# shellcheck source=_common.sh
|
||||||
|
|
@ -14,7 +17,7 @@ function main {
|
||||||
# shellcheck disable=SC2178 # It's the simplest syntax for that case
|
# shellcheck disable=SC2178 # It's the simplest syntax for that case
|
||||||
ARGS=${ARGS[*]/__GIT_WORKING_DIR__/$(pwd)\/}
|
ARGS=${ARGS[*]/__GIT_WORKING_DIR__/$(pwd)\/}
|
||||||
# shellcheck disable=SC2128 # It's the simplest syntax for that case
|
# shellcheck disable=SC2128 # It's the simplest syntax for that case
|
||||||
common::per_dir_hook "$ARGS" "${FILES[@]}"
|
common::per_dir_hook "$ARGS" "$HOOK_ID" "${FILES[@]}"
|
||||||
}
|
}
|
||||||
|
|
||||||
#######################################################################
|
#######################################################################
|
||||||
|
|
|
||||||
|
|
@ -1,6 +1,9 @@
|
||||||
#!/usr/bin/env bash
|
#!/usr/bin/env bash
|
||||||
set -eo pipefail
|
set -eo pipefail
|
||||||
|
|
||||||
|
# globals variables
|
||||||
|
# hook ID, see `- id` for details in .pre-commit-hooks.yaml file
|
||||||
|
readonly HOOK_ID='terraform_tfsec'
|
||||||
# shellcheck disable=SC2155 # No way to assign to readonly variable in separate lines
|
# shellcheck disable=SC2155 # No way to assign to readonly variable in separate lines
|
||||||
readonly SCRIPT_DIR="$(dirname "$(realpath "${BASH_SOURCE[0]}")")"
|
readonly SCRIPT_DIR="$(dirname "$(realpath "${BASH_SOURCE[0]}")")"
|
||||||
# shellcheck source=_common.sh
|
# shellcheck source=_common.sh
|
||||||
|
|
@ -13,7 +16,7 @@ function main {
|
||||||
# shellcheck disable=SC2178 # It's the simplest syntax for that case
|
# shellcheck disable=SC2178 # It's the simplest syntax for that case
|
||||||
ARGS=${ARGS[*]/__GIT_WORKING_DIR__/$(pwd)\/}
|
ARGS=${ARGS[*]/__GIT_WORKING_DIR__/$(pwd)\/}
|
||||||
# shellcheck disable=SC2128 # It's the simplest syntax for that case
|
# shellcheck disable=SC2128 # It's the simplest syntax for that case
|
||||||
common::per_dir_hook "$ARGS" "${FILES[@]}"
|
common::per_dir_hook "$ARGS" "$HOOK_ID" "${FILES[@]}"
|
||||||
}
|
}
|
||||||
|
|
||||||
#######################################################################
|
#######################################################################
|
||||||
|
|
|
||||||
|
|
@ -1,6 +1,10 @@
|
||||||
#!/usr/bin/env bash
|
#!/usr/bin/env bash
|
||||||
set -eo pipefail
|
set -eo pipefail
|
||||||
|
|
||||||
|
# globals variables
|
||||||
|
# hook ID, see `- id` for details in .pre-commit-hooks.yaml file
|
||||||
|
# shellcheck disable=SC2034 # Unused var.
|
||||||
|
readonly HOOK_ID='terraform_validate'
|
||||||
# shellcheck disable=SC2155 # No way to assign to readonly variable in separate lines
|
# shellcheck disable=SC2155 # No way to assign to readonly variable in separate lines
|
||||||
readonly SCRIPT_DIR="$(dirname "$(realpath "${BASH_SOURCE[0]}")")"
|
readonly SCRIPT_DIR="$(dirname "$(realpath "${BASH_SOURCE[0]}")")"
|
||||||
# shellcheck source=_common.sh
|
# shellcheck source=_common.sh
|
||||||
|
|
|
||||||
|
|
@ -1,6 +1,9 @@
|
||||||
#!/usr/bin/env bash
|
#!/usr/bin/env bash
|
||||||
set -eo pipefail
|
set -eo pipefail
|
||||||
|
|
||||||
|
# globals variables
|
||||||
|
# hook ID, see `- id` for details in .pre-commit-hooks.yaml file
|
||||||
|
readonly HOOK_ID='terragrunt_fmt'
|
||||||
# shellcheck disable=SC2155 # No way to assign to readonly variable in separate lines
|
# shellcheck disable=SC2155 # No way to assign to readonly variable in separate lines
|
||||||
readonly SCRIPT_DIR="$(dirname "$(realpath "${BASH_SOURCE[0]}")")"
|
readonly SCRIPT_DIR="$(dirname "$(realpath "${BASH_SOURCE[0]}")")"
|
||||||
# shellcheck source=_common.sh
|
# shellcheck source=_common.sh
|
||||||
|
|
@ -10,7 +13,7 @@ function main {
|
||||||
common::initialize "$SCRIPT_DIR"
|
common::initialize "$SCRIPT_DIR"
|
||||||
common::parse_cmdline "$@"
|
common::parse_cmdline "$@"
|
||||||
# shellcheck disable=SC2153 # False positive
|
# shellcheck disable=SC2153 # False positive
|
||||||
common::per_dir_hook "${ARGS[*]}" "${FILES[@]}"
|
common::per_dir_hook "${ARGS[*]}" "$HOOK_ID" "${FILES[@]}"
|
||||||
}
|
}
|
||||||
|
|
||||||
#######################################################################
|
#######################################################################
|
||||||
|
|
|
||||||
|
|
@ -1,6 +1,9 @@
|
||||||
#!/usr/bin/env bash
|
#!/usr/bin/env bash
|
||||||
set -eo pipefail
|
set -eo pipefail
|
||||||
|
|
||||||
|
# globals variables
|
||||||
|
# hook ID, see `- id` for details in .pre-commit-hooks.yaml file
|
||||||
|
readonly HOOK_ID='terragrunt_validate'
|
||||||
# shellcheck disable=SC2155 # No way to assign to readonly variable in separate lines
|
# shellcheck disable=SC2155 # No way to assign to readonly variable in separate lines
|
||||||
readonly SCRIPT_DIR="$(dirname "$(realpath "${BASH_SOURCE[0]}")")"
|
readonly SCRIPT_DIR="$(dirname "$(realpath "${BASH_SOURCE[0]}")")"
|
||||||
# shellcheck source=_common.sh
|
# shellcheck source=_common.sh
|
||||||
|
|
@ -10,7 +13,7 @@ function main {
|
||||||
common::initialize "$SCRIPT_DIR"
|
common::initialize "$SCRIPT_DIR"
|
||||||
common::parse_cmdline "$@"
|
common::parse_cmdline "$@"
|
||||||
# shellcheck disable=SC2153 # False positive
|
# shellcheck disable=SC2153 # False positive
|
||||||
common::per_dir_hook "${ARGS[*]}" "${FILES[@]}"
|
common::per_dir_hook "${ARGS[*]}" "$HOOK_ID" "${FILES[@]}"
|
||||||
}
|
}
|
||||||
|
|
||||||
#######################################################################
|
#######################################################################
|
||||||
|
|
|
||||||
|
|
@ -1,6 +1,9 @@
|
||||||
#!/usr/bin/env bash
|
#!/usr/bin/env bash
|
||||||
set -eo pipefail
|
set -eo pipefail
|
||||||
|
|
||||||
|
# globals variables
|
||||||
|
# hook ID, see `- id` for details in .pre-commit-hooks.yaml file
|
||||||
|
readonly HOOK_ID='terrascan'
|
||||||
# shellcheck disable=SC2155 # No way to assign to readonly variable in separate lines
|
# shellcheck disable=SC2155 # No way to assign to readonly variable in separate lines
|
||||||
readonly SCRIPT_DIR="$(dirname "$(realpath "${BASH_SOURCE[0]}")")"
|
readonly SCRIPT_DIR="$(dirname "$(realpath "${BASH_SOURCE[0]}")")"
|
||||||
# shellcheck source=_common.sh
|
# shellcheck source=_common.sh
|
||||||
|
|
@ -10,7 +13,7 @@ function main {
|
||||||
common::initialize "$SCRIPT_DIR"
|
common::initialize "$SCRIPT_DIR"
|
||||||
common::parse_cmdline "$@"
|
common::parse_cmdline "$@"
|
||||||
# shellcheck disable=SC2153 # False positive
|
# shellcheck disable=SC2153 # False positive
|
||||||
common::per_dir_hook "${ARGS[*]}" "${FILES[@]}"
|
common::per_dir_hook "${ARGS[*]}" "$HOOK_ID" "${FILES[@]}"
|
||||||
}
|
}
|
||||||
|
|
||||||
#######################################################################
|
#######################################################################
|
||||||
|
|
@ -37,4 +40,22 @@ function per_dir_hook_unique_part {
|
||||||
return $exit_code
|
return $exit_code
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#######################################################################
|
||||||
|
# Unique part of `common::per_dir_hook`. The function is executed one time
|
||||||
|
# in the root git repo
|
||||||
|
# Arguments:
|
||||||
|
# args (string with array) arguments that configure wrapped tool behavior
|
||||||
|
#######################################################################
|
||||||
|
function run_hook_on_whole_repo {
|
||||||
|
local -r args="$1"
|
||||||
|
|
||||||
|
# pass the arguments to hook
|
||||||
|
# shellcheck disable=SC2068 # hook fails when quoting is used ("$arg[@]")
|
||||||
|
terrascan scan -i terraform ${args[@]}
|
||||||
|
|
||||||
|
# return exit code to common::per_dir_hook
|
||||||
|
local exit_code=$?
|
||||||
|
return $exit_code
|
||||||
|
}
|
||||||
|
|
||||||
[ "${BASH_SOURCE[0]}" != "$0" ] || main "$@"
|
[ "${BASH_SOURCE[0]}" != "$0" ] || main "$@"
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue