2020-11-12 11:27:34 -06:00
#!/usr/bin/env bash
2021-07-19 09:28:49 -05:00
DetectActions( ) {
FILE = " ${ 1 } "
2024-01-06 18:39:39 +01:00
if [ " ${ VALIDATE_GITHUB_ACTIONS } " = = "false" ] ; then
debug " Don't check if ${ FILE } is a GitHub Actions file because VALIDATE_GITHUB_ACTIONS is: ${ VALIDATE_GITHUB_ACTIONS } "
return 1
fi
2021-07-19 09:28:49 -05:00
debug " Checking if ${ FILE } is a GitHub Actions file... "
# Check if in the users .github, or the super linter test suite
2023-12-15 09:50:35 +01:00
if [ [ " $( dirname " ${ FILE } " ) " = = *".github/workflows" * ] ] || [ [ " $( dirname " ${ FILE } " ) " = = *" ${ TEST_CASE_FOLDER } /github_actions " * ] ] ; then
2021-07-19 09:28:49 -05:00
debug " ${ FILE } is GitHub Actions file. "
return 0
else
debug " ${ FILE } is NOT GitHub Actions file. "
return 1
fi
}
2024-01-06 18:39:39 +01:00
2020-11-12 11:27:34 -06:00
DetectOpenAPIFile( ) {
FILE = " ${ 1 } "
2024-01-06 18:39:39 +01:00
if [ " ${ VALIDATE_OPENAPI } " = = "false" ] ; then
debug " Don't check if ${ FILE } is an OpenAPI file because VALIDATE_OPENAPI is: ${ VALIDATE_OPENAPI } "
return 1
fi
2020-11-12 11:27:34 -06:00
2024-01-06 18:39:39 +01:00
debug " Checking if ${ FILE } is an OpenAPI file... "
2020-11-12 11:27:34 -06:00
2024-01-06 18:39:39 +01:00
if grep -E '"openapi":|"swagger":|^openapi:|^swagger:' " ${ FILE } " >/dev/null; then
2021-01-27 20:47:34 +01:00
debug " ${ FILE } is an OpenAPI descriptor "
2020-11-12 11:27:34 -06:00
return 0
else
2021-01-27 20:47:34 +01:00
debug " ${ FILE } is NOT an OpenAPI descriptor "
2020-11-12 11:27:34 -06:00
return 1
fi
}
2024-01-06 18:39:39 +01:00
2020-11-12 11:27:34 -06:00
DetectTektonFile( ) {
FILE = " ${ 1 } "
2024-01-06 18:39:39 +01:00
if [ " ${ VALIDATE_TEKTON } " = = "false" ] ; then
debug " Don't check if ${ FILE } is a Tekton file because VALIDATE_TEKTON is: ${ VALIDATE_TEKTON } "
return 1
fi
2020-11-12 11:27:34 -06:00
debug " Checking if ${ FILE } is a Tekton file... "
2024-01-06 18:39:39 +01:00
if grep -q -E 'apiVersion: tekton' " ${ FILE } " >/dev/null; then
2020-11-12 11:27:34 -06:00
return 0
else
return 1
fi
}
2024-01-06 18:39:39 +01:00
2020-11-12 11:27:34 -06:00
DetectARMFile( ) {
2024-01-06 18:39:39 +01:00
FILE = " ${ 1 } "
if [ " ${ VALIDATE_ARM } " = = "false" ] ; then
debug " Don't check if ${ FILE } is an ARM file because VALIDATE_ARM is: ${ VALIDATE_ARM } "
return 1
fi
2020-11-12 11:27:34 -06:00
debug " Checking if ${ FILE } is an ARM file... "
2024-01-06 18:39:39 +01:00
if grep -E 'schema.management.azure.com' " ${ FILE } " >/dev/null; then
2020-11-12 11:27:34 -06:00
return 0
else
return 1
fi
}
2024-01-06 18:39:39 +01:00
2020-11-12 11:27:34 -06:00
DetectCloudFormationFile( ) {
2024-01-06 18:39:39 +01:00
FILE = " ${ 1 } "
if [ " ${ VALIDATE_CLOUDFORMATION } " = = "false" ] ; then
debug " Don't check if ${ FILE } is a CloudFormation file because VALIDATE_CLOUDFORMATION is: ${ VALIDATE_CLOUDFORMATION } "
return 1
fi
2020-11-12 11:27:34 -06:00
debug " Checking if ${ FILE } is a Cloud Formation file... "
# https://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/template-formats.html
# AWSTemplateFormatVersion is optional
2024-01-06 18:39:39 +01:00
# Check if file has AWS Template info
2020-11-12 11:27:34 -06:00
if grep -q 'AWSTemplateFormatVersion' " ${ FILE } " >/dev/null; then
return 0
fi
2024-01-06 18:39:39 +01:00
# See if it contains AWS References
2020-11-12 11:27:34 -06:00
if grep -q -E '(AWS|Alexa|Custom)::' " ${ FILE } " >/dev/null; then
return 0
fi
return 1
}
2024-01-06 18:39:39 +01:00
2020-11-12 11:27:34 -06:00
DetectKubernetesFile( ) {
2024-01-06 18:39:39 +01:00
FILE = " ${ 1 } "
if [ " ${ VALIDATE_KUBERNETES_KUBECONFORM } " = = "false" ] ; then
debug " Don't check if ${ FILE } is a Kubernetes file because VALIDATE_KUBERNETES_KUBECONFORM is: ${ VALIDATE_KUBERNETES_KUBECONFORM } "
return 1
fi
2020-11-12 11:27:34 -06:00
debug " Checking if ${ FILE } is a Kubernetes descriptor... "
2022-03-14 15:22:58 +01:00
if grep -q -v 'kustomize.config.k8s.io' " ${ FILE } " &&
grep -q -v "tekton" " ${ FILE } " &&
2023-06-20 12:27:03 -07:00
grep -q -E '(^apiVersion):' " ${ FILE } " &&
grep -q -E '(^kind):' " ${ FILE } " ; then
2020-11-12 11:27:34 -06:00
debug " ${ FILE } is a Kubernetes descriptor "
return 0
fi
debug " ${ FILE } is NOT a Kubernetes descriptor "
return 1
}
2024-01-06 18:39:39 +01:00
2020-11-12 11:27:34 -06:00
DetectAWSStatesFIle( ) {
2024-01-06 18:39:39 +01:00
FILE = " ${ 1 } "
if [ " ${ VALIDATE_STATES } " = = "false" ] ; then
debug " Don't check if ${ FILE } is an AWS states file because VALIDATE_STATES is: ${ VALIDATE_STATES } "
return 1
fi
2020-11-12 11:27:34 -06:00
debug " Checking if ${ FILE } is a AWS states descriptor... "
# https://states-language.net/spec.html#example
2021-09-10 04:03:41 +10:00
if grep -q '"Resource": *"arn' " ${ FILE } " &&
grep -q '"States"' " ${ FILE } " ; then
2020-11-12 11:27:34 -06:00
return 0
fi
return 1
}
2024-01-06 18:39:39 +01:00
2020-11-12 11:27:34 -06:00
function GetFileType( ) {
# Need to run the file through the 'file' exec to help determine
# The type of file being parsed
FILE = " $1 "
GET_FILE_TYPE_CMD = $( file " ${ FILE } " 2>& 1)
echo " ${ GET_FILE_TYPE_CMD } "
}
2024-01-06 18:39:39 +01:00
2020-11-12 11:27:34 -06:00
function CheckFileType( ) {
# Need to run the file through the 'file' exec to help determine
# The type of file being parsed
2024-01-30 20:24:55 +01:00
local FILE
2020-11-12 11:27:34 -06:00
FILE = " $1 "
2024-01-30 20:24:55 +01:00
local GET_FILE_TYPE_CMD
2020-11-12 11:27:34 -06:00
GET_FILE_TYPE_CMD = " $( GetFileType " $FILE " ) "
2024-01-11 20:44:16 +01:00
local FILE_TYPE_MESSAGE
2020-11-12 11:27:34 -06:00
if [ [ ${ GET_FILE_TYPE_CMD } = = *"Ruby script" * ] ] ; then
2024-01-11 20:44:16 +01:00
FILE_TYPE_MESSAGE = " Found Ruby script without extension ( ${ FILE } ). Rename the file with proper extension for Ruby files. "
2024-01-30 20:24:55 +01:00
echo " ${ FILE } " >>" ${ FILE_ARRAYS_DIRECTORY_PATH } /file-array-RUBY "
2022-01-19 11:09:26 -06:00
elif [ [ ${ GET_FILE_TYPE_CMD } = = *"Python script" * ] ] ; then
2024-01-11 20:44:16 +01:00
FILE_TYPE_MESSAGE = " Found Python script without extension ( ${ FILE } ). Rename the file with proper extension for Python files. "
2024-01-30 20:24:55 +01:00
echo " ${ FILE } " >>" ${ FILE_ARRAYS_DIRECTORY_PATH } /file-array-PYTHON "
2022-01-19 11:09:26 -06:00
elif [ [ ${ GET_FILE_TYPE_CMD } = = *"Perl script" * ] ] ; then
2024-01-11 20:44:16 +01:00
FILE_TYPE_MESSAGE = " Found Perl script without extension ( ${ FILE } ). Rename the file with proper extension for Perl files. "
2024-01-30 20:24:55 +01:00
echo " ${ FILE } " >>" ${ FILE_ARRAYS_DIRECTORY_PATH } /file-array-PERL "
2020-11-12 11:27:34 -06:00
else
2024-01-11 20:44:16 +01:00
FILE_TYPE_MESSAGE = " Failed to get file type for: ${ FILE } "
fi
if [ " ${ SUPPRESS_FILE_TYPE_WARN } " = = "false" ] ; then
warn " ${ FILE_TYPE_MESSAGE } "
else
debug " ${ FILE_TYPE_MESSAGE } "
2020-11-12 11:27:34 -06:00
fi
}
2024-01-06 18:39:39 +01:00
2020-11-12 11:27:34 -06:00
function GetFileExtension( ) {
FILE = " $1 "
2024-01-11 21:30:00 +01:00
# We want a lowercase value
local -l FILE_TYPE
# Extract the file extension
2020-11-12 11:27:34 -06:00
FILE_TYPE = ${ FILE ##*. }
echo " $FILE_TYPE "
}
2024-01-06 18:39:39 +01:00
2020-11-12 11:27:34 -06:00
function IsValidShellScript( ) {
FILE = " $1 "
2024-01-06 18:39:39 +01:00
if [ " ${ VALIDATE_BASH } " = = "false" ] && [ " ${ VALIDATE_BASH_EXEC } " = = "false" ] && [ " ${ VALIDATE_SHELL_SHFMT } " = = "false" ] ; then
debug " Don't check if ${ FILE } is a shell script because VALIDATE_BASH, VALIDATE_BASH_EXEC, and VALIDATE_SHELL_SHFMT are set to: ${ VALIDATE_BASH } , ${ VALIDATE_BASH_EXEC } , ${ VALIDATE_SHELL_SHFMT } "
return 1
fi
2020-11-12 11:27:34 -06:00
FILE_EXTENSION = " $( GetFileExtension " $FILE " ) "
GET_FILE_TYPE_CMD = " $( GetFileType " $FILE " ) "
2024-02-09 19:43:58 +01:00
debug " File:[ ${ FILE } ], File extension:[ ${ FILE_EXTENSION } ], File type: [ ${ GET_FILE_TYPE_CMD } ] "
2020-11-12 11:27:34 -06:00
if [ [ " ${ FILE_EXTENSION } " = = "zsh" ] ] ||
[ [ ${ GET_FILE_TYPE_CMD } = = *"zsh script" * ] ] ; then
warn " $FILE is a ZSH script. Skipping... "
return 1
fi
if [ " ${ FILE_EXTENSION } " = = "sh" ] ||
[ " ${ FILE_EXTENSION } " = = "bash" ] ||
2021-07-19 22:30:44 +08:00
[ " ${ FILE_EXTENSION } " = = "bats" ] ||
2020-11-12 11:27:34 -06:00
[ " ${ FILE_EXTENSION } " = = "dash" ] ||
[ " ${ FILE_EXTENSION } " = = "ksh" ] ; then
debug " $FILE is a valid shell script (has a valid extension: ${ FILE_EXTENSION } ) "
return 0
fi
if [ [ " ${ GET_FILE_TYPE_CMD } " = = *"POSIX shell script" * ] ] ||
[ [ ${ GET_FILE_TYPE_CMD } = = *"Bourne-Again shell script" * ] ] ||
[ [ ${ GET_FILE_TYPE_CMD } = = *"dash script" * ] ] ||
[ [ ${ GET_FILE_TYPE_CMD } = = *"ksh script" * ] ] ||
[ [ ${ GET_FILE_TYPE_CMD } = = *"/usr/bin/env sh script" * ] ] ; then
debug " $FILE is a valid shell script (has a valid file type: ${ GET_FILE_TYPE_CMD } ) "
return 0
fi
2024-02-09 19:43:58 +01:00
debug " $FILE is NOT a supported shell script. Skipping "
2020-11-12 11:27:34 -06:00
return 1
}
2024-01-06 18:39:39 +01:00
2024-02-27 13:17:22 -05:00
# HasNoShebang returns true if a file has no shebang line
function HasNoShebang( ) {
local FILE SHEBANG FIRST_TWO
FILE = " ${ 1 } "
SHEBANG = '#!'
IFS = read -rn2 FIRST_TWO <" ${ FILE } "
if [ [ ${ FIRST_TWO } = = " ${ SHEBANG } " ] ] ; then
return 1
fi
debug " ${ FILE } doesn't contain a shebang "
return 0
}
2021-06-28 13:59:11 +01:00
function IsGenerated( ) {
FILE = " $1 "
2024-01-06 18:39:39 +01:00
if [ " ${ IGNORE_GENERATED_FILES } " = = "false" ] ; then
debug " Don't check if ${ FILE } is generated because IGNORE_GENERATED_FILES is: ${ IGNORE_GENERATED_FILES } "
return 1
fi
2021-06-28 13:59:11 +01:00
2024-01-06 18:39:39 +01:00
if ! grep -q "@generated" " $FILE " ; then
2024-02-09 19:43:58 +01:00
debug " File:[ ${ FILE } ] is not generated, because it doesn't have @generated marker "
2021-06-28 13:59:11 +01:00
return 1
fi
2024-01-06 18:39:39 +01:00
if grep -q "@not-generated" " $FILE " ; then
2024-02-09 19:43:58 +01:00
debug " File:[ ${ FILE } ] is not-generated because it has @not-generated marker "
2021-06-28 13:59:11 +01:00
return 1
else
2024-02-09 19:43:58 +01:00
debug " File:[ ${ FILE } ] is generated because it has @generated marker "
2021-06-28 13:59:11 +01:00
return 0
fi
}
2024-01-06 18:39:39 +01:00
2024-01-30 20:24:55 +01:00
# We need these functions when building the file list with paralle
export -f CheckFileType
export -f DetectActions
export -f DetectARMFile
export -f DetectAWSStatesFIle
export -f DetectCloudFormationFile
export -f DetectKubernetesFile
export -f DetectOpenAPIFile
export -f DetectTektonFile
export -f GetFileExtension
export -f GetFileType
export -f IsValidShellScript
2024-02-27 13:17:22 -05:00
export -f HasNoShebang
2024-01-30 20:24:55 +01:00
export -f IsGenerated
2021-09-10 09:43:20 -05:00
function RunAdditionalInstalls( ) {
2024-01-30 20:24:55 +01:00
if [ -z " ${ FILE_ARRAYS_DIRECTORY_PATH } " ] || [ ! -d " ${ FILE_ARRAYS_DIRECTORY_PATH } " ] ; then
fatal " FILE_ARRAYS_DIRECTORY_PATH (set to ${ FILE_ARRAYS_DIRECTORY_PATH } ) is empty or doesn't exist "
fi
2021-09-10 09:43:20 -05:00
##################################
# Run installs for Psalm and PHP #
##################################
2024-01-30 20:24:55 +01:00
if [ " ${ VALIDATE_PHP_PSALM } " = = "true" ] && [ -e " ${ FILE_ARRAYS_DIRECTORY_PATH } /file-array-PHP_PSALM " ] ; then
2021-09-10 09:43:20 -05:00
# found PHP files and were validating it, need to composer install
2024-02-20 20:05:39 +01:00
info " Found PHP files to validate, and VALIDATE_PHP_PSALM is set to ${ VALIDATE_PHP_PSALM } . Check if we need to run composer install "
mapfile -t COMPOSER_FILE_ARRAY < <( find " ${ GITHUB_WORKSPACE } " -name composer.json 2>& 1)
debug " COMPOSER_FILE_ARRAY contents: ${ COMPOSER_FILE_ARRAY [*] } "
2021-09-10 09:43:20 -05:00
if [ " ${# COMPOSER_FILE_ARRAY [@] } " -ne 0 ] ; then
for LINE in " ${ COMPOSER_FILE_ARRAY [@] } " ; do
2024-02-20 20:05:39 +01:00
local COMPOSER_PATH
2022-03-23 17:43:28 +01:00
COMPOSER_PATH = $( dirname " ${ LINE } " 2>& 1)
2024-02-20 20:05:39 +01:00
info " Found Composer file: ${ LINE } "
local COMPOSER_CMD
if ! COMPOSER_CMD = $( cd " ${ COMPOSER_PATH } " && composer install --no-progress -q 2>& 1) ; then
fatal " Failed to run composer install for ${ COMPOSER_PATH } . Output: ${ COMPOSER_CMD } "
2021-09-10 09:43:20 -05:00
else
2024-02-20 20:05:39 +01:00
info "Successfully ran composer install."
2021-09-10 09:43:20 -05:00
fi
2024-02-20 20:05:39 +01:00
debug " Composer install output: ${ COMPOSER_CMD } "
2021-09-10 09:43:20 -05:00
done
fi
fi
2021-10-05 15:46:38 +02:00
2024-02-06 15:53:30 +01:00
if [ " ${ VALIDATE_PYTHON_MYPY } " = = "true" ] && [ -e " ${ FILE_ARRAYS_DIRECTORY_PATH } /file-array-PYTHON_MYPY " ] ; then
local MYPY_CACHE_DIRECTORY_PATH
MYPY_CACHE_DIRECTORY_PATH = " ${ GITHUB_WORKSPACE } /.mypy_cache "
debug " Create MyPy cache directory: ${ MYPY_CACHE_DIRECTORY_PATH } "
2024-02-10 10:16:31 +01:00
mkdir -p " ${ MYPY_CACHE_DIRECTORY_PATH } "
2024-02-06 15:53:30 +01:00
fi
2021-10-05 15:46:38 +02:00
###############################
# Run installs for R language #
###############################
2024-01-30 20:24:55 +01:00
if [ " ${ VALIDATE_R } " = = "true" ] && [ -e " ${ FILE_ARRAYS_DIRECTORY_PATH } /file-array-R " ] ; then
2021-10-05 15:46:38 +02:00
info "Detected R Language files to lint."
2024-02-20 20:05:39 +01:00
info " Installing the R package in: ${ GITHUB_WORKSPACE } "
local BUILD_CMD
if ! BUILD_CMD = $( R CMD build " ${ GITHUB_WORKSPACE } " 2>& 1) ; then
warn " Failed to build R package in ${ GITHUB_WORKSPACE } . Output: ${ BUILD_CMD } "
2021-10-05 15:46:38 +02:00
else
2024-02-20 20:05:39 +01:00
local BUILD_PKG
if ! BUILD_PKG = $( cd " ${ GITHUB_WORKSPACE } " && echo *.tar.gz 2>& 1) ; then
warn " Failed to echo R archives. Output: ${ BUILD_PKG } "
2021-10-05 15:46:38 +02:00
fi
2024-02-20 20:05:39 +01:00
debug " echo R archives output: ${ BUILD_PKG } "
local INSTALL_CMD
if ! INSTALL_CMD = $( cd " ${ GITHUB_WORKSPACE } " && R -e "remotes::install_local('.', dependencies=T)" 2>& 1) ; then
warn " Failed to install the R package. Output: ${ BUILD_PKG } ] "
fi
debug " R package install output: ${ INSTALL_CMD } "
2021-10-05 15:46:38 +02:00
fi
2024-01-30 20:24:55 +01:00
if [ ! -f " ${ R_RULES_FILE_PATH_IN_ROOT } " ] ; then
info "No .lintr configuration file found, using defaults."
cp " $R_LINTER_RULES " " $GITHUB_WORKSPACE "
# shellcheck disable=SC2034
SUPER_LINTER_COPIED_R_LINTER_RULES_FILE = "true"
fi
2021-10-05 15:46:38 +02:00
fi
2022-03-28 13:32:04 -05:00
####################################
# Run installs for TFLINT language #
####################################
2024-01-30 20:24:55 +01:00
if [ " ${ VALIDATE_TERRAFORM_TFLINT } " = = "true" ] && [ -e " ${ FILE_ARRAYS_DIRECTORY_PATH } /file-array-TERRAFORM_TFLINT " ] ; then
2022-03-28 13:32:04 -05:00
info "Detected TFLint Language files to lint."
2024-02-20 20:05:39 +01:00
info " Initializing TFLint in ${ GITHUB_WORKSPACE } "
local BUILD_CMD
if ! BUILD_CMD = $( cd " ${ GITHUB_WORKSPACE } " && tflint --init -c " ${ TERRAFORM_TFLINT_LINTER_RULES } " 2>& 1) ; then
2023-12-15 10:29:34 +01:00
fatal " ERROR! Failed to initialize tflint with the ${ TERRAFORM_TFLINT_LINTER_RULES } config file: ${ BUILD_CMD } "
2022-03-28 13:32:04 -05:00
else
2023-12-15 10:29:34 +01:00
info " Successfully initialized tflint with the ${ TERRAFORM_TFLINT_LINTER_RULES } config file "
debug " Tflint output: ${ BUILD_CMD } "
2022-03-28 13:32:04 -05:00
fi
2024-01-30 20:24:55 +01:00
# Array to track directories where tflint was run
local -A TFLINT_SEEN_DIRS
TFLINT_SEEN_DIRS = ( )
for FILE in " ${ FILE_ARRAY_TERRAFORM_TFLINT [@] } " ; do
local DIR_NAME
DIR_NAME = $( dirname " ${ FILE } " 2>& 1)
debug " DIR_NAME for ${ FILE } : ${ DIR_NAME } "
# Check the cache to see if we've already prepped this directory for tflint
if [ [ ! -v " TFLINT_SEEN_DIRS[ ${ DIR_NAME } ] " ] ] ; then
debug " Configuring Terraform data directory for ${ DIR_NAME } "
# Define the path to an empty Terraform data directory
# (def: https://developer.hashicorp.com/terraform/cli/config/environment-variables#tf_data_dir)
# in case the user has a Terraform data directory already, and we don't
# want to modify it.
# TFlint considers this variable as well.
# Ref: https://github.com/terraform-linters/tflint/blob/master/docs/user-guide/compatibility.md#environment-variables
TF_DATA_DIR = " /tmp/.terraform- ${ TERRAFORM_TFLINT } - ${ DIR_NAME } "
# Fetch Terraform modules
debug " Fetch Terraform modules for ${ FILE } in ${ DIR_NAME } in ${ TF_DATA_DIR } "
local FETCH_TERRAFORM_MODULES_CMD
if ! FETCH_TERRAFORM_MODULES_CMD = " $( terraform get) " ; then
fatal " Error when fetching Terraform modules while linting ${ FILE } . Command output: ${ FETCH_TERRAFORM_MODULES_CMD } "
fi
debug " Fetch Terraform modules command for ${ FILE } output: ${ FETCH_TERRAFORM_MODULES_CMD } "
# Let the cache know we've seen this before
# Set the value to an arbitrary non-empty string.
TFLINT_SEEN_DIRS[ ${ DIR_NAME } ] = "false"
else
debug " Skip fetching Terraform modules for ${ FILE } because we already did that for ${ DIR_NAME } "
fi
done
fi
2024-02-09 23:57:01 +01:00
if [ " ${ VALIDATE_TERRAFORM_TERRASCAN } " = = "true" ] && [ -e " ${ FILE_ARRAYS_DIRECTORY_PATH } /file-array-TERRAFORM_TERRASCAN " ] ; then
info "Initializing Terrascan repository"
local -a TERRASCAN_INIT_COMMAND
TERRASCAN_INIT_COMMAND = ( terrascan init -c " ${ TERRAFORM_TERRASCAN_LINTER_RULES } " )
if [ [ " ${ LOG_DEBUG } " = = "true" ] ] ; then
TERRASCAN_INIT_COMMAND += ( --log-level "debug" )
fi
debug " Terrascan init command: ${ TERRASCAN_INIT_COMMAND [*] } "
local TERRASCAN_INIT_COMMAND_OUTPUT
if ! TERRASCAN_INIT_COMMAND_OUTPUT = " $( " ${ TERRASCAN_INIT_COMMAND [@] } " 2>& 1) " ; then
fatal " Error while initializing Terrascan:\n ${ TERRASCAN_INIT_COMMAND_OUTPUT } "
fi
debug " Terrascan init command output:\n ${ TERRASCAN_INIT_COMMAND_OUTPUT } "
fi
2024-01-30 20:24:55 +01:00
# Check if there's local configuration for the Raku linter
if [ -e " ${ GITHUB_WORKSPACE } /META6.json " ] ; then
cd " ${ GITHUB_WORKSPACE } " && zef install --deps-only --/test .
2022-03-28 13:32:04 -05:00
fi
2021-09-10 09:43:20 -05:00
}