From 9cb4c33715a74049e63a15df1906b97671b596b2 Mon Sep 17 00:00:00 2001 From: Lucas Gravley <29484535+admiralAwkbar@users.noreply.github.com> Date: Wed, 22 Jul 2020 14:07:08 -0500 Subject: [PATCH 1/7] found the missing link --- .automation/test/cfn/reports/expected-CFN.tap | 22 ---- .../test/{cfn => cloudformation}/README.md | 0 .../cloudformation_bad_1.json} | 0 .../cloudformation_bad_2.yaml} | 0 .../cloudformation_bad_3.json} | 0 .../cloudformation_bad_4.yaml} | 0 .../cloudformation_good_1.json} | 0 .../cloudformation_good_2.yaml} | 0 .../cloudformation_good_3.json} | 0 .../cloudformation_good_4.yaml} | 0 .../reports/expected-CLOUDFORMATION.tap | 22 ++++ Dockerfile | 1 + docs/disabling-linters.md | 2 +- lib/buildFileList.sh | 10 +- lib/linter.sh | 118 +++++++++--------- lib/validation.sh | 21 ++++ lib/worker.sh | 2 +- 17 files changed, 110 insertions(+), 88 deletions(-) delete mode 100644 .automation/test/cfn/reports/expected-CFN.tap rename .automation/test/{cfn => cloudformation}/README.md (100%) rename .automation/test/{cfn/cfn_bad_1.json => cloudformation/cloudformation_bad_1.json} (100%) rename .automation/test/{cfn/cfn_bad_2.yaml => cloudformation/cloudformation_bad_2.yaml} (100%) rename .automation/test/{cfn/cfn_bad_3.json => cloudformation/cloudformation_bad_3.json} (100%) rename .automation/test/{cfn/cfn_bad_4.yaml => cloudformation/cloudformation_bad_4.yaml} (100%) rename .automation/test/{cfn/cfn_good_1.json => cloudformation/cloudformation_good_1.json} (100%) rename .automation/test/{cfn/cfn_good_2.yaml => cloudformation/cloudformation_good_2.yaml} (100%) rename .automation/test/{cfn/cfn_good_3.json => cloudformation/cloudformation_good_3.json} (100%) rename .automation/test/{cfn/cfn_good_4.yaml => cloudformation/cloudformation_good_4.yaml} (100%) create mode 100644 .automation/test/cloudformation/reports/expected-CLOUDFORMATION.tap diff --git a/.automation/test/cfn/reports/expected-CFN.tap b/.automation/test/cfn/reports/expected-CFN.tap deleted file mode 100644 index 98466237..00000000 --- a/.automation/test/cfn/reports/expected-CFN.tap +++ /dev/null @@ -1,22 +0,0 @@ -TAP version 13 -1..8 -not ok 1 - cfn_bad_1.json - --- - message: E3001 Invalid or unsupported Type AWS Route53 HostedZonee for resource DNS in us-east-1\n/tmp/lint/.automation/test/cfn/cfn_bad_1.json 6 10\n - ... -not ok 2 - cfn_bad_2.yaml - --- - message: E3001 Invalid or unsupported Type AWS Route53 HostedZonee for resource DNS in us-east-1\n/tmp/lint/.automation/test/cfn/cfn_bad_2.yaml 5 5\n - ... -not ok 3 - cfn_bad_3.json - --- - message: E3002 Invalid Property Resources/myDNSRecord/Properties/Ttl\n/tmp/lint/.automation/test/cfn/cfn_bad_3.json 11 13\n - ... -not ok 4 - cfn_bad_4.yaml - --- - message: E3002 Invalid Property Resources/myDNSRecord/Properties/Ttl\n/tmp/lint/.automation/test/cfn/cfn_bad_4.yaml 9 7\n - ... -ok 5 - cfn_good_1.json -ok 6 - cfn_good_2.yaml -ok 7 - cfn_good_3.json -ok 8 - cfn_good_4.yaml diff --git a/.automation/test/cfn/README.md b/.automation/test/cloudformation/README.md similarity index 100% rename from .automation/test/cfn/README.md rename to .automation/test/cloudformation/README.md diff --git a/.automation/test/cfn/cfn_bad_1.json b/.automation/test/cloudformation/cloudformation_bad_1.json similarity index 100% rename from .automation/test/cfn/cfn_bad_1.json rename to .automation/test/cloudformation/cloudformation_bad_1.json diff --git a/.automation/test/cfn/cfn_bad_2.yaml b/.automation/test/cloudformation/cloudformation_bad_2.yaml similarity index 100% rename from .automation/test/cfn/cfn_bad_2.yaml rename to .automation/test/cloudformation/cloudformation_bad_2.yaml diff --git a/.automation/test/cfn/cfn_bad_3.json b/.automation/test/cloudformation/cloudformation_bad_3.json similarity index 100% rename from .automation/test/cfn/cfn_bad_3.json rename to .automation/test/cloudformation/cloudformation_bad_3.json diff --git a/.automation/test/cfn/cfn_bad_4.yaml b/.automation/test/cloudformation/cloudformation_bad_4.yaml similarity index 100% rename from .automation/test/cfn/cfn_bad_4.yaml rename to .automation/test/cloudformation/cloudformation_bad_4.yaml diff --git a/.automation/test/cfn/cfn_good_1.json b/.automation/test/cloudformation/cloudformation_good_1.json similarity index 100% rename from .automation/test/cfn/cfn_good_1.json rename to .automation/test/cloudformation/cloudformation_good_1.json diff --git a/.automation/test/cfn/cfn_good_2.yaml b/.automation/test/cloudformation/cloudformation_good_2.yaml similarity index 100% rename from .automation/test/cfn/cfn_good_2.yaml rename to .automation/test/cloudformation/cloudformation_good_2.yaml diff --git a/.automation/test/cfn/cfn_good_3.json b/.automation/test/cloudformation/cloudformation_good_3.json similarity index 100% rename from .automation/test/cfn/cfn_good_3.json rename to .automation/test/cloudformation/cloudformation_good_3.json diff --git a/.automation/test/cfn/cfn_good_4.yaml b/.automation/test/cloudformation/cloudformation_good_4.yaml similarity index 100% rename from .automation/test/cfn/cfn_good_4.yaml rename to .automation/test/cloudformation/cloudformation_good_4.yaml diff --git a/.automation/test/cloudformation/reports/expected-CLOUDFORMATION.tap b/.automation/test/cloudformation/reports/expected-CLOUDFORMATION.tap new file mode 100644 index 00000000..a92e9775 --- /dev/null +++ b/.automation/test/cloudformation/reports/expected-CLOUDFORMATION.tap @@ -0,0 +1,22 @@ +TAP version 13 +1..8 +not ok 1 - cloudformation_bad_1.json + --- + message: E3001 Invalid or unsupported Type AWS Route53 HostedZonee for resource DNS in us-east-1\n/tmp/lint/.automation/test/cloudformation/cloudformation_bad_1.json 6 10\n + ... +not ok 2 - cloudformation_bad_2.yaml + --- + message: E3001 Invalid or unsupported Type AWS Route53 HostedZonee for resource DNS in us-east-1\n/tmp/lint/.automation/test/cloudformation/cloudformation_bad_2.yaml 5 5\n + ... +not ok 3 - cloudformation_bad_3.json + --- + message: E3002 Invalid Property Resources/myDNSRecord/Properties/Ttl\n/tmp/lint/.automation/test/cloudformation/cloudformation_bad_3.json 11 13\n + ... +not ok 4 - cloudformation_bad_4.yaml + --- + message: E3002 Invalid Property Resources/myDNSRecord/Properties/Ttl\n/tmp/lint/.automation/test/cloudformation/cloudformation_bad_4.yaml 9 7\n + ... +ok 5 - cloudformation_good_1.json +ok 6 - cloudformation_good_2.yaml +ok 7 - cloudformation_good_3.json +ok 8 - cloudformation_good_4.yaml diff --git a/Dockerfile b/Dockerfile index 32964e48..cf48d8c7 100644 --- a/Dockerfile +++ b/Dockerfile @@ -209,6 +209,7 @@ ENV ACTIONS_RUNNER_DEBUG=${ACTIONS_RUNNER_DEBUG} \ VALIDATE_ARM=${VALIDATE_ARM} \ VALIDATE_BASH=${VALIDATE_BASH} \ VALIDATE_CLOJURE=${VALIDATE_CLOJURE} \ + VALIDATE_CLOUDFORMATION=${VALIDATE_CLOUDFORMATION} \ VALIDATE_COFFEE=${VALIDATE_COFFEE} \ VALIDATE_CSS=${VALIDATE_CSS} \ VALIDATE_DART=${VALIDATE_DART} \ diff --git a/docs/disabling-linters.md b/docs/disabling-linters.md index 858966a0..fb19256e 100644 --- a/docs/disabling-linters.md +++ b/docs/disabling-linters.md @@ -18,7 +18,7 @@ For some linters it is also possible to override rules on a case by case level w - [Shell](#shell) - [Ansible](#ansible) - [YAML](#yaml) -- [AWS CloudFormation templates](#cfn) +- [AWS CloudFormation templates](#aws-cloud-formation) - [Python](#python3) - [JSON](#json) - [Markdown](#markdown) diff --git a/lib/buildFileList.sh b/lib/buildFileList.sh index 915ddcfa..2627238c 100755 --- a/lib/buildFileList.sh +++ b/lib/buildFileList.sh @@ -99,9 +99,9 @@ function BuildFileList() { ######### #echo "FILE_TYPE:[${FILE_TYPE}]" - ##################### - # Get the CFN files # - ##################### + ################################ + # Get the CLOUDFORMATION files # + ################################ if [ "${FILE_TYPE}" == "yml" ] || [ "${FILE_TYPE}" == "yaml" ]; then ################################ # Append the file to the array # @@ -119,7 +119,7 @@ function BuildFileList() { ################################ # Append the file to the array # ################################ - FILE_ARRAY_CFN+=("${FILE}") + FILE_ARRAY_CLOUDFORMATION+=("${FILE}") ########################################################## # Set the READ_ONLY_CHANGE_FLAG since this could be exec # @@ -159,7 +159,7 @@ function BuildFileList() { ################################ # Append the file to the array # ################################ - FILE_ARRAY_CFN+=("${FILE}") + FILE_ARRAY_CLOUDFORMATION+=("${FILE}") fi ############################################ # Check if the file is AWS States Language # diff --git a/lib/linter.sh b/lib/linter.sh index c489a260..516c9d3c 100755 --- a/lib/linter.sh +++ b/lib/linter.sh @@ -22,71 +22,71 @@ source /action/lib/worker.sh # Source the function script(s) # GLOBALS # ########### # Default Vars -DEFAULT_RULES_LOCATION='/action/lib/.automation' # Default rules files location +DEFAULT_RULES_LOCATION='/action/lib/.automation' # Default rules files location # Ansible Vars -ANSIBLE_FILE_NAME='.ansible-lint.yml' # Name of the file -ANSIBLE_LINTER_RULES="${DEFAULT_RULES_LOCATION}/${ANSIBLE_FILE_NAME}" # Path to the Ansible lint rules +ANSIBLE_FILE_NAME='.ansible-lint.yml' # Name of the file +ANSIBLE_LINTER_RULES="${DEFAULT_RULES_LOCATION}/${ANSIBLE_FILE_NAME}" # Path to the Ansible lint rules # Azure Resource Manager Vars -ARM_FILE_NAME='.arm-ttk.psd1' # Name of the file -ARM_LINTER_RULES="${DEFAULT_RULES_LOCATION}/${ARM_FILE_NAME}" # Path to the ARM lint rules +ARM_FILE_NAME='.arm-ttk.psd1' # Name of the file +ARM_LINTER_RULES="${DEFAULT_RULES_LOCATION}/${ARM_FILE_NAME}" # Path to the ARM lint rules # Cloudformation Vars -CFN_FILE_NAME='.cfnlintrc.yml' # Name of the file -CFN_LINTER_RULES="${DEFAULT_RULES_LOCATION}/${CFN_FILE_NAME}" # Path to the cloudformation lint rules +CLOUDFORMATION_FILE_NAME='.cfnlintrc.yml' # Name of the file +CLOUDFORMATION_LINTER_RULES="${DEFAULT_RULES_LOCATION}/${CLOUDFORMATION_FILE_NAME}" # Path to the cloudformation lint rules # Clojure Vars -CLOJURE_FILE_NAME='.clj-kondo/config.edn' # Name of the file -CLOJURE_LINTER_RULES="${DEFAULT_RULES_LOCATION}/${CLOJURE_FILE_NAME}" # Path to the Clojure lint rules +CLOJURE_FILE_NAME='.clj-kondo/config.edn' # Name of the file +CLOJURE_LINTER_RULES="${DEFAULT_RULES_LOCATION}/${CLOJURE_FILE_NAME}" # Path to the Clojure lint rules # Coffee Vars -COFFEE_FILE_NAME='.coffee-lint.json' # Name of the file -COFFEESCRIPT_LINTER_RULES="${DEFAULT_RULES_LOCATION}/${COFFEE_FILE_NAME}" # Path to the coffeescript lint rules +COFFEE_FILE_NAME='.coffee-lint.json' # Name of the file +COFFEESCRIPT_LINTER_RULES="${DEFAULT_RULES_LOCATION}/${COFFEE_FILE_NAME}" # Path to the coffeescript lint rules # CSS Vars -CSS_FILE_NAME='.stylelintrc.json' # Name of the file -CSS_LINTER_RULES="${DEFAULT_RULES_LOCATION}/${CSS_FILE_NAME}" # Path to the CSS lint rules +CSS_FILE_NAME='.stylelintrc.json' # Name of the file +CSS_LINTER_RULES="${DEFAULT_RULES_LOCATION}/${CSS_FILE_NAME}" # Path to the CSS lint rules # Dart Vars -DART_FILE_NAME='analysis_options.yaml' # Name of the file -DART_LINTER_RULES="${DEFAULT_RULES_LOCATION}/${DART_FILE_NAME}" # Path to the DART lint rules +DART_FILE_NAME='analysis_options.yaml' # Name of the file +DART_LINTER_RULES="${DEFAULT_RULES_LOCATION}/${DART_FILE_NAME}" # Path to the DART lint rules # Docker Vars -DOCKER_FILE_NAME='.dockerfilelintrc' # Name of the file -DOCKER_LINTER_RULES="${DEFAULT_RULES_LOCATION}/${DOCKER_FILE_NAME}" # Path to the Docker lint rules +DOCKER_FILE_NAME='.dockerfilelintrc' # Name of the file +DOCKER_LINTER_RULES="${DEFAULT_RULES_LOCATION}/${DOCKER_FILE_NAME}" # Path to the Docker lint rules # Golang Vars -GO_FILE_NAME='.golangci.yml' # Name of the file -GO_LINTER_RULES="${DEFAULT_RULES_LOCATION}/${GO_FILE_NAME}" # Path to the Go lint rules +GO_FILE_NAME='.golangci.yml' # Name of the file +GO_LINTER_RULES="${DEFAULT_RULES_LOCATION}/${GO_FILE_NAME}" # Path to the Go lint rules # HTML Vars -HTML_FILE_NAME='.htmlhintrc' # Name of the file -HTML_LINTER_RULES="${DEFAULT_RULES_LOCATION}/${HTML_FILE_NAME}" # Path to the CSS lint rules +HTML_FILE_NAME='.htmlhintrc' # Name of the file +HTML_LINTER_RULES="${DEFAULT_RULES_LOCATION}/${HTML_FILE_NAME}" # Path to the CSS lint rules # Javascript Vars -JAVASCRIPT_FILE_NAME="${JAVASCRIPT_ES_CONFIG_FILE:-.eslintrc.yml}" # Name of the file -JAVASCRIPT_LINTER_RULES="${DEFAULT_RULES_LOCATION}/${JAVASCRIPT_FILE_NAME}" # Path to the Javascript lint rules -JAVASCRIPT_STANDARD_LINTER_RULES='' # ENV string to pass when running js standard +JAVASCRIPT_FILE_NAME="${JAVASCRIPT_ES_CONFIG_FILE:-.eslintrc.yml}" # Name of the file +JAVASCRIPT_LINTER_RULES="${DEFAULT_RULES_LOCATION}/${JAVASCRIPT_FILE_NAME}" # Path to the Javascript lint rules +JAVASCRIPT_STANDARD_LINTER_RULES='' # ENV string to pass when running js standard # Default linter path -LINTER_RULES_PATH="${LINTER_RULES_PATH:-.github/linters}" # Linter Path Directory +LINTER_RULES_PATH="${LINTER_RULES_PATH:-.github/linters}" # Linter Path Directory # MD Vars -MARKDOWN_FILE_NAME='.markdown-lint.yml' # Name of the file -MARKDOWN_LINTER_RULES="${DEFAULT_RULES_LOCATION}/${MARKDOWN_FILE_NAME}" # Path to the markdown lint rules +MARKDOWN_FILE_NAME='.markdown-lint.yml' # Name of the file +MARKDOWN_LINTER_RULES="${DEFAULT_RULES_LOCATION}/${MARKDOWN_FILE_NAME}" # Path to the markdown lint rules # OpenAPI Vars -OPENAPI_FILE_NAME='.openapirc.yml' # Name of the file -OPENAPI_LINTER_RULES="${DEFAULT_RULES_LOCATION}/${OPENAPI_FILE_NAME}" # Path to the OpenAPI lint rules +OPENAPI_FILE_NAME='.openapirc.yml' # Name of the file +OPENAPI_LINTER_RULES="${DEFAULT_RULES_LOCATION}/${OPENAPI_FILE_NAME}" # Path to the OpenAPI lint rules # Powershell Vars -POWERSHELL_FILE_NAME='.powershell-psscriptanalyzer.psd1' # Name of the file -POWERSHELL_LINTER_RULES="${DEFAULT_RULES_LOCATION}/${POWERSHELL_FILE_NAME}" # Path to the Powershell lint rules +POWERSHELL_FILE_NAME='.powershell-psscriptanalyzer.psd1' # Name of the file +POWERSHELL_LINTER_RULES="${DEFAULT_RULES_LOCATION}/${POWERSHELL_FILE_NAME}" # Path to the Powershell lint rules # Protocol Buffers Vars -PROTOBUF_FILE_NAME='.protolintrc.yml' # Name of the file -PROTOBUF_LINTER_RULES="${DEFAULT_RULES_LOCATION}/${PROTOBUF_FILE_NAME}" # Path to the Protocol Buffers lint rules +PROTOBUF_FILE_NAME='.protolintrc.yml' # Name of the file +PROTOBUF_LINTER_RULES="${DEFAULT_RULES_LOCATION}/${PROTOBUF_FILE_NAME}" # Path to the Protocol Buffers lint rules # Python Vars -PYTHON_FILE_NAME='.python-lint' # Name of the file -PYTHON_LINTER_RULES="${DEFAULT_RULES_LOCATION}/${PYTHON_FILE_NAME}" # Path to the python lint rules +PYTHON_FILE_NAME='.python-lint' # Name of the file +PYTHON_LINTER_RULES="${DEFAULT_RULES_LOCATION}/${PYTHON_FILE_NAME}" # Path to the python lint rules # Ruby Vars -RUBY_FILE_NAME="${RUBY_CONFIG_FILE:-.ruby-lint.yml}" # Name of the file -RUBY_LINTER_RULES="${DEFAULT_RULES_LOCATION}/${RUBY_FILE_NAME}" # Path to the ruby lint rules +RUBY_FILE_NAME="${RUBY_CONFIG_FILE:-.ruby-lint.yml}" # Name of the file +RUBY_LINTER_RULES="${DEFAULT_RULES_LOCATION}/${RUBY_FILE_NAME}" # Path to the ruby lint rules # Terraform Vars -TERRAFORM_FILE_NAME='.tflint.hcl' # Name of the file -TERRAFORM_LINTER_RULES="${DEFAULT_RULES_LOCATION}/${TERRAFORM_FILE_NAME}" # Path to the Terraform lint rules +TERRAFORM_FILE_NAME='.tflint.hcl' # Name of the file +TERRAFORM_LINTER_RULES="${DEFAULT_RULES_LOCATION}/${TERRAFORM_FILE_NAME}" # Path to the Terraform lint rules # Typescript Vars -TYPESCRIPT_FILE_NAME="${TYPESCRIPT_ES_CONFIG_FILE:-.eslintrc.yml}" # Name of the file -TYPESCRIPT_LINTER_RULES="${DEFAULT_RULES_LOCATION}/${TYPESCRIPT_FILE_NAME}" # Path to the Typescript lint rules -TYPESCRIPT_STANDARD_LINTER_RULES='' # ENV string to pass when running js standard +TYPESCRIPT_FILE_NAME="${TYPESCRIPT_ES_CONFIG_FILE:-.eslintrc.yml}" # Name of the file +TYPESCRIPT_LINTER_RULES="${DEFAULT_RULES_LOCATION}/${TYPESCRIPT_FILE_NAME}" # Path to the Typescript lint rules +TYPESCRIPT_STANDARD_LINTER_RULES='' # ENV string to pass when running js standard # YAML Vars -YAML_FILE_NAME='.yaml-lint.yml' # Name of the file -YAML_LINTER_RULES="${DEFAULT_RULES_LOCATION}/${YAML_FILE_NAME}" # Path to the yaml lint rules +YAML_FILE_NAME='.yaml-lint.yml' # Name of the file +YAML_LINTER_RULES="${DEFAULT_RULES_LOCATION}/${YAML_FILE_NAME}" # Path to the yaml lint rules ####################################### # Linter array for information prints # @@ -100,7 +100,7 @@ LINTER_ARRAY=('ansible-lint' 'arm-ttk' 'asl-validator' 'cfn-lint' 'clj-kondo' ############################# # Language array for prints # ############################# -LANGUAGE_ARRAY=('ANSIBLE' 'ARM' 'BASH' 'CFN' 'CLOJURE' 'COFFEESCRIPT' +LANGUAGE_ARRAY=('ANSIBLE' 'ARM' 'BASH' 'CLOUDFORMATION' 'CLOJURE' 'COFFEESCRIPT' 'CSS' 'DART' 'DOCKER' 'ENV' 'GO' 'HTML' 'JAVASCRIPT_ES' 'JAVASCRIPT_STANDARD' 'JSON' 'JSX' 'KOTLIN' 'MARKDOWN' 'OPENAPI' 'PERL' 'PHP' 'POWERSHELL' 'PROTOBUF' 'PYTHON' @@ -130,7 +130,7 @@ VALIDATE_ALL_CODEBASE="${VALIDATE_ALL_CODEBASE}" # Boolean to vali VALIDATE_ANSIBLE="${VALIDATE_ANSIBLE}" # Boolean to validate language VALIDATE_ARM="${VALIDATE_ARM}" # Boolean to validate language VALIDATE_BASH="${VALIDATE_BASH}" # Boolean to validate language -VALIDATE_CFN="${VALIDATE_CLOUDFORMATION}" # Boolean to validate language +VALIDATE_CLOUDFORMATION="${VALIDATE_CLOUDFORMATION}" # Boolean to validate language VALIDATE_CLOJURE="${VALIDATE_CLOJURE}" # Boolean to validate language VALIDATE_COFFEE="${VALIDATE_COFFEE}" # Boolean to validate language VALIDATE_CSS="${VALIDATE_CSS}" # Boolean to validate language @@ -205,7 +205,7 @@ REPORT_OUTPUT_FOLDER="${DEFAULT_WORKSPACE}/${OUTPUT_FOLDER}" # Location for the ########################## FILE_ARRAY_ARM=() # Array of files to check FILE_ARRAY_BASH=() # Array of files to check -FILE_ARRAY_CFN=() # Array of files to check +FILE_ARRAY_CLOUDFORMATION=() # Array of files to check FILE_ARRAY_CLOJURE=() # Array of files to check FILE_ARRAY_COFFEESCRIPT=() # Array of files to check FILE_ARRAY_CSS=() # Array of files to check @@ -242,7 +242,7 @@ FILE_ARRAY_YML=() # Array of files to check ERRORS_FOUND_ANSIBLE=0 # Count of errors found ERRORS_FOUND_ARM=0 # Count of errors found ERRORS_FOUND_BASH=0 # Count of errors found -ERRORS_FOUND_CFN=0 # Count of errors found +ERRORS_FOUND_CLOUDFORMATION=0 # Count of errors found ERRORS_FOUND_CLOJURE=0 # Count of errors found ERRORS_FOUND_CSS=0 # Count of errors found ERRORS_FOUND_COFFEESCRIPT=0 # Count of errors found @@ -574,9 +574,9 @@ DetectCloudFormationFile() { return 0 fi - ########################################## - # No identifiers of a CFN template found # - ########################################## + ##################################################### + # No identifiers of a CLOUDFORMATION template found # + ##################################################### return 1 } ################################################################################ @@ -965,7 +965,7 @@ Footer() { elif [ "${ERRORS_FOUND_ANSIBLE}" -ne 0 ] || [ "${ERRORS_FOUND_ARM}" -ne 0 ] || [ "${ERRORS_FOUND_BASH}" -ne 0 ] || - [ "${ERRORS_FOUND_CFN}" -ne 0 ] || + [ "${ERRORS_FOUND_CLOUDFORMATION}" -ne 0 ] || [ "${ERRORS_FOUND_CLOJURE}" -ne 0 ] || [ "${ERRORS_FOUND_COFFEESCRIPT}" -ne 0 ] || [ "${ERRORS_FOUND_CSS}" -ne 0 ] || @@ -1074,8 +1074,8 @@ GetLinterRules "POWERSHELL" GetLinterRules "ARM" # Get CSS rules GetLinterRules "CSS" -# Get CFN rules -GetLinterRules "CFN" +# Get CLOUDFORMATION rules +GetLinterRules "CLOUDFORMATION" # Get DART rules GetLinterRules "DART" # Get HTML rules @@ -1184,15 +1184,15 @@ if [ "${VALIDATE_PYTHON}" == "true" ]; then LintCodebase "PYTHON" "pylint" "pylint --rcfile ${PYTHON_LINTER_RULES}" ".*\.\(py\)\$" "${FILE_ARRAY_PYTHON[@]}" fi -############### -# CFN LINTING # -############### -if [ "${VALIDATE_CFN}" == "true" ]; then +########################## +# CLOUDFORMATION LINTING # +########################## +if [ "${VALIDATE_CLOUDFORMATION}" == "true" ]; then ################################# # Lint the CloudFormation files # ################################# # LintCodebase "FILE_TYPE" "LINTER_NAME" "LINTER_CMD" "FILE_TYPES_REGEX" "FILE_ARRAY" - LintCodebase "CFN" "cfn-lint" "cfn-lint --config-file ${CFN_LINTER_RULES}" ".*\.\(json\|yml\|yaml\)\$" "${FILE_ARRAY_CFN[@]}" + LintCodebase "CLOUDFORMATION" "cfn-lint" "cfn-lint --config-file ${CLOUDFORMATION_LINTER_RULES}" ".*\.\(json\|yml\|yaml\)\$" "${FILE_ARRAY_CLOUDFORMATION[@]}" fi ################ diff --git a/lib/validation.sh b/lib/validation.sh index 4fffb249..bf1e7ccb 100755 --- a/lib/validation.sh +++ b/lib/validation.sh @@ -50,6 +50,7 @@ function GetValidationInfo() { VALIDATE_ARM="${VALIDATE_ARM,,}" VALIDATE_BASH="${VALIDATE_BASH,,}" VALIDATE_CLOJURE="${VALIDATE_CLOJURE,,}" + VALIDATE_CLOUDFORMATION="${VALIDATE_CLOUDFORMATION,,}" VALIDATE_COFFEE="${VALIDATE_COFFEE,,}" VALIDATE_CSS="${VALIDATE_CSS,,}" VALIDATE_DART="${VALIDATE_DART,,}" @@ -88,6 +89,7 @@ function GetValidationInfo() { ${VALIDATE_ARM} || -n \ ${VALIDATE_BASH} || -n \ ${VALIDATE_CLOJURE} || -n \ + ${VALIDATE_CLOUDFORMATION} || -n \ ${VALIDATE_COFFEE} || -n \ ${VALIDATE_CSS} || -n \ ${VALIDATE_DART} || -n \ @@ -551,6 +553,20 @@ function GetValidationInfo() { VALIDATE_CLOJURE="true" fi + ############################################## + # Validate if we should check CloudFormation # + ############################################## + if [[ ${ANY_SET} == "true" ]]; then + # Some linter flags were set - only run those set to true + if [[ -z ${VALIDATE_CLOUDFORMATION} ]]; then + # Cloud Formation flag was not set - default to false + VALIDATE_CLOUDFORMATION="false" + fi + else + # No linter flags were set - default all to true + VALIDATE_CLOUDFORMATION="true" + fi + ############################################ # Validate if we should check editorconfig # ############################################ @@ -700,6 +716,11 @@ function GetValidationInfo() { else PRINT_ARRAY+=("- Excluding [CLOJURE] files in code base...") fi + if [[ ${VALIDATE_CLOUDFORMATION} == "true" ]]; then + PRINT_ARRAY+=("- Validating [CLOUDFORMATION] files in code base...") + else + PRINT_ARRAY+=("- Excluding [CLOUDFORMATION] files in code base...") + fi if [[ ${VALIDATE_ENV} == "true" ]]; then PRINT_ARRAY+=("- Validating [ENV] files in code base...") else diff --git a/lib/worker.sh b/lib/worker.sh index f5957f4e..57ee3413 100755 --- a/lib/worker.sh +++ b/lib/worker.sh @@ -557,7 +557,7 @@ function RunTestCases() { TestCodebase "ANSIBLE" "ansible-lint" "ansible-lint -v -c ${ANSIBLE_LINTER_RULES}" ".*\.\(yml\|yaml\)\$" "ansible" TestCodebase "ARM" "arm-ttk" "Import-Module ${ARM_TTK_PSD1} ; \${config} = \$(Import-PowerShellDataFile -Path ${ARM_LINTER_RULES}) ; Test-AzTemplate @config -TemplatePath" ".*\.\(json\)\$" "arm" TestCodebase "BASH" "shellcheck" "shellcheck --color" ".*\.\(sh\|bash\|dash\|ksh\)\$" "shell" - TestCodebase "CFN" "cfn-lint" "cfn-lint --config-file ${CFN_LINTER_RULES}" ".*\.\(json\|yml\|yaml\)\$" "cfn" + TestCodebase "CLOUDFORMATION" "cfn-lint" "cfn-lint --config-file ${CLOUDFORMATION_LINTER_RULES}" ".*\.\(json\|yml\|yaml\)\$" "cloudformation" TestCodebase "CLOJURE" "clj-kondo" "clj-kondo --config ${CLOJURE_LINTER_RULES} --lint" ".*\.\(clj\|cljs\|cljc\|edn\)\$" "clojure" TestCodebase "COFFEESCRIPT" "coffeelint" "coffeelint -f ${COFFEESCRIPT_LINTER_RULES}" ".*\.\(coffee\)\$" "coffeescript" TestCodebase "CSS" "stylelint" "stylelint --config ${CSS_LINTER_RULES}" ".*\.\(css\)\$" "css" From 3c92dcd70b19a83756a723274188cb3c27523cc6 Mon Sep 17 00:00:00 2001 From: Lucas Gravley <29484535+admiralAwkbar@users.noreply.github.com> Date: Wed, 22 Jul 2020 14:26:45 -0500 Subject: [PATCH 2/7] Went sooo hard on this --- lib/validation.sh | 703 +++------------------------------------------- 1 file changed, 37 insertions(+), 666 deletions(-) diff --git a/lib/validation.sh b/lib/validation.sh index bf1e7ccb..d13bb3f4 100755 --- a/lib/validation.sh +++ b/lib/validation.sh @@ -85,682 +85,53 @@ function GetValidationInfo() { # Determine if any linters were explicitly set # ################################################ ANY_SET="false" - if [[ -n ${VALIDATE_ANSIBLE} || -n \ - ${VALIDATE_ARM} || -n \ - ${VALIDATE_BASH} || -n \ - ${VALIDATE_CLOJURE} || -n \ - ${VALIDATE_CLOUDFORMATION} || -n \ - ${VALIDATE_COFFEE} || -n \ - ${VALIDATE_CSS} || -n \ - ${VALIDATE_DART} || -n \ - ${VALIDATE_DOCKER} || -n \ - ${VALIDATE_EDITORCONFIG} || -n \ - ${VALIDATE_ENV} || -n \ - ${VALIDATE_GO} || -n \ - ${VALIDATE_HTML} || -n \ - ${VALIDATE_JAVASCRIPT_ES} || -n \ - ${VALIDATE_JAVASCRIPT_STANDARD} || -n \ - ${VALIDATE_JSON} || -n \ - ${VALIDATE_KOTLIN} || -n \ - ${VALIDATE_MARKDOWN} || -n \ - ${VALIDATE_OPENAPI} || -n \ - ${VALIDATE_PERL} || -n \ - ${VALIDATE_PHP} || -n \ - ${VALIDATE_POWERSHELL} || -n \ - ${VALIDATE_PROTOBUF} || -n \ - ${VALIDATE_PYTHON} || -n \ - ${VALIDATE_RAKU} || -n \ - ${VALIDATE_RUBY} || -n \ - ${VALIDATE_TERRAFORM} || -n \ - ${VALIDATE_TYPESCRIPT_ES} || -n \ - ${VALIDATE_TYPESCRIPT_STANDARD} || -n \ - ${VALIDATE_XML} || -n \ - ${VALIDATE_YAML} ]]; then - ANY_SET="true" - fi - - #################################### - # Validate if we should check YAML # - #################################### - if [[ ${ANY_SET} == "true" ]]; then - # Some linter flags were set - only run those set to true - if [[ -z ${VALIDATE_YAML} ]]; then - # YAML flag was not set - default to false - VALIDATE_YAML="false" + # Loop through all languages + for LANGUAGE in "${LANGUAGE_ARRAY[@]}"; do + # build the variable + VALIDATE_LANGUAGE="VALIDATE_${LANGUAGE}" + # Check to see if the variable was set + if [ -n ${!VALIDATE_LANGUAGE} ]; then + # It was set, need to set flag + ANY_SET="true" fi - else - # No linter flags were set - default all to true - VALIDATE_YAML="true" - fi + done - #################################### - # Validate if we should check JSON # - #################################### - if [[ ${ANY_SET} == "true" ]]; then - # Some linter flags were set - only run those set to true - if [[ -z ${VALIDATE_JSON} ]]; then - # JSON flag was not set - default to false - VALIDATE_JSON="false" - fi - else - # No linter flags were set - default all to true - VALIDATE_JSON="true" - fi - - ################################### - # Validate if we should check XML # - ################################### - if [[ ${ANY_SET} == "true" ]]; then - # Some linter flags were set - only run those set to true - if [[ -z ${VALIDATE_XML} ]]; then - # XML flag was not set - default to false - VALIDATE_XML="false" - fi - else - # No linter flags were set - default all to true - VALIDATE_XML="true" - fi - - ######################################## - # Validate if we should check MARKDOWN # - ######################################## - if [[ ${ANY_SET} == "true" ]]; then - # Some linter flags were set - only run those set to true - if [[ -z ${VALIDATE_MARKDOWN} ]]; then - # MD flag was not set - default to false - VALIDATE_MARKDOWN="false" - fi - else - # No linter flags were set - default all to true - VALIDATE_MARKDOWN="true" - fi - - #################################### - # Validate if we should check BASH # - #################################### - if [[ ${ANY_SET} == "true" ]]; then - # Some linter flags were set - only run those set to true - if [[ -z ${VALIDATE_BASH} ]]; then - # BASH flag was not set - default to false - VALIDATE_BASH="false" - fi - else - # No linter flags were set - default all to true - VALIDATE_BASH="true" - fi - - #################################### - # Validate if we should check PERL # - #################################### - if [[ ${ANY_SET} == "true" ]]; then - # Some linter flags were set - only run those set to true - if [[ -z ${VALIDATE_PERL} ]]; then - # PERL flag was not set - default to false - VALIDATE_PERL="false" - fi - else - # No linter flags were set - default all to true - VALIDATE_PERL="true" - fi - - #################################### - # Validate if we should check RAKU # - #################################### - if [[ ${ANY_SET} == "true" ]]; then - # Some linter flags were set - only run those set to true - if [[ -z ${VALIDATE_RAKU} ]]; then - # RAKU flag was not set - default to false - VALIDATE_RAKU="false" - fi - else - # No linter flags were set - default all to true - VALIDATE_RAKU="true" - fi - - #################################### - # Validate if we should check PHP # - #################################### - if [[ ${ANY_SET} == "true" ]]; then - # Some linter flags were set - only run those set to true - if [[ -z ${VALIDATE_PHP} ]]; then - # PHP flag was not set - default to false - VALIDATE_PHP="false" - fi - else - # No linter flags were set - default all to true - VALIDATE_PHP="true" - fi - - ###################################### - # Validate if we should check PYTHON # - ###################################### - if [[ ${ANY_SET} == "true" ]]; then - # Some linter flags were set - only run those set to true - if [[ -z ${VALIDATE_PYTHON} ]]; then - # PYTHON flag was not set - default to false - VALIDATE_PYTHON="false" - fi - else - # No linter flags were set - default all to true - VALIDATE_PYTHON="true" - fi - - #################################### - # Validate if we should check RUBY # - #################################### - if [[ ${ANY_SET} == "true" ]]; then - # Some linter flags were set - only run those set to true - if [[ -z ${VALIDATE_RUBY} ]]; then - # RUBY flag was not set - default to false - VALIDATE_RUBY="false" - fi - else - # No linter flags were set - default all to true - VALIDATE_RUBY="true" - fi - - ########################################## - # Validate if we should check AWS States # - ########################################## - if [[ ${ANY_SET} == "true" ]]; then - # Some linter flags were set - only run those set to true - if [[ -z ${VALIDATE_STATES} ]]; then - # STATES flag was not set - default to false - VALIDATE_STATES="false" - fi - else - # No linter flags were set - default all to true - VALIDATE_STATES="true" - fi - - ###################################### - # Validate if we should check COFFEE # - ###################################### - if [[ ${ANY_SET} == "true" ]]; then - # Some linter flags were set - only run those set to true - if [[ -z ${VALIDATE_COFFEE} ]]; then - # COFFEE flag was not set - default to false - VALIDATE_COFFEE="false" - fi - else - # No linter flags were set - default all to true - VALIDATE_COFFEE="true" - fi - - ####################################### - # Validate if we should check ANSIBLE # - ####################################### - if [[ ${ANY_SET} == "true" ]]; then - # Some linter flags were set - only run those set to true - if [[ -z ${VALIDATE_ANSIBLE} ]]; then - # ANSIBLE flag was not set - default to false - VALIDATE_ANSIBLE="false" - fi - else - # No linter flags were set - default all to true - VALIDATE_ANSIBLE="true" - fi - - ############################################# - # Validate if we should check JAVASCRIPT_ES # - ############################################# - if [[ ${ANY_SET} == "true" ]]; then - # Some linter flags were set - only run those set to true - if [[ -z ${VALIDATE_JAVASCRIPT_ES} ]]; then - # JAVASCRIPT_ES flag was not set - default to false - VALIDATE_JAVASCRIPT_ES="false" - fi - else - # No linter flags were set - default all to true - VALIDATE_JAVASCRIPT_ES="true" - fi ################################################### - # Validate if we should check JAVASCRIPT_STANDARD # + # Validate if we should check individual lanuages # ################################################### - if [[ ${ANY_SET} == "true" ]]; then - # Some linter flags were set - only run those set to true - if [[ -z ${VALIDATE_JAVASCRIPT_STANDARD} ]]; then - # JAVASCRIPT_STANDARD flag was not set - default to false - VALIDATE_JAVASCRIPT_STANDARD="false" + # Loop through all languages + for LANGUAGE in "${LANGUAGE_ARRAY[@]}"; do + # build the variable + VALIDATE_LANGUAGE="VALIDATE_${LANGUAGE}" + # Check if ANY_SET was set + if [[ ${ANY_SET} == "true" ]]; then + # Check to see if the variable was set + if [ -z ${!VALIDATE_LANGUAGE} ]; then + # Flag was not set, default to false + eval "${VALIDATE_LANGUAGE}='false'" + fi + else + # No linter flags were set - default all to true + eval "${VALIDATE_LANGUAGE}='true'" fi - else - # No linter flags were set - default all to true - VALIDATE_JAVASCRIPT_STANDARD="true" - fi - - ############################################# - # Validate if we should check JSX # - ############################################# - if [[ ${ANY_SET} == "true" ]]; then - # Some linter flags were set - only run those set to true - if [[ -z ${VALIDATE_JSX} ]]; then - # JSX flag was not set - default to false - VALIDATE_JSX="false" - fi - else - # No linter flags were set - default all to true - VALIDATE_JSX="true" - fi - - ############################################# - # Validate if we should check TSX # - ############################################# - if [[ ${ANY_SET} == "true" ]]; then - # Some linter flags were set - only run those set to true - if [[ -z ${VALIDATE_TSX} ]]; then - # TSX flag was not set - default to false - VALIDATE_TSX="false" - fi - else - # No linter flags were set - default all to true - VALIDATE_TSX="true" - fi - - ############################################# - # Validate if we should check TYPESCRIPT_ES # - ############################################# - if [[ ${ANY_SET} == "true" ]]; then - # Some linter flags were set - only run those set to true - if [[ -z ${VALIDATE_TYPESCRIPT_ES} ]]; then - # TYPESCRIPT_ES flag was not set - default to false - VALIDATE_TYPESCRIPT_ES="false" - fi - else - # No linter flags were set - default all to true - VALIDATE_TYPESCRIPT_ES="true" - fi - - ################################################### - # Validate if we should check TYPESCRIPT_STANDARD # - ################################################### - if [[ ${ANY_SET} == "true" ]]; then - # Some linter flags were set - only run those set to true - if [[ -z ${VALIDATE_TYPESCRIPT_STANDARD} ]]; then - # TYPESCRIPT_STANDARD flag was not set - default to false - VALIDATE_TYPESCRIPT_STANDARD="false" - fi - else - # No linter flags were set - default all to true - VALIDATE_TYPESCRIPT_STANDARD="true" - fi - - ###################################### - # Validate if we should check DOCKER # - ###################################### - if [[ ${ANY_SET} == "true" ]]; then - # Some linter flags were set - only run those set to true - if [[ -z ${VALIDATE_DOCKER} ]]; then - # DOCKER flag was not set - default to false - VALIDATE_DOCKER="false" - fi - else - # No linter flags were set - default all to true - VALIDATE_DOCKER="true" - fi - - ################################## - # Validate if we should check GO # - ################################## - if [[ ${ANY_SET} == "true" ]]; then - # Some linter flags were set - only run those set to true - if [[ -z ${VALIDATE_GO} ]]; then - # GO flag was not set - default to false - VALIDATE_GO="false" - fi - else - # No linter flags were set - default all to true - VALIDATE_GO="true" - fi - - ######################################### - # Validate if we should check TERRAFORM # - ######################################### - if [[ ${ANY_SET} == "true" ]]; then - # Some linter flags were set - only run those set to true - if [[ -z ${VALIDATE_TERRAFORM} ]]; then - # TERRAFORM flag was not set - default to false - VALIDATE_TERRAFORM="false" - fi - else - # No linter flags were set - default all to true - VALIDATE_TERRAFORM="true" - fi - - ######################################### - # Validate if we should check POWERSHELL # - ######################################### - if [[ ${ANY_SET} == "true" ]]; then - # Some linter flags were set - only run those set to true - if [[ -z ${VALIDATE_POWERSHELL} ]]; then - # POWERSHELL flag was not set - default to false - VALIDATE_POWERSHELL="false" - fi - else - # No linter flags were set - default all to true - VALIDATE_POWERSHELL="true" - fi - - ################################### - # Validate if we should check ARM # - ################################### - if [[ "${ANY_SET}" == "true" ]]; then - # Some linter flags were set - only run those set to true - if [[ -z "${VALIDATE_ARM}" ]]; then - # ARM flag was not set - default to false - VALIDATE_ARM="false" - fi - else - # No linter flags were set - default all to true - VALIDATE_ARM="true" - fi - - ################################### - # Validate if we should check CSS # - ################################### - if [[ ${ANY_SET} == "true" ]]; then - # Some linter flags were set - only run those set to true - if [[ -z ${VALIDATE_CSS} ]]; then - # CSS flag was not set - default to false - VALIDATE_CSS="false" - fi - else - # No linter flags were set - default all to true - VALIDATE_CSS="true" - fi - - ################################### - # Validate if we should check ENV # - ################################### - if [[ ${ANY_SET} == "true" ]]; then - # Some linter flags were set - only run those set to true - if [[ -z ${VALIDATE_ENV} ]]; then - # ENV flag was not set - default to false - VALIDATE_ENV="false" - fi - else - # No linter flags were set - default all to true - VALIDATE_ENV="true" - fi - - ###################################### - # Validate if we should check KOTLIN # - ###################################### - if [[ ${ANY_SET} == "true" ]]; then - # Some linter flags were set - only run those set to true - if [[ -z ${VALIDATE_KOTLIN} ]]; then - # ENV flag was not set - default to false - VALIDATE_KOTLIN="false" - fi - else - # No linter flags were set - default all to true - VALIDATE_KOTLIN="true" - fi - - #################################### - # Validate if we should check DART # - #################################### - if [[ ${ANY_SET} == "true" ]]; then - # Some linter flags were set - only run those set to true - if [[ -z ${VALIDATE_DART} ]]; then - # ENV flag was not set - default to false - VALIDATE_DART="false" - fi - else - # No linter flags were set - default all to true - VALIDATE_DART="true" - fi - - ####################################### - # Validate if we should check OPENAPI # - ####################################### - if [[ ${ANY_SET} == "true" ]]; then - # Some linter flags were set - only run those set to true - if [[ -z ${VALIDATE_OPENAPI} ]]; then - # OPENAPI flag was not set - default to false - VALIDATE_OPENAPI="false" - fi - else - # No linter flags were set - default all to true - VALIDATE_OPENAPI="true" - fi - - ####################################### - # Validate if we should check PROTOBUF # - ####################################### - if [[ ${ANY_SET} == "true" ]]; then - # Some linter flags were set - only run those set to true - if [[ -z ${VALIDATE_PROTOBUF} ]]; then - # PROTOBUF flag was not set - default to false - VALIDATE_PROTOBUF="false" - fi - else - # No linter flags were set - default all to true - VALIDATE_PROTOBUF="true" - fi - - ####################################### - # Validate if we should check Clojure # - ####################################### - if [[ ${ANY_SET} == "true" ]]; then - # Some linter flags were set - only run those set to true - if [[ -z ${VALIDATE_CLOJURE} ]]; then - # Clojure flag was not set - default to false - VALIDATE_CLOJURE="false" - fi - else - # No linter flags were set - default all to true - VALIDATE_CLOJURE="true" - fi - - ############################################## - # Validate if we should check CloudFormation # - ############################################## - if [[ ${ANY_SET} == "true" ]]; then - # Some linter flags were set - only run those set to true - if [[ -z ${VALIDATE_CLOUDFORMATION} ]]; then - # Cloud Formation flag was not set - default to false - VALIDATE_CLOUDFORMATION="false" - fi - else - # No linter flags were set - default all to true - VALIDATE_CLOUDFORMATION="true" - fi - - ############################################ - # Validate if we should check editorconfig # - ############################################ - if [[ ${ANY_SET} == "true" ]]; then - # Some linter flags were set - only run those set to true - if [[ -z ${VALIDATE_EDITORCONFIG} ]]; then - # EDITORCONFIG flag was not set - default to false - VALIDATE_EDITORCONFIG="false" - fi - else - # No linter flags were set - # special case checking for .editorconfig - if [ -f "${GITHUB_WORKSPACE}/.editorconfig" ]; then - VALIDATE_EDITORCONFIG="true" - fi - fi - - #################################### - # Validate if we should check HTML # - #################################### - if [[ ${ANY_SET} == "true" ]]; then - # Some linter flags were set - only run those set to true - if [[ -z ${VALIDATE_HTML} ]]; then - # HTML flag was not set - default to false - VALIDATE_HTML="false" - fi - else - # No linter flags were set - default all to true - VALIDATE_HTML="true" - fi + done ####################################### # Print which linters we are enabling # ####################################### - if [[ ${VALIDATE_YAML} == "true" ]]; then - PRINT_ARRAY+=("- Validating [YAML] files in code base...") - else - PRINT_ARRAY+=("- Excluding [YAML] files in code base...") - fi - if [[ ${VALIDATE_JSON} == "true" ]]; then - PRINT_ARRAY+=("- Validating [JSON] files in code base...") - else - PRINT_ARRAY+=("- Excluding [JSON] files in code base...") - fi - if [[ ${VALIDATE_XML} == "true" ]]; then - PRINT_ARRAY+=("- Validating [XML] files in code base...") - else - PRINT_ARRAY+=("- Excluding [XML] files in code base...") - fi - if [[ ${VALIDATE_MARKDOWN} == "true" ]]; then - PRINT_ARRAY+=("- Validating [MARKDOWN] files in code base...") - else - PRINT_ARRAY+=("- Excluding [MARKDOWN] files in code base...") - fi - if [[ ${VALIDATE_BASH} == "true" ]]; then - PRINT_ARRAY+=("- Validating [BASH] files in code base...") - else - PRINT_ARRAY+=("- Excluding [BASH] files in code base...") - fi - if [[ ${VALIDATE_PERL} == "true" ]]; then - PRINT_ARRAY+=("- Validating [PERL] files in code base...") - else - PRINT_ARRAY+=("- Excluding [PERL] files in code base...") - fi - if [[ ${VALIDATE_RAKU} == "true" ]]; then - PRINT_ARRAY+=("- Validating [RAKU] files in code base...") - else - PRINT_ARRAY+=("- Excluding [RAKU] files in code base...") - fi - if [[ ${VALIDATE_PHP} == "true" ]]; then - PRINT_ARRAY+=("- Validating [PHP] files in code base...") - else - PRINT_ARRAY+=("- Excluding [PHP] files in code base...") - fi - if [[ ${VALIDATE_PYTHON} == "true" ]]; then - PRINT_ARRAY+=("- Validating [PYTHON] files in code base...") - else - PRINT_ARRAY+=("- Excluding [PYTHON] files in code base...") - fi - if [[ ${VALIDATE_RUBY} == "true" ]]; then - PRINT_ARRAY+=("- Validating [RUBY] files in code base...") - else - PRINT_ARRAY+=("- Excluding [RUBY] files in code base...") - fi - if [[ ${VALIDATE_COFFEE} == "true" ]]; then - PRINT_ARRAY+=("- Validating [COFFEE] files in code base...") - else - PRINT_ARRAY+=("- Excluding [COFFEE] files in code base...") - fi - if [[ ${VALIDATE_ANSIBLE} == "true" ]]; then - PRINT_ARRAY+=("- Validating [ANSIBLE] files in code base...") - else - PRINT_ARRAY+=("- Excluding [ANSIBLE] files in code base...") - fi - if [[ ${VALIDATE_JAVASCRIPT_ES} == "true" ]]; then - PRINT_ARRAY+=("- Validating [JAVASCRIPT(eslint)] files in code base...") - else - PRINT_ARRAY+=("- Excluding [JAVASCRIPT(eslint)] files in code base...") - fi - if [[ ${VALIDATE_JAVASCRIPT_STANDARD} == "true" ]]; then - PRINT_ARRAY+=("- Validating [JAVASCRIPT(standard)] files in code base...") - else - PRINT_ARRAY+=("- Excluding [JAVASCRIPT(standard)] files in code base...") - fi - if [[ ${VALIDATE_TYPESCRIPT_ES} == "true" ]]; then - PRINT_ARRAY+=("- Validating [TYPESCRIPT(eslint)] files in code base...") - else - PRINT_ARRAY+=("- Excluding [TYPESCRIPT(eslint)] files in code base...") - fi - if [[ ${VALIDATE_TYPESCRIPT_STANDARD} == "true" ]]; then - PRINT_ARRAY+=("- Validating [TYPESCRIPT(standard)] files in code base...") - else - PRINT_ARRAY+=("- Excluding [TYPESCRIPT(standard)] files in code base...") - fi - if [[ ${VALIDATE_DOCKER} == "true" ]]; then - PRINT_ARRAY+=("- Validating [DOCKER] files in code base...") - else - PRINT_ARRAY+=("- Excluding [DOCKER] files in code base...") - fi - if [[ ${VALIDATE_GO} == "true" ]]; then - PRINT_ARRAY+=("- Validating [GOLANG] files in code base...") - else - PRINT_ARRAY+=("- Excluding [GOLANG] files in code base...") - fi - if [[ ${VALIDATE_TERRAFORM} == "true" ]]; then - PRINT_ARRAY+=("- Validating [TERRAFORM] files in code base...") - else - PRINT_ARRAY+=("- Excluding [TERRAFORM] files in code base...") - fi - if [[ ${VALIDATE_POWERSHELL} == "true" ]]; then - PRINT_ARRAY+=("- Validating [POWERSHELL] files in code base...") - else - PRINT_ARRAY+=("- Excluding [POWERSHELL] files in code base...") - fi - if [[ ${VALIDATE_ARM} == "true" ]]; then - PRINT_ARRAY+=("- Validating [ARM] files in code base...") - else - PRINT_ARRAY+=("- Excluding [ARM] files in code base...") - fi - if [[ ${VALIDATE_CSS} == "true" ]]; then - PRINT_ARRAY+=("- Validating [CSS] files in code base...") - else - PRINT_ARRAY+=("- Excluding [CSS] files in code base...") - fi - if [[ ${VALIDATE_CLOJURE} == "true" ]]; then - PRINT_ARRAY+=("- Validating [CLOJURE] files in code base...") - else - PRINT_ARRAY+=("- Excluding [CLOJURE] files in code base...") - fi - if [[ ${VALIDATE_CLOUDFORMATION} == "true" ]]; then - PRINT_ARRAY+=("- Validating [CLOUDFORMATION] files in code base...") - else - PRINT_ARRAY+=("- Excluding [CLOUDFORMATION] files in code base...") - fi - if [[ ${VALIDATE_ENV} == "true" ]]; then - PRINT_ARRAY+=("- Validating [ENV] files in code base...") - else - PRINT_ARRAY+=("- Excluding [ENV] files in code base...") - fi - if [[ ${VALIDATE_KOTLIN} == "true" ]]; then - PRINT_ARRAY+=("- Validating [KOTLIN] files in code base...") - else - PRINT_ARRAY+=("- Excluding [KOTLIN] files in code base...") - fi - if [[ ${VALIDATE_OPENAPI} == "true" ]]; then - PRINT_ARRAY+=("- Validating [OPENAPI] files in code base...") - else - PRINT_ARRAY+=("- Excluding [OPENAPI] files in code base...") - fi - if [[ ${VALIDATE_PROTOBUF} == "true" ]]; then - PRINT_ARRAY+=("- Validating [PROTOBUF] files in code base...") - else - PRINT_ARRAY+=("- Excluding [PROTOBUF] files in code base...") - fi - if [[ ${VALIDATE_DART} == "true" ]]; then - PRINT_ARRAY+=("- Validating [DART] files in code base...") - else - PRINT_ARRAY+=("- Excluding [DART] files in code base...") - fi - if [[ ${VALIDATE_EDITORCONFIG} == "true" ]]; then - PRINT_ARRAY+=("- Validating [EDITORCONFIG] files in code base...") - else - PRINT_ARRAY+=("- Excluding [EDITORCONFIG] files in code base...") - fi - if [[ ${VALIDATE_HTML} == "true" ]]; then - PRINT_ARRAY+=("- Validating [HTML] files in code base...") - else - PRINT_ARRAY+=("- Excluding [HTML] files in code base...") - fi - if [[ ${VALIDATE_STATES} == "true" ]]; then - PRINT_ARRAY+=("- Validating [AWS STATES] files in code base...") - else - PRINT_ARRAY+=("- Excluding [AWS STATES] files in code base...") - fi + # Loop through all languages + for LANGUAGE in "${LANGUAGE_ARRAY[@]}"; do + # build the variable + VALIDATE_LANGUAGE="VALIDATE_${LANGUAGE}" + if [[ ${!VALIDATE_LANGUAGE} == "true" ]]; then + # We need to validate + PRINT_ARRAY+=("- Validating [$LANGUAGE] files in code base...") + else + # We are skipping the language + PRINT_ARRAY+=("- Excluding [$LANGUAGE] files in code base...") + fi + done ############################## # Validate Ansible Directory # From 5001845b7baf4c018e039cf35a418b7dbb3b7b1a Mon Sep 17 00:00:00 2001 From: Lucas Gravley <29484535+admiralAwkbar@users.noreply.github.com> Date: Wed, 22 Jul 2020 14:31:47 -0500 Subject: [PATCH 3/7] going soooo hard --- lib/validation.sh | 45 +++++++++------------------------------------ 1 file changed, 9 insertions(+), 36 deletions(-) diff --git a/lib/validation.sh b/lib/validation.sh index d13bb3f4..57aad373 100755 --- a/lib/validation.sh +++ b/lib/validation.sh @@ -46,40 +46,13 @@ function GetValidationInfo() { ################################ # Convert strings to lowercase # ################################ - VALIDATE_ANSIBLE="${VALIDATE_ANSIBLE,,}" - VALIDATE_ARM="${VALIDATE_ARM,,}" - VALIDATE_BASH="${VALIDATE_BASH,,}" - VALIDATE_CLOJURE="${VALIDATE_CLOJURE,,}" - VALIDATE_CLOUDFORMATION="${VALIDATE_CLOUDFORMATION,,}" - VALIDATE_COFFEE="${VALIDATE_COFFEE,,}" - VALIDATE_CSS="${VALIDATE_CSS,,}" - VALIDATE_DART="${VALIDATE_DART,,}" - VALIDATE_DOCKER="${VALIDATE_DOCKER,,}" - VALIDATE_EDITORCONFIG="${VALIDATE_EDITORCONFIG,,}" - VALIDATE_ENV="${VALIDATE_ENV,,}" - VALIDATE_GO="${VALIDATE_GO,,}" - VALIDATE_HTML="${VALIDATE_HTML,,}" - VALIDATE_JAVASCRIPT_ES="${VALIDATE_JAVASCRIPT_ES,,}" - VALIDATE_JAVASCRIPT_STANDARD="${VALIDATE_JAVASCRIPT_STANDARD,,}" - VALIDATE_JSON="${VALIDATE_JSON,,}" - VALIDATE_JSX="${VALIDATE_JSX,,}" - VALIDATE_KOTLIN="${VALIDATE_KOTLIN,,}" - VALIDATE_MARKDOWN="${VALIDATE_MARKDOWN,,}" - VALIDATE_OPENAPI="${VALIDATE_OPENAPI,,}" - VALIDATE_PERL="${VALIDATE_PERL,,}" - VALIDATE_PHP="${VALIDATE_PHP,,}" - VALIDATE_POWERSHELL="${VALIDATE_POWERSHELL,,}" - VALIDATE_PROTOBUF="${VALIDATE_PROTOBUF,,}" - VALIDATE_PYTHON="${VALIDATE_PYTHON,,}" - VALIDATE_RAKU="${VALIDATE_RAKU,,}" - VALIDATE_RUBY="${VALIDATE_RUBY,,}" - VALIDATE_STATES="${VALIDATE_STATES,,}" - VALIDATE_TERRAFORM="${VALIDATE_TERRAFORM,,}" - VALIDATE_TSX="${VALIDATE_TSX,,}" - VALIDATE_TYPESCRIPT_ES="${VALIDATE_TYPESCRIPT_ES,,}" - VALIDATE_TYPESCRIPT_STANDARD="${VALIDATE_TYPESCRIPT_STANDARD,,}" - VALIDATE_YAML="${VALIDATE_YAML,,}" - VALIDATE_XML="${VALIDATE_XML,,}" + # Loop through all languages + for LANGUAGE in "${LANGUAGE_ARRAY[@]}"; do + # build the variable + VALIDATE_LANGUAGE="VALIDATE_${LANGUAGE}" + # Set the value of the var to lowercase + eval "${VALIDATE_LANGUAGE}=${!VALIDATE_LANGUAGE,,}" + done ################################################ # Determine if any linters were explicitly set # @@ -90,7 +63,7 @@ function GetValidationInfo() { # build the variable VALIDATE_LANGUAGE="VALIDATE_${LANGUAGE}" # Check to see if the variable was set - if [ -n ${!VALIDATE_LANGUAGE} ]; then + if [ -n "${!VALIDATE_LANGUAGE}" ]; then # It was set, need to set flag ANY_SET="true" fi @@ -107,7 +80,7 @@ function GetValidationInfo() { # Check if ANY_SET was set if [[ ${ANY_SET} == "true" ]]; then # Check to see if the variable was set - if [ -z ${!VALIDATE_LANGUAGE} ]; then + if [ -z "${!VALIDATE_LANGUAGE}" ]; then # Flag was not set, default to false eval "${VALIDATE_LANGUAGE}='false'" fi From f74fa431f4bda7ae562465ea68e7c591095c49a0 Mon Sep 17 00:00:00 2001 From: Lucas Gravley <29484535+admiralAwkbar@users.noreply.github.com> Date: Wed, 22 Jul 2020 14:41:37 -0500 Subject: [PATCH 4/7] Cleanup of errors --- lib/linter.sh | 52 ++++++++++++++------------------------------------- 1 file changed, 14 insertions(+), 38 deletions(-) diff --git a/lib/linter.sh b/lib/linter.sh index 516c9d3c..e9c156d2 100755 --- a/lib/linter.sh +++ b/lib/linter.sh @@ -205,7 +205,7 @@ REPORT_OUTPUT_FOLDER="${DEFAULT_WORKSPACE}/${OUTPUT_FOLDER}" # Location for the ########################## FILE_ARRAY_ARM=() # Array of files to check FILE_ARRAY_BASH=() # Array of files to check -FILE_ARRAY_CLOUDFORMATION=() # Array of files to check +FILE_ARRAY_CLOUDFORMATION=() # Array of files to check FILE_ARRAY_CLOJURE=() # Array of files to check FILE_ARRAY_COFFEESCRIPT=() # Array of files to check FILE_ARRAY_CSS=() # Array of files to check @@ -242,7 +242,7 @@ FILE_ARRAY_YML=() # Array of files to check ERRORS_FOUND_ANSIBLE=0 # Count of errors found ERRORS_FOUND_ARM=0 # Count of errors found ERRORS_FOUND_BASH=0 # Count of errors found -ERRORS_FOUND_CLOUDFORMATION=0 # Count of errors found +ERRORS_FOUND_CLOUDFORMATION=0 # Count of errors found ERRORS_FOUND_CLOJURE=0 # Count of errors found ERRORS_FOUND_CSS=0 # Count of errors found ERRORS_FOUND_COFFEESCRIPT=0 # Count of errors found @@ -962,42 +962,18 @@ Footer() { ############################### # Exit with 1 if errors found # ############################### - elif [ "${ERRORS_FOUND_ANSIBLE}" -ne 0 ] || - [ "${ERRORS_FOUND_ARM}" -ne 0 ] || - [ "${ERRORS_FOUND_BASH}" -ne 0 ] || - [ "${ERRORS_FOUND_CLOUDFORMATION}" -ne 0 ] || - [ "${ERRORS_FOUND_CLOJURE}" -ne 0 ] || - [ "${ERRORS_FOUND_COFFEESCRIPT}" -ne 0 ] || - [ "${ERRORS_FOUND_CSS}" -ne 0 ] || - [ "${ERRORS_FOUND_DART}" -ne 0 ] || - [ "${ERRORS_FOUND_DOCKER}" -ne 0 ] || - [ "${ERRORS_FOUND_ENV}" -ne 0 ] || - [ "${ERRORS_FOUND_GO}" -ne 0 ] || - [ "${ERRORS_FOUND_HTML}" -ne 0 ] || - [ "${ERRORS_FOUND_JAVASCRIPT_ES}" -ne 0 ] || - [ "${ERRORS_FOUND_JAVASCRIPT_STANDARD}" -ne 0 ] || - [ "${ERRORS_FOUND_JSON}" -ne 0 ] || - [ "${ERRORS_FOUND_JSX}" -ne 0 ] || - [ "${ERRORS_FOUND_KOTLIN}" -ne 0 ] || - [ "${ERRORS_FOUND_MARKDOWN}" -ne 0 ] || - [ "${ERRORS_FOUND_OPENAPI}" -ne 0 ] || - [ "${ERRORS_FOUND_PERL}" -ne 0 ] || - [ "${ERRORS_FOUND_PHP}" -ne 0 ] || - [ "${ERRORS_FOUND_POWERSHELL}" -ne 0 ] || - [ "${ERRORS_FOUND_PROTOBUF}" -ne 0 ] || - [ "${ERRORS_FOUND_PYTHON}" -ne 0 ] || - [ "${ERRORS_FOUND_RAKU}" -ne 0 ] || - [ "${ERRORS_FOUND_RUBY}" -ne 0 ] || - [ "${ERRORS_FOUND_STATES}" -ne 0 ] || - [ "${ERRORS_FOUND_TERRAFORM}" -ne 0 ] || - [ "${ERRORS_FOUND_TSX}" -ne 0 ] || - [ "${ERRORS_FOUND_TYPESCRIPT_ES}" -ne 0 ] || - [ "${ERRORS_FOUND_TYPESCRIPT_STANDARD}" -ne 0 ] || - [ "${ERRORS_FOUND_XML}" -ne 0 ] || - [ "${ERRORS_FOUND_YML}" -ne 0 ]; then - # Failed exit - echo -e "${NC}${F[R]}Exiting with errors found!${NC}" - exit 1 + elif + # Loop through all languages + for LANGUAGE in "${LANGUAGE_ARRAY[@]}"; do + # build the variable + ERRORS_FOUND_LANGUAGE="ERRORS_FOUND_${LANGUAGE}" + # Check if error was found + if [ "${!ERRORS_FOUND_LANGUAGE}" -ne 0 ]; then + # Failed exit + echo -e "${NC}${F[R]}Exiting with errors found!${NC}" + exit 1 + fi + done else ################# # Footer prints # From 1249a930b7c283571fa264c5b4420bcb90d469d1 Mon Sep 17 00:00:00 2001 From: Lucas Gravley <29484535+admiralAwkbar@users.noreply.github.com> Date: Wed, 22 Jul 2020 14:49:26 -0500 Subject: [PATCH 5/7] making cool moves --- lib/linter.sh | 83 +++++++++++++++++++++++++++++++-------------------- 1 file changed, 50 insertions(+), 33 deletions(-) diff --git a/lib/linter.sh b/lib/linter.sh index e9c156d2..7346b0ec 100755 --- a/lib/linter.sh +++ b/lib/linter.sh @@ -890,12 +890,12 @@ CallStatusAPI() { fi } ################################################################################ -#### Function Footer ########################################################### -Footer() { +#### Function Reports ########################################################## +Reports() { echo "" echo "----------------------------------------------" echo "----------------------------------------------" - echo "The script has completed" + echo "Generated reports:" echo "----------------------------------------------" echo "----------------------------------------------" echo "" @@ -907,6 +907,25 @@ Footer() { echo "Reports generated in folder ${REPORT_OUTPUT_FOLDER}" fi + ################################ + # Prints for warnings if found # + ################################ + for TEST in "${WARNING_ARRAY_TEST[@]}"; do + echo -e "${NC}${F[Y]}WARN!${NC} Expected file to compare with was not found for ${TEST}${NC}" + done + +} +################################################################################ +#### Function Footer ########################################################### +Footer() { + echo "" + echo "----------------------------------------------" + echo "----------------------------------------------" + echo "The script has completed" + echo "----------------------------------------------" + echo "----------------------------------------------" + echo "" + #################################################### # Need to clean up the lanuage array of duplicates # #################################################### @@ -946,45 +965,38 @@ Footer() { fi done - ################################ - # Prints for warnings if found # - ################################ - for TEST in "${WARNING_ARRAY_TEST[@]}"; do - echo -e "${NC}${F[Y]}WARN!${NC} Expected file to compare with was not found for ${TEST}${NC}" - done - ################################## # Exit with 0 if errors disabled # ################################## if [ "${DISABLE_ERRORS}" == "true" ]; then echo -e "${NC}${F[Y]}WARN!${NC} Exiting with exit code:[0] as:[DISABLE_ERRORS] was set to:[${DISABLE_ERRORS}]${NC}" exit 0 + fi + ############################### # Exit with 1 if errors found # ############################### - elif - # Loop through all languages - for LANGUAGE in "${LANGUAGE_ARRAY[@]}"; do - # build the variable - ERRORS_FOUND_LANGUAGE="ERRORS_FOUND_${LANGUAGE}" - # Check if error was found - if [ "${!ERRORS_FOUND_LANGUAGE}" -ne 0 ]; then - # Failed exit - echo -e "${NC}${F[R]}Exiting with errors found!${NC}" - exit 1 - fi - done - else - ################# - # Footer prints # - ################# - echo "" - echo -e "${NC}${F[G]}All file(s) linted successfully with no errors detected${NC}" - echo "----------------------------------------------" - echo "" - # Successful exit - exit 0 - fi + # Loop through all languages + for LANGUAGE in "${LANGUAGE_ARRAY[@]}"; do + # build the variable + ERRORS_FOUND_LANGUAGE="ERRORS_FOUND_${LANGUAGE}" + # Check if error was found + if [ "${!ERRORS_FOUND_LANGUAGE}" -ne 0 ]; then + # Failed exit + echo -e "${NC}${F[R]}Exiting with errors found!${NC}" + exit 1 + fi + done + + ######################## + # Footer prints Exit 0 # + ######################## + echo "" + echo -e "${NC}${F[G]}All file(s) linted successfully with no errors detected${NC}" + echo "----------------------------------------------" + echo "" + # Successful exit + exit 0 } ################################################################################ @@ -1513,6 +1525,11 @@ if [ "${VALIDATE_STATES}" == "true" ]; then LintCodebase "STATES" "asl-validator" "asl-validator --json-path" ".*\.\(json\)\$" "${FILE_ARRAY_STATES[@]}" fi +########### +# Reports # +########### +Reports + ########## # Footer # ########## From da67a885357540760fcbaec9b76589d3522f81f7 Mon Sep 17 00:00:00 2001 From: Lucas Gravley <29484535+admiralAwkbar@users.noreply.github.com> Date: Wed, 22 Jul 2020 14:59:03 -0500 Subject: [PATCH 6/7] fix fun else --- lib/linter.sh | 12 +++++------- 1 file changed, 5 insertions(+), 7 deletions(-) diff --git a/lib/linter.sh b/lib/linter.sh index 7346b0ec..e080cfeb 100755 --- a/lib/linter.sh +++ b/lib/linter.sh @@ -954,14 +954,12 @@ Footer() { # Create status API for Failed language # ######################################### CallStatusAPI "${LANGUAGE}" "error" - else + ###################################### + # Check if we validated the langauge # + ###################################### + elif [ "${!ERROR_COUNTER}" -eq 0 ] && [[ "${UNIQUE_LINTED_ARRAY[*]}" =~ ${LANGUAGE} ]]; then # No errors found when linting the language - ###################################### - # Check if we validated the langauge # - ###################################### - if [[ "${UNIQUE_LINTED_ARRAY[*]}" =~ ${LANGUAGE} ]]; then - CallStatusAPI "${LANGUAGE}" "success" - fi + CallStatusAPI "${LANGUAGE}" "success" fi done From a0ff3df431437a683ccffa149a054cb03aaf407e Mon Sep 17 00:00:00 2001 From: Lucas Gravley <29484535+admiralAwkbar@users.noreply.github.com> Date: Wed, 22 Jul 2020 15:41:08 -0500 Subject: [PATCH 7/7] imports and exports --- lib/linter.sh | 99 ++++++++++++++++++++++++++++++++++----------------- 1 file changed, 66 insertions(+), 33 deletions(-) diff --git a/lib/linter.sh b/lib/linter.sh index e080cfeb..3ac5ea63 100755 --- a/lib/linter.sh +++ b/lib/linter.sh @@ -239,39 +239,72 @@ FILE_ARRAY_YML=() # Array of files to check ############ # Counters # ############ -ERRORS_FOUND_ANSIBLE=0 # Count of errors found -ERRORS_FOUND_ARM=0 # Count of errors found -ERRORS_FOUND_BASH=0 # Count of errors found -ERRORS_FOUND_CLOUDFORMATION=0 # Count of errors found -ERRORS_FOUND_CLOJURE=0 # Count of errors found -ERRORS_FOUND_CSS=0 # Count of errors found -ERRORS_FOUND_COFFEESCRIPT=0 # Count of errors found -ERRORS_FOUND_DART=0 # Count of errors found -ERRORS_FOUND_DOCKER=0 # Count of errors found -ERRORS_FOUND_ENV=0 # Count of errors found -ERRORS_FOUND_GO=0 # Count of errors found -ERRORS_FOUND_HTML=0 # Count of errors found -ERRORS_FOUND_JAVASCRIPT_STANDARD=0 # Count of errors found -ERRORS_FOUND_JAVASCRIPT_ES=0 # Count of errors found -ERRORS_FOUND_JSON=0 # Count of errors found -ERRORS_FOUND_JSX=0 # Count of errors found -ERRORS_FOUND_KOTLIN=0 # Count of errors found -ERRORS_FOUND_MARKDOWN=0 # Count of errors found -ERRORS_FOUND_OPENAPI=0 # Count of errors found -ERRORS_FOUND_PERL=0 # Count of errors found -ERRORS_FOUND_PHP=0 # Count of errors found -ERRORS_FOUND_POWERSHELL=0 # Count of errors found -ERRORS_FOUND_PROTOBUF=0 # Count of errors found -ERRORS_FOUND_PYTHON=0 # Count of errors found -ERRORS_FOUND_RAKU=0 # Count of errors found -ERRORS_FOUND_RUBY=0 # Count of errors found -ERRORS_FOUND_STATES=0 # Count of errors found -ERRORS_FOUND_TERRAFORM=0 # Count of errors found -ERRORS_FOUND_TSX=0 # Count of errors found -ERRORS_FOUND_TYPESCRIPT_STANDARD=0 # Count of errors found -ERRORS_FOUND_TYPESCRIPT_ES=0 # Count of errors found -ERRORS_FOUND_XML=0 # Count of errors found -ERRORS_FOUND_YML=0 # Count of errors found +ERRORS_FOUND_ANSIBLE=0 # Count of errors found +export ERRORS_FOUND_ANSIBLE # Workaround SC2034 +ERRORS_FOUND_ARM=0 # Count of errors found +export ERRORS_FOUND_ARM # Workaround SC2034 +ERRORS_FOUND_BASH=0 # Count of errors found +export ERRORS_FOUND_BASH # Workaround SC2034 +ERRORS_FOUND_CLOUDFORMATION=0 # Count of errors found +export ERRORS_FOUND_CLOUDFORMATION # Workaround SC2034 +ERRORS_FOUND_CLOJURE=0 # Count of errors found +export ERRORS_FOUND_CLOJURE # Workaround SC2034 +ERRORS_FOUND_CSS=0 # Count of errors found +export ERRORS_FOUND_CSS # Workaround SC2034 +ERRORS_FOUND_COFFEESCRIPT=0 # Count of errors found +export ERRORS_FOUND_COFFEESCRIPT # Workaround SC2034 +ERRORS_FOUND_DART=0 # Count of errors found +export ERRORS_FOUND_DART # Workaround SC2034 +ERRORS_FOUND_DOCKER=0 # Count of errors found +export ERRORS_FOUND_DOCKER # Workaround SC2034 +ERRORS_FOUND_ENV=0 # Count of errors found +export ERRORS_FOUND_ENV # Workaround SC2034 +ERRORS_FOUND_GO=0 # Count of errors found +export ERRORS_FOUND_GO # Workaround SC2034 +ERRORS_FOUND_HTML=0 # Count of errors found +export ERRORS_FOUND_HTML # Workaround SC2034 +ERRORS_FOUND_JAVASCRIPT_STANDARD=0 # Count of errors found +export ERRORS_FOUND_JAVASCRIPT_STANDARD # Workaround SC2034 +ERRORS_FOUND_JAVASCRIPT_ES=0 # Count of errors found +export ERRORS_FOUND_JAVASCRIPT_ES # Workaround SC2034 +ERRORS_FOUND_JSON=0 # Count of errors found +export ERRORS_FOUND_JSON # Workaround SC2034 +ERRORS_FOUND_JSX=0 # Count of errors found +export ERRORS_FOUND_JSX # Workaround SC2034 +ERRORS_FOUND_KOTLIN=0 # Count of errors found +export ERRORS_FOUND_KOTLIN # Workaround SC2034 +ERRORS_FOUND_MARKDOWN=0 # Count of errors found +export ERRORS_FOUND_MARKDOWN # Workaround SC2034 +ERRORS_FOUND_OPENAPI=0 # Count of errors found +export ERRORS_FOUND_OPENAPI # Workaround SC2034 +ERRORS_FOUND_PERL=0 # Count of errors found +export ERRORS_FOUND_PERL # Workaround SC2034 +ERRORS_FOUND_PHP=0 # Count of errors found +export ERRORS_FOUND_PHP # Workaround SC2034 +ERRORS_FOUND_POWERSHELL=0 # Count of errors found +export ERRORS_FOUND_POWERSHELL # Workaround SC2034 +ERRORS_FOUND_PROTOBUF=0 # Count of errors found +export ERRORS_FOUND_PROTOBUF # Workaround SC2034 +ERRORS_FOUND_PYTHON=0 # Count of errors found +export ERRORS_FOUND_PYTHON # Workaround SC2034 +ERRORS_FOUND_RAKU=0 # Count of errors found +export ERRORS_FOUND_RAKU # Workaround SC2034 +ERRORS_FOUND_RUBY=0 # Count of errors found +export ERRORS_FOUND_RUBY # Workaround SC2034 +ERRORS_FOUND_STATES=0 # Count of errors found +export ERRORS_FOUND_STATES # Workaround SC2034 +ERRORS_FOUND_TERRAFORM=0 # Count of errors found +export ERRORS_FOUND_TERRAFORM # Workaround SC2034 +ERRORS_FOUND_TSX=0 # Count of errors found +export ERRORS_FOUND_TSX # Workaround SC2034 +ERRORS_FOUND_TYPESCRIPT_STANDARD=0 # Count of errors found +export ERRORS_FOUND_TYPESCRIPT_STANDARD # Workaround SC2034 +ERRORS_FOUND_TYPESCRIPT_ES=0 # Count of errors found +export ERRORS_FOUND_TYPESCRIPT_ES # Workaround SC2034 +ERRORS_FOUND_XML=0 # Count of errors found +export ERRORS_FOUND_XML # Workaround SC2034 +ERRORS_FOUND_YML=0 # Count of errors found +export ERRORS_FOUND_YML # Workaround SC2034 ################################################################################ ########################## FUNCTIONS BELOW #####################################