-
-
Notifications
You must be signed in to change notification settings - Fork 583
feat: Add terragrunt_providers_lock hook
#632
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Changes from 10 commits
d1abce1
78fb7a8
5b9e33a
582d87b
3c974c4
8ccb5ef
796df1a
056083a
75a05e8
97a352f
2fda000
4828847
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
|
Collaborator
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. I'm also wondering whether it is worth of 1) re-using tf providers lock per-dir function from tf providers lock hook since
Contributor
Author
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. I also noticed that all three As I know in v2.0 we'll get a bit cleaner code and hope till then @Tensho will provide feedback on actual usage |
| Original file line number | Diff line number | Diff line change |
|---|---|---|
| @@ -0,0 +1,70 @@ | ||
| #!/usr/bin/env bash | ||
| set -eo pipefail | ||
|
|
||
| # globals variables | ||
| # shellcheck disable=SC2155 # No way to assign to readonly variable in separate lines | ||
| readonly SCRIPT_DIR="$(cd "$(dirname "${BASH_SOURCE[0]}")" && pwd -P)" | ||
| # shellcheck source=_common.sh | ||
| . "$SCRIPT_DIR/_common.sh" | ||
|
|
||
| function main { | ||
| common::initialize "$SCRIPT_DIR" | ||
| common::parse_cmdline "$@" | ||
| common::export_provided_env_vars "${ENV_VARS[@]}" | ||
| common::parse_and_export_env_vars | ||
| # JFYI: terragrunt providers lock color already suppressed via PRE_COMMIT_COLOR=never | ||
|
|
||
| # shellcheck disable=SC2153 # False positive | ||
| common::per_dir_hook "$HOOK_ID" "${#ARGS[@]}" "${ARGS[@]}" "${FILES[@]}" | ||
| } | ||
|
|
||
| ####################################################################### | ||
| # Unique part of `common::per_dir_hook`. The function is executed in loop | ||
| # on each provided dir path. Run wrapped tool with specified arguments | ||
| # Arguments: | ||
| # dir_path (string) PATH to dir relative to git repo root. | ||
| # Can be used in error logging | ||
| # change_dir_in_unique_part (string/false) Modifier which creates | ||
| # possibilities to use non-common chdir strategies. | ||
| # Availability depends on hook. | ||
| # parallelism_disabled (bool) if true - skip lock mechanism | ||
| # args (array) arguments that configure wrapped tool behavior | ||
| # Outputs: | ||
| # If failed - print out hook checks status | ||
| ####################################################################### | ||
| function per_dir_hook_unique_part { | ||
| # shellcheck disable=SC2034 # Unused var. | ||
| local -r dir_path="$1" | ||
| # shellcheck disable=SC2034 # Unused var. | ||
| local -r change_dir_in_unique_part="$2" | ||
| # shellcheck disable=SC2034 # Unused var. | ||
| local -r parallelism_disabled="$3" | ||
| shift 3 | ||
| local -a -r args=("$@") | ||
|
|
||
| # pass the arguments to hook | ||
| terragrunt providers lock "${args[@]}" | ||
|
|
||
| # return exit code to common::per_dir_hook | ||
| local 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 (array) arguments that configure wrapped tool behavior | ||
| ####################################################################### | ||
| function run_hook_on_whole_repo { | ||
| local -a -r args=("$@") | ||
|
|
||
| # pass the arguments to hook | ||
| terragrunt run-all providers lock "${args[@]}" | ||
|
|
||
| # return exit code to common::per_dir_hook | ||
| local exit_code=$? | ||
| return $exit_code | ||
| } | ||
|
|
||
| [ "${BASH_SOURCE[0]}" != "$0" ] || main "$@" |
Uh oh!
There was an error while loading. Please reload this page.