Skip to content
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

feat: terrascan - Improve performance during pre-commit --all (-a) run #327

Merged
merged 3 commits into from
Feb 10, 2022
Merged

feat: terrascan - Improve performance during pre-commit --all (-a) run #327

merged 3 commits into from
Feb 10, 2022

Conversation

carlosbustillordguez
Copy link
Contributor

Put an x into the box if that apply:

  • This PR introduces breaking change.
  • This PR fixes a bug.
  • This PR adds new functionality.
  • This PR enhances existing functionality.

Description of your changes

Close #309

How has this code been tested

time pre-commit try-repo --ref 44ae15a https://github.com/carlosbustillordguez/pre-commit-terraform.git terrascan -a
===============================================================================
Using config:
===============================================================================
repos:
-   repo: https://github.com/carlosbustillordguez/pre-commit-terraform.git
    rev: 44ae15a
    hooks:
    -   id: terrascan
===============================================================================

hooks/_common.sh Outdated Show resolved Hide resolved
hooks/terrascan.sh Outdated Show resolved Hide resolved
hooks/_common.sh Show resolved Hide resolved
@carlosbustillordguez
Copy link
Contributor Author

Regarding HOOK_ID read-only global variable, currently is defined for terrascan hook. Should we define it for other hooks?

@MaxymVlasov
Copy link
Collaborator

Regarding HOOK_ID read-only global variable, currently is defined for terrascan hook. Should we define it for other hooks?

Yes, please

@carlosbustillordguez
Copy link
Contributor Author

Regarding HOOK_ID read-only global variable, currently is defined for terrascan hook. Should we define it for other hooks?

Yes, please

Done! Please note that the following hooks are not using the common::per_dir_hook which can consume the HOOK_ID global read-only variable. The variable is defined but not used.

  • infracost_breakdown
  • terraform_docs
  • terraform_fmt
  • terraform_validate

For terraform_docs_replace hook, I didn't add the variable.

Copy link
Collaborator

@yermulnik yermulnik left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

LGTM if @MaxymVlasov approves

Copy link
Owner

@antonbabenko antonbabenko left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Looks very good (I didn't run it)!

I wonder if you can confirm that this change will work with a big repository like this one - https://github.com/terraform-aws-modules/terraform-aws-security-group ? And how much faster will it become?

Another consideration - spaces in the path. It is not often but it happens that people use spaces in the path and we need to make sure it works correctly.

@carlosbustillordguez
Copy link
Contributor Author

carlosbustillordguez commented Feb 3, 2022

Looks very good (I didn't run it)!

Thanks!

I wonder if you can confirm that this change will work with a big repository like this one - https://github.com/terraform-aws-modules/terraform-aws-security-group ? And how much faster will it become?

I tested the suggested repo against the code on this PR:

===============================================================================
Using config:
===============================================================================
repos:
-   repo: https://github.com/carlosbustillordguez/pre-commit-terraform
    rev: 976dc1d
    hooks:
    -   id: terrascan
===============================================================================

Test details:

5 runs 'terrascan PR 327#pullrequestreview-871100755'

time command max min mean median
users seconds 9.31 8.91 9.076 9.05
system seconds 0.45 0.27 0.362 0.37
CPU % 115 108 112 113
Total time 8.6 8.06 8.4 8.4
Run details
  • Test Start: Thu Feb 3 19:04:49 UTC 2022
  • Test End: Thu Feb 3 19:05:31 UTC 2022
Variable name Value
TEST_NUM 5
TEST_COMMAND pre-commit try-repo --ref 976dc1d https://github.com/carlosbustillordguez/pre-commit-terraform terrascan -a
TEST_DIR /home/carlos/testing/pre-commit-terraform-tests/big-module/terraform-aws-security-group
TEST_DESCRIPTION 5 runs 'terrascan PR 327#pullrequestreview-871100755'
RAW_TEST_RESULTS_FILE_NAME terrascan_terraform-aws-security-group

Memory info (head -n 6 /proc/meminfo):

MemTotal:       26032556 kB
MemFree:        20210464 kB
MemAvailable:   23720044 kB
Buffers:          338640 kB
Cached:          3811452 kB
SwapCached:            0 kB

CPU info:

Real procs: 4
Virtual (hyper-threading) procs: 8

processor	: 7
vendor_id	: GenuineIntel
cpu family	: 6
model		: 140
model name	: 11th Gen Intel(R) Core(TM) i7-1165G7 @ 2.80GHz
stepping	: 1
microcode	: 0xffffffff
cpu MHz		: 2803.198
cache size	: 12288 KB
physical id	: 0
siblings	: 8
core id		: 3
cpu cores	: 4
apicid		: 7
initial apicid	: 7
fpu		: yes
fpu_exception	: yes
cpuid level	: 21
wp		: yes
flags		: fpu vme de pse tsc msr pae mce cx8 apic sep mtrr pge mca cmov pat pse36 clflush mmx fxsr sse sse2 ss ht syscall nx pdpe1gb rdtscp lm constant_tsc rep_good nopl xtopology tsc_reliable nonstop_tsc cpuid pni pclmulqdq ssse3 fma cx16 pcid sse4_1 sse4_2 movbe popcnt aes xsave avx f16c rdrand hypervisor lahf_lm abm 3dnowprefetch invpcid_single ssbd ibrs ibpb stibp ibrs_enhanced fsgsbase bmi1 avx2 smep bmi2 erms invpcid avx512f avx512dq rdseed adx smap avx512ifma clflushopt clwb avx512cd sha_ni avx512bw avx512vl xsaveopt xsavec xgetbv1 xsaves avx512vbmi umip avx512_vbmi2 gfni vaes vpclmulqdq avx512_vnni avx512_bitalg avx512_vpopcntdq rdpid fsrm avx512_vp2intersect flush_l1d arch_capabilities
bugs		: spectre_v1 spectre_v2 spec_store_bypass swapgs
bogomips	: 5606.39
clflush size	: 64
cache_alignment	: 64
address sizes	: 39 bits physical, 48 bits virtual
power management:

Test against the current release:

===============================================================================
Using config:
===============================================================================
repos:
-   repo: https://github.com/antonbabenko/pre-commit-terraform
    rev: v1.62.3
    hooks:
    -   id: terrascan
===============================================================================

Test details:

5 runs 'terrascan pre-commit-terraform v1.62.3'

time command max min mean median
users seconds 125.23 122.7 124.432 124.61
system seconds 6.38 5.94 6.2 6.27
CPU % 182 179 181.4 182
Total time 73.18 70.4 71.794 71.74
Run details
  • Test Start: Thu Feb 3 19:19:47 UTC 2022
  • Test End: Thu Feb 3 19:25:46 UTC 2022
Variable name Value
TEST_NUM 5
TEST_COMMAND pre-commit try-repo --ref v1.62.3 https://github.com/antonbabenko/pre-commit-terraform terrascan -a
TEST_DIR /home/carlos/testing/pre-commit-terraform-tests/big-module/terraform-aws-security-group
TEST_DESCRIPTION 5 runs 'terrascan pre-commit-terraform v1.62.3'
RAW_TEST_RESULTS_FILE_NAME terrascan-v1.62.3_terraform-aws-security-group

Memory info (head -n 6 /proc/meminfo):

MemTotal:       26032556 kB
MemFree:        19494044 kB
MemAvailable:   23009248 kB
Buffers:          341248 kB
Cached:          3813972 kB
SwapCached:            0 kB

CPU info:

Real procs: 4
Virtual (hyper-threading) procs: 8

processor	: 7
vendor_id	: GenuineIntel
cpu family	: 6
model		: 140
model name	: 11th Gen Intel(R) Core(TM) i7-1165G7 @ 2.80GHz
stepping	: 1
microcode	: 0xffffffff
cpu MHz		: 2803.198
cache size	: 12288 KB
physical id	: 0
siblings	: 8
core id		: 3
cpu cores	: 4
apicid		: 7
initial apicid	: 7
fpu		: yes
fpu_exception	: yes
cpuid level	: 21
wp		: yes
flags		: fpu vme de pse tsc msr pae mce cx8 apic sep mtrr pge mca cmov pat pse36 clflush mmx fxsr sse sse2 ss ht syscall nx pdpe1gb rdtscp lm constant_tsc rep_good nopl xtopology tsc_reliable nonstop_tsc cpuid pni pclmulqdq ssse3 fma cx16 pcid sse4_1 sse4_2 movbe popcnt aes xsave avx f16c rdrand hypervisor lahf_lm abm 3dnowprefetch invpcid_single ssbd ibrs ibpb stibp ibrs_enhanced fsgsbase bmi1 avx2 smep bmi2 erms invpcid avx512f avx512dq rdseed adx smap avx512ifma clflushopt clwb avx512cd sha_ni avx512bw avx512vl xsaveopt xsavec xgetbv1 xsaves avx512vbmi umip avx512_vbmi2 gfni vaes vpclmulqdq avx512_vnni avx512_bitalg avx512_vpopcntdq rdpid fsrm avx512_vp2intersect flush_l1d arch_capabilities
bugs		: spectre_v1 spectre_v2 spec_store_bypass swapgs
bogomips	: 5606.39
clflush size	: 64
cache_alignment	: 64
address sizes	: 39 bits physical, 48 bits virtual
power management:

From the above results, we can see that the code of this PR has a significant improvement (x8 faster) compared with the current release (v1.62.3).

Another consideration - spaces in the path. It is not often but it happens that people use spaces in the path and we need to make sure it works correctly.

I made a test as follows:

TEST_NUM=5
TEST_DIR='/home/carlos/testing/pre-commit-terraform-tests/big module with spaces/terraform-aws-security-group'
TEST_DESCRIPTION='`terrascan` PR 327#pullrequestreview-871100755 with spaces in the path'
RAW_TEST_RESULTS_FILE_NAME='terrascan_terraform-aws-security-group-spaces_in_the_path'

TEST_COMMAND="pre-commit try-repo --ref 976dc1d https://github.com/carlosbustillordguez/pre-commit-terraform terrascan -a"

./hooks_performance_test.sh "$TEST_NUM" "$TEST_COMMAND" "$TEST_DIR" "$TEST_DESCRIPTION" "$RAW_TEST_RESULTS_FILE_NAME"

and it works, but I am not sure is a valid test because the path with spaces is inside simple quotes...

Also, I ran pre-commit from a path with spaces and it works:

 ~/testing/pre-commit-terraform-tests/big module with spaces/terraform-aws-security-group   master 
 pre-commit try-repo --ref 976dc1d https://github.com/carlosbustillordguez/pre-commit-terraform.git terrascan -a
===============================================================================
Using config:
===============================================================================
repos:
-   repo: https://github.com/carlosbustillordguez/pre-commit-terraform.git
    rev: 976dc1d
    hooks:
    -   id: terrascan
===============================================================================
...
Scan Summary -

        File/Folder         :   /home/carlos/testing/pre-commit-terraform-tests/big module with spaces/terraform-aws-security-group
        IaC Type            :   terraform
        Scanned At          :   2022-02-03 20:03:52.091596863 +0000 UTC
        Policies Validated  :   50
        Violated Policies   :   13
        Low                 :   1
        Medium              :   0
        High                :   12

Please, note a path with spaces in the "Scan Summary".

Copy link
Collaborator

@MaxymVlasov MaxymVlasov left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Works fine.
Ready to merge, @antonbabenko

@antonbabenko antonbabenko merged commit 7e7c916 into antonbabenko:master Feb 10, 2022
antonbabenko pushed a commit that referenced this pull request Feb 10, 2022
# [1.63.0](v1.62.3...v1.63.0) (2022-02-10)

### Features

* Improve performance during `pre-commit --all (-a)` run ([#327](#327)) ([7e7c916](7e7c916))
@antonbabenko
Copy link
Owner

This PR is included in version 1.63.0 🎉

@MaxymVlasov MaxymVlasov changed the title feat: Improve performance during pre-commit --all (-a) run feat: terrascan: Improve performance during pre-commit --all (-a) run Feb 10, 2022
@MaxymVlasov MaxymVlasov changed the title feat: terrascan: Improve performance during pre-commit --all (-a) run feat: terrascan - Improve performance during pre-commit --all (-a) run Feb 10, 2022
@carlosbustillordguez carlosbustillordguez deleted the 309-improve-perfomance-during-pre-commit-all branch February 10, 2022 16:06
mrwacky42 added a commit to HeadspaceMeditation/pre-commit-terraform that referenced this pull request Feb 15, 2022
* Added terraform-docs integration (#13)

* Add hook to create readme

* Updated README

* Run terraform_docs only if README.md is present

* Run terraform_docs only if README.md is present

* Fixes use of md5 for tempfile name (#16)

* Replace terraform_docs use of GNU sed with perl (#15)

* Fix ShellCheck warning 2219

https://github.com/koalaman/shellcheck/wiki/SC2219

* Replace GNU sed commands with perl

This replaces the sed commands which required GNU sed be installed with
perl versions. This should make this script more universally usable
(e.g., on macOS) without installing additional tools.

* Only run validate if .tf files exist in the directory. (antonbabenko#20)

* Only run validate if .tf files exist in the directory.

* Same fix, different script :)

* Updated README

* Added license file (fixed antonbabenko#21)

* Add feature to pass options to terraform-docs.

* Added followup after antonbabenko#25

* Add new hook for running terraform-docs with replacing README.md from doc in main.tf

* Address requested changes

* Add `--dest` argument

* Address requested changes

* fix typo

* Fix bug not letting terraform_docs_replace work in the root directory of a repo

* Require terraform-docs runs in serial to avoid pre-commit doing parallel operations on similar file paths

* Added chglog (hi @robinbowes :))

* Added CHANGELOG.md

* Add exit code for 'terraform validate' so pre-commit check fails (antonbabenko#34)

* Bump new version

* fix check for errors at the end (antonbabenko#35)

* Updated changelog

* Update README.md (antonbabenko#36)

* Fixed broken "maintained badge"

* Added note about incompatibility of terraform-docs with Terraform 0.12 (antonbabenko#41)

* Updated CHANGELOG

* Added support for terraform_docs for Terraform 0.12 (antonbabenko#45)

* Updated CHANGELOG

* Upgraded to work with Terraform >= 0.12 (antonbabenko#44)

* Updated CHANGELOG

* Fix version in README.md (antonbabenko#46)

* Fixed awk script for terraform-docs (kudos @cytopia) and mktemp on Mac (closes antonbabenko#47, antonbabenko#48, antonbabenko#49)

* Updated CHANGELOG

* Add slash to mktemp dir (fixed antonbabenko#50)

* Updated CHANGELOG

* Fix typo in README (antonbabenko#51)

* Fixed enquoted types in terraform_docs (fixed antonbabenko#52)

* Updated CHANGELOG

* Formatter for Terragrunt HCL files (antonbabenko#60)

* Formatter for Terragrunt HCL files

* Adding Terragrunt documentation

* Updated README with terragrunt_fmt hook

* Updated CHANGELOG

* Added support for TFLint with --deep parameter (antonbabenko#53)

Added support for TFLint (https://github.com/wata727/tflint).

Signed-off-by: Costin Galan <[email protected]>

* Updated README with terraform_tflint hook

* Updated CHANGELOG

* Update rev in README.md (antonbabenko#70)

Updating the version in the README.

In order for `terraform_tflint`, the rev must be at least `v1.19.0`.

* Improve installation instructions and make README more readable (antonbabenko#72)

* Added FUNDING.yml

* Fixes antonbabenko#65: terraform-docs should not fail if complex types contain 'description' keyword (antonbabenko#73)

* Updated CHANGELOG

* use getopt for args in the tflint hook, following the approach in terraform-docs (antonbabenko#75)

* Updated CHANGELOG

* move terraform-docs args after markdown command (antonbabenko#83)

* Updated CHANGELOG

* Added support for terraform-docs 0.8.0 with proper support for Terraform 0.12 syntax (bye-bye awk) (antonbabenko#85)

* Updated CHANGELOG

* Added shfmt to autoformat shell scripts (antonbabenko#86)

* Updated CHANGELOG

* Fixed tflint hook to iterate over files (antonbabenko#77)

* Updated CHANGELOG

* Fixed exit code for terraform 0.11 branch in terraform_docs (antonbabenko#94)

* Updated pre-commit-hooks

* Updated CHANGELOG

* corrected tflint documentation (antonbabenko#95)

* Updated CHANGELOG

* Update installation instructions (antonbabenko#79)

- Fix package name misspell
- TFlint migrate to another organization

* Allow passing multiple args to terraform-docs (antonbabenko#98)

* Updated CHANGELOG

* fix: Change terraform_validate hook functionality for subdirectories with terraform files (antonbabenko#100)

* Update terraform_validate.sh:
-Change to the directory before running terraform validate to use the Terraform
 configuration for the appropriate working directory.

* Neglected to change the terraform validate call to use the default of the
current directory.

* Several changes to improve functionality:
- Switch to checking the path for '*.tf' instead of always checking the current
  directory.
- Try to find a '.terraform' directory (which indicates a `terraform init`) and
  change to that directory before running `terraform validate`.

* Fix the description for the terraform_validate hook to reflect changes that were
made in:
antonbabenko@35e0356

* - Clean up comments.
- Adjust variable names to better reflect what they are holding.

* Updated CHANGELOG

* feat: Support for TFSec (antonbabenko#103)

* Updated pre-commit deps

* Updated CHANGELOG

* docs: Added coreutils as requirements in README.md (antonbabenko#105)

* docs: Fixed the docs to use the latest config syntax(antonbabenko#106)

* fix: Updated formatting in README (closes antonbabenko#113)

* Updated CHANGELOG

* feat: add terragrunt validate hook (antonbabenko#134)

* Updated CHANGELOG

* docs: Update terraform-docs link pointing to new organization (antonbabenko#130)

* fix: Pass args and env vars to terraform validate (antonbabenko#125)

* Updated CHANGELOG

* chore: Use lib_getopt for all hooks and some style tweaks (antonbabenko#137)

* Updated CHANGELOG

* fix: Squash terraform_docs bug (antonbabenko#138)

* Updated CHANGELOG

* feat: have option for terraform_tfsec hook to only run in relevant modified directories (antonbabenko#135)

* Updated CHANGELOG

* fix: make terraform_tfsec.sh executable (antonbabenko#140)

* Updated CHANGELOG

* fix: Correctly handle arrays in terraform_docs.sh (antonbabenko#141)

* Updated CHANGELOG

* feat: Add checkov support (antonbabenko#143)

* Updated CHANGELOG

* feat: Add possibility to share tflint config file for subdirs (antonbabenko#149)

* Updated CHANGELOG

* fix: terraform-docs version 0.10 removed with-aggregate-type-defaults (antonbabenko#150)

* Updated CHANGELOG

* fix: make terraform_docs Windows compatible (antonbabenko#129)

* Updated CHANGELOG

* fix: Fix regex considering terraform-docs v0.10.0 old (antonbabenko#151)

* Updated CHANGELOG

* feat: Make terraform_validate to run init if necessary (antonbabenko#158)

* Updated CHANGELOG

* fix: Correct deprecated parameter to terraform-docs (antonbabenko#156)

* Updated CHANGELOG

* update to upstream hooks

* just report, do not error

* fix: Terraform validate for submodules (antonbabenko#172)

* Updated CHANGELOG

* docs: updates installs for macOS and ubuntu (antonbabenko#175)

* fix: remove sed postprocessing from the terraform_docs_replace hook to fix compatibility with terraform-docs 0.11.0+ (antonbabenko#176)

* Updated CHANGELOG

* docs: Added checkov install (antonbabenko#182)

* chore: add dockerfile (antonbabenko#183)

* Updated CHANGELOG

* Update README.md

* chore: Fix mistake on command (antonbabenko#185)

* fix: Fix and pin versions in Dockerfile (antonbabenko#193)

* Updated CHANGELOG

* feat: Adds support for Terrascan (antonbabenko#195)

* Updated CHANGELOG

* chore: Update Ubuntu install method (antonbabenko#198)

* docs: Initial docs improvement (antonbabenko#218)

* fix: Dockerized pre-commit-terraform (antonbabenko#219)

Co-authored-by: Anton Babenko <[email protected]>

* feat: Add mixed line ending check to prevent possible errors (antonbabenko#221)

* feat: Add GH checks and templates (antonbabenko#222)

* chore: Updated GH stale action config (antonbabenko#223)

* fix: label auto-adding after label rename (antonbabenko#226)

* fix: trigger terraform-docs on changes in lock files (antonbabenko#228)

* Updated CHANGELOG

* fix: remove dead code from terraform-docs script (antonbabenko#229)

* chore: Add shfmt to workflow (antonbabenko#231)

* docs: Describe hooks usage and improve examples (antonbabenko#232)

Co-authored-by: Anton Babenko <[email protected]>

* fix: Dockerfile if INSTALL_ALL is not defined (antonbabenko#233)

* feat: Add PATH outputs when TFLint found any problem (antonbabenko#234)

* fix: terraform_tflint hook executes in a serial way to run less often (antonbabenko#211)

* docs: Add contributing guide and docs about performance tests (antonbabenko#235)

* docs: Make contributors more visible (antonbabenko#236)

* docs: Document terraform_tfsec args usage (antonbabenko#238)

* feat: Add new hook for `terraform providers lock` operation (antonbabenko#173)

* Updated CHANGELOG

* chore: Do not mark issues and PR's in milestone as stale (antonbabenko#241)

* fix: TFSec outputs the same results multiple times (antonbabenko#237)

* docs: Add terraform_fmt usage instructions and how-to debug script with args (antonbabenko#242)

* feat: Allow passing of args to terraform_fmt (antonbabenko#147)

* docs: Document hooks dependencies (antonbabenko#247)

* feat: Add support for specify terraform-docs config file (antonbabenko#244)

* fix: terrafrom_tflint ERROR output for files located in repo root (antonbabenko#243)

* feat: Add `terraform_docs` hook settings (antonbabenko#245)

* docs: fix deps (antonbabenko#249)

* fix: execute tflint once in no errors (antonbabenko#250)

* fix: command not found (antonbabenko#251)

* docs: Add missing space in terrascan install cmd (antonbabenko#253)

* feat: add __GIT_WORKING_DIR__ to tfsec (antonbabenko#255)

* docs: fix protocol to prevent MITM (antonbabenko#257)

* feat: Set up PR reviewers automatically (antonbabenko#258)

* feat: Add infracost_breakdown hook (antonbabenko#252)

* docs: Clarify docs for terraform_tfsec hook (antonbabenko#266)

* docs: Pre-release 1.53 (antonbabenko#267)

* Updated CHANGELOG

* fix: Fixed args expand in terraform_docs (antonbabenko#260)

* docs: Added notes about sponsors (antonbabenko#268)

* feat: Add support for quoted values in `infracost_breakdown` `--hook-config` (antonbabenko#269)

* Updated CHANGELOG

* fix: Fixed 1.54.0 where `terraform_docs` was broken (antonbabenko#272)

* Updated CHANGELOG

* chore: Updated messages shown in terraform_tflint hook (antonbabenko#274)

* feat: Updated Docker image from Ubuntu to Alpine (antonbabenko#278)

* Updated CHANGELOG

* chore: Add deprecation notice to `terraform_docs_replace` (antonbabenko#280)

* fix: typo in arg name for terraform-docs (antonbabenko#283)

* Updated CHANGELOG

* chore: Fix master merge to working branch on pre-commit autofixes (antonbabenko#286)

* chore: Publish container image on release (antonbabenko#285)

* Updated CHANGELOG

* fix: Fixed docker build (antonbabenko#288)

* Updated CHANGELOG

* fix: pre-build docker image (antonbabenko#292)

* Updated CHANGELOG

* fix: analyse all folders with tflint and don't stop on first execution (antonbabenko#289)

* feat: Pass custom arguments to terraform init in `terraform_validate` hook (antonbabenko#293)

* Updated CHANGELOG

* feat: Added semantic release (antonbabenko#296)

* chore(release): version 1.62.0 [skip ci]

# [1.62.0](antonbabenko/pre-commit-terraform@v1.61.0...v1.62.0) (2021-12-12)

### Features

* Added semantic release ([antonbabenko#296](antonbabenko#296)) ([1bcca44](antonbabenko@1bcca44))

* chore: Validate PR title (antonbabenko#297)

* chore: Updated validation PR title types (antonbabenko#298)

* chore: Fixed allowed types for PR titles

* chore: Publish container image only after the release

* fix(terraform_tflint): Restore current working directory behavior (antonbabenko#302)

* chore: Use valid token for the Release GHA

* chore(release): version 1.62.1 [skip ci]

## [1.62.1](antonbabenko/pre-commit-terraform@v1.62.0...v1.62.1) (2021-12-18)

### Bug Fixes

* **terraform_tflint:** Restore current working directory behavior ([antonbabenko#302](antonbabenko#302)) ([93029dc](antonbabenko@93029dc))

* fix: Properly exclude .terraform directory with checkov hook (antonbabenko#306)

* fix: Speedup `terrascan` hook up to x3 times in big repos (antonbabenko#307)

* chore: Release action should track hooks configuration changes (antonbabenko#308)

* chore(release): version 1.62.2 [skip ci]

## [1.62.2](antonbabenko/pre-commit-terraform@v1.62.1...v1.62.2) (2021-12-21)

### Bug Fixes

* Properly exclude .terraform directory with checkov hook ([antonbabenko#306](antonbabenko#306)) ([b431a43](antonbabenko@b431a43))
* Speedup `terrascan` hook up to x3 times in big repos ([antonbabenko#307](antonbabenko#307)) ([2e8dcf9](antonbabenko@2e8dcf9))

* fix: Check all directories with changes and pass all args in terrascan hook (antonbabenko#305)

* chore(release): version 1.62.3 [skip ci]

## [1.62.3](antonbabenko/pre-commit-terraform@v1.62.2...v1.62.3) (2021-12-22)

### Bug Fixes

* Check all directories with changes and pass all args in terrascan hook ([antonbabenko#305](antonbabenko#305)) ([66401d9](antonbabenko@66401d9))

* chore: Refactor all hooks (antonbabenko#310)

* chore: Cleanup file with test data (antonbabenko#311)

* chore: Add shellcheck and make checks passing (antonbabenko#315)

Co-authored-by: Anton Babenko <[email protected]>

* chore: Improved code structure (moved hooks into a separate dir) (antonbabenko#316)

* chore: Specify what we exactly mean (antonbabenko#320)

* chore: Document functions (based on google style guide) (antonbabenko#317)

* chore: Add hadolint check for Dockerfiles (antonbabenko#322)

Co-authored-by: Balazs Hamorszky <[email protected]>

* chore: Add Github Actions Workflow to build if Dockerfile updated (antonbabenko#318)

Co-authored-by: Maksym Vlasov <[email protected]>

* docs: Add workaround for configuration_aliases tf bug (antonbabenko#332)

* chore: fix bug intoduced in antonbabenko#316 (antonbabenko#335)

* feat: Improve performance during `pre-commit --all (-a)` run (antonbabenko#327)

* chore(release): version 1.63.0 [skip ci]

# [1.63.0](antonbabenko/pre-commit-terraform@v1.62.3...v1.63.0) (2022-02-10)

### Features

* Improve performance during `pre-commit --all (-a)` run ([antonbabenko#327](antonbabenko#327)) ([7e7c916](antonbabenko@7e7c916))

* feat: Improved speed of `pre-commit run -a` for multiple hooks (antonbabenko#338)

* chore(release): version 1.64.0 [skip ci]

# [1.64.0](antonbabenko/pre-commit-terraform@v1.63.0...v1.64.0) (2022-02-10)

### Features

* Improved speed of `pre-commit run -a` for multiple hooks ([antonbabenko#338](antonbabenko#338)) ([579dc45](antonbabenko@579dc45))

* chore: Fix docker test workflow (antonbabenko#340)

* chore: Add Docker latest and nightly tag (antonbabenko#343)

Co-authored-by: Anton Babenko <[email protected]>
Co-authored-by: jeremy avnet <[email protected]>
Co-authored-by: Robin Bowes <[email protected]>
Co-authored-by: Martin Etmajer <[email protected]>
Co-authored-by: rothandrew <[email protected]>
Co-authored-by: Chris Gilmer <[email protected]>
Co-authored-by: Josiah Halme <[email protected]>
Co-authored-by: Tyler Christiansen <[email protected]>
Co-authored-by: Guido Dobboletta <[email protected]>
Co-authored-by: Paweł Szczepaniak <[email protected]>
Co-authored-by: Leonhardt Wille <[email protected]>
Co-authored-by: Eric Gonzales <[email protected]>
Co-authored-by: Scott Crooks <[email protected]>
Co-authored-by: Costin GALAN <[email protected]>
Co-authored-by: Dave Gallant <[email protected]>
Co-authored-by: Maksym Vlasov <[email protected]>
Co-authored-by: cytopia <[email protected]>
Co-authored-by: chopped pork <[email protected]>
Co-authored-by: Thierno IB. BARRY <[email protected]>
Co-authored-by: Konstantin Kirpichnikov <[email protected]>
Co-authored-by: Robson Roberto Souza Peixoto <[email protected]>
Co-authored-by: Martin Coxall <[email protected]>
Co-authored-by: Sergei Ivanov <[email protected]>
Co-authored-by: Nick M <[email protected]>
Co-authored-by: Jon Proietti <[email protected]>
Co-authored-by: gchappell99 <[email protected]>
Co-authored-by: snolan-uturn <[email protected]>
Co-authored-by: Prahalad Ramji <[email protected]>
Co-authored-by: Khosrow Moossavi <[email protected]>
Co-authored-by: nkazarian-spokeo <[email protected]>
Co-authored-by: Matias Zilli <[email protected]>
Co-authored-by: Evan Stoddard <[email protected]>
Co-authored-by: Shawn <[email protected]>
Co-authored-by: Manuel Vogel <[email protected]>
Co-authored-by: Sergio Kef <[email protected]>
Co-authored-by: Cesar Rodriguez <[email protected]>
Co-authored-by: Lorenz Vanthillo <[email protected]>
Co-authored-by: balihb <[email protected]>
Co-authored-by: Javier Collado <[email protected]>
Co-authored-by: Dan Arnold <[email protected]>
Co-authored-by: gravitybacklight <[email protected]>
Co-authored-by: Milos Jajac <[email protected]>
Co-authored-by: Birger J. Nordølum <[email protected]>
Co-authored-by: sg70 <[email protected]>
Co-authored-by: Bruno Ferreira <[email protected]>
Co-authored-by: Maxime Brunet <[email protected]>
Co-authored-by: semantic-release-bot <[email protected]>
Co-authored-by: Maxime Brunet <[email protected]>
Co-authored-by: Carlos Miguel Bustillo Rodríguez <[email protected]>
Co-authored-by: Mohit Saxena <[email protected]>
Co-authored-by: Mark Bainter <[email protected]>
Co-authored-by: Pasquale De Vita <[email protected]>
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

Improve perfomance during pre-commit --all (-a) run
4 participants