2024-07-30 08:35:14 +02:00
|
|
|
#!/usr/bin/env bash
|
|
|
|
set -o errexit
|
|
|
|
set -o nounset
|
|
|
|
set -o pipefail
|
|
|
|
|
|
|
|
# Default log level
|
|
|
|
# shellcheck disable=SC2034
|
|
|
|
LOG_LEVEL="DEBUG"
|
|
|
|
|
|
|
|
# shellcheck source=/dev/null
|
|
|
|
source "lib/functions/log.sh"
|
|
|
|
|
2024-08-25 19:43:33 +02:00
|
|
|
# shellcheck source=/dev/null
|
|
|
|
source "test/testUtils.sh"
|
|
|
|
|
2024-07-30 08:35:14 +02:00
|
|
|
# shellcheck source=/dev/null
|
|
|
|
source "lib/functions/output.sh"
|
|
|
|
|
|
|
|
TEMP_WORKSPACE="$(pwd)/super-linter-output"
|
|
|
|
|
|
|
|
function InitWorkspace() {
|
|
|
|
CleanupWorkspace
|
|
|
|
mkdir -p "${TEMP_WORKSPACE}"
|
|
|
|
}
|
|
|
|
|
|
|
|
function CleanupWorkspace() {
|
|
|
|
rm -rf "${TEMP_WORKSPACE}"
|
|
|
|
}
|
|
|
|
|
2024-08-25 19:43:33 +02:00
|
|
|
CheckIfContentsDiff() {
|
|
|
|
local INPUT_FILE_CONTENT
|
|
|
|
INPUT_FILE_CONTENT="$(cat "${1}")"
|
|
|
|
local EXPECTED_CONTENT="${2}"
|
|
|
|
if [[ "${INPUT_FILE_CONTENT}" != "${EXPECTED_CONTENT}" ]]; then
|
|
|
|
fatal "\n${INPUT_FILE_CONTENT}\ncontents don't match the expected contents:\n${EXPECTED_CONTENT}"
|
2024-07-30 08:35:14 +02:00
|
|
|
else
|
2024-08-25 19:43:33 +02:00
|
|
|
debug "\n${INPUT_FILE_CONTENT}\ncontents match the expected contents\n${EXPECTED_CONTENT}"
|
2024-07-30 08:35:14 +02:00
|
|
|
fi
|
|
|
|
}
|
|
|
|
|
|
|
|
function WriteSummaryMarkdownTableHeaderTest() {
|
|
|
|
local FUNCTION_NAME
|
|
|
|
FUNCTION_NAME="${FUNCNAME[0]}"
|
|
|
|
info "${FUNCTION_NAME} start"
|
|
|
|
|
|
|
|
local RESULTS_FILE="${TEMP_WORKSPACE}/${FUNCTION_NAME}-output.md"
|
|
|
|
InitWorkspace
|
|
|
|
WriteSummaryHeader "${RESULTS_FILE}"
|
2024-08-25 19:43:33 +02:00
|
|
|
local EXPECTED_CONTENT
|
|
|
|
EXPECTED_CONTENT=$(
|
|
|
|
cat <<EOF
|
|
|
|
# Super-linter summary
|
|
|
|
|
|
|
|
| Language | Validation result |
|
|
|
|
| -------- | ----------------- |
|
|
|
|
EOF
|
|
|
|
)
|
|
|
|
CheckIfContentsDiff "${RESULTS_FILE}" "${EXPECTED_CONTENT}"
|
2024-07-30 08:35:14 +02:00
|
|
|
CleanupWorkspace
|
|
|
|
|
|
|
|
notice "${FUNCTION_NAME} PASS"
|
|
|
|
}
|
|
|
|
|
|
|
|
function WriteSummaryMarkdownTableLineSuccessTest() {
|
|
|
|
local FUNCTION_NAME
|
|
|
|
FUNCTION_NAME="${FUNCNAME[0]}"
|
|
|
|
info "${FUNCTION_NAME} start"
|
|
|
|
|
|
|
|
local RESULTS_FILE="${TEMP_WORKSPACE}/${FUNCTION_NAME}-output-${FUNCTION_NAME}.md"
|
|
|
|
InitWorkspace
|
|
|
|
WriteSummaryLineSuccess "${RESULTS_FILE}" "Test Language"
|
2024-08-25 19:43:33 +02:00
|
|
|
CheckIfContentsDiff "${RESULTS_FILE}" "| Test Language | Pass ✅ |"
|
2024-07-30 08:35:14 +02:00
|
|
|
CleanupWorkspace
|
|
|
|
|
|
|
|
notice "${FUNCTION_NAME} PASS"
|
|
|
|
}
|
|
|
|
|
|
|
|
function WriteSummaryMarkdownTableLineFailureTest() {
|
|
|
|
local FUNCTION_NAME
|
|
|
|
FUNCTION_NAME="${FUNCNAME[0]}"
|
|
|
|
info "${FUNCTION_NAME} start"
|
|
|
|
|
|
|
|
local RESULTS_FILE="${TEMP_WORKSPACE}/${FUNCTION_NAME}-output-${FUNCTION_NAME}.md"
|
|
|
|
InitWorkspace
|
|
|
|
WriteSummaryLineFailure "${RESULTS_FILE}" "Test Language"
|
2024-08-25 19:43:33 +02:00
|
|
|
CheckIfContentsDiff "${RESULTS_FILE}" "| Test Language | Fail ❌ |"
|
2024-07-30 08:35:14 +02:00
|
|
|
CleanupWorkspace
|
|
|
|
|
|
|
|
notice "${FUNCTION_NAME} PASS"
|
|
|
|
}
|
|
|
|
|
|
|
|
function WriteSummaryMarkdownTableFooterSuccessTest() {
|
|
|
|
local FUNCTION_NAME
|
|
|
|
FUNCTION_NAME="${FUNCNAME[0]}"
|
|
|
|
info "${FUNCTION_NAME} start"
|
|
|
|
|
|
|
|
local RESULTS_FILE="${TEMP_WORKSPACE}/${FUNCTION_NAME}-output-${FUNCTION_NAME}.md"
|
|
|
|
InitWorkspace
|
|
|
|
WriteSummaryFooterSuccess "${RESULTS_FILE}"
|
2024-08-25 19:43:33 +02:00
|
|
|
local EXPECTED_CONTENT
|
|
|
|
EXPECTED_CONTENT=$(
|
|
|
|
cat <<EOF
|
|
|
|
|
|
|
|
All files and directories linted successfully
|
|
|
|
EOF
|
|
|
|
)
|
|
|
|
CheckIfContentsDiff "${RESULTS_FILE}" "${EXPECTED_CONTENT}"
|
2024-07-30 08:35:14 +02:00
|
|
|
CleanupWorkspace
|
|
|
|
|
|
|
|
notice "${FUNCTION_NAME} PASS"
|
|
|
|
}
|
|
|
|
|
|
|
|
function WriteSummaryMarkdownTableFooterFailureTest() {
|
|
|
|
local FUNCTION_NAME
|
|
|
|
FUNCTION_NAME="${FUNCNAME[0]}"
|
|
|
|
info "${FUNCTION_NAME} start"
|
|
|
|
|
|
|
|
local RESULTS_FILE="${TEMP_WORKSPACE}/${FUNCTION_NAME}-output-${FUNCTION_NAME}.md"
|
|
|
|
InitWorkspace
|
|
|
|
WriteSummaryFooterFailure "${RESULTS_FILE}"
|
2024-08-25 19:43:33 +02:00
|
|
|
local EXPECTED_CONTENT
|
|
|
|
EXPECTED_CONTENT=$(
|
|
|
|
cat <<EOF
|
|
|
|
|
|
|
|
Super-linter detected linting errors
|
|
|
|
EOF
|
|
|
|
)
|
|
|
|
CheckIfContentsDiff "${RESULTS_FILE}" "${EXPECTED_CONTENT}"
|
2024-07-30 08:35:14 +02:00
|
|
|
CleanupWorkspace
|
|
|
|
|
|
|
|
notice "${FUNCTION_NAME} PASS"
|
|
|
|
}
|
|
|
|
|
|
|
|
WriteSummaryMarkdownTableHeaderTest
|
|
|
|
WriteSummaryMarkdownTableLineSuccessTest
|
|
|
|
WriteSummaryMarkdownTableLineFailureTest
|
|
|
|
WriteSummaryMarkdownTableFooterSuccessTest
|
|
|
|
WriteSummaryMarkdownTableFooterFailureTest
|