2022-01-20 23:09:34 +00:00
|
|
|
#!/bin/bash
|
2022-01-24 04:19:25 +00:00
|
|
|
set -euo pipefail
|
|
|
|
IFS=$'\n\t'
|
2022-01-20 23:09:34 +00:00
|
|
|
|
2024-07-06 14:48:47 +00:00
|
|
|
: "${IMAGE_TO_TEST:=itzg/minecraft-server}"
|
|
|
|
|
2022-01-20 23:09:34 +00:00
|
|
|
# go to script root directory
|
|
|
|
cd "$(dirname "$0")" || exit 1
|
|
|
|
|
2022-02-14 00:02:09 +00:00
|
|
|
outputContainerLog() {
|
|
|
|
logs=${1?}
|
|
|
|
|
|
|
|
echo "${folder} test scenario FAILED"
|
|
|
|
echo ":::::::::::: LOGS ::::::::::::::::
|
|
|
|
$logs
|
|
|
|
::::::::::::::::::::::::::::::::::
|
|
|
|
"
|
|
|
|
}
|
|
|
|
|
2022-06-18 14:56:53 +00:00
|
|
|
delta() {
|
|
|
|
startTime=${1?}
|
|
|
|
|
|
|
|
endTime=$(date +%s)
|
|
|
|
echo "$(( endTime - startTime )) seconds"
|
|
|
|
}
|
|
|
|
|
2022-01-24 04:19:25 +00:00
|
|
|
# tests that only run the setup files for things like downloads and configuration.
|
2022-01-20 23:09:34 +00:00
|
|
|
setupOnlyMinecraftTest(){
|
|
|
|
folder=$1
|
|
|
|
cd "$folder"
|
2022-01-24 04:19:25 +00:00
|
|
|
result=0
|
|
|
|
|
2022-01-28 00:42:33 +00:00
|
|
|
if [ -f require.sh ]; then
|
|
|
|
# require.sh scripts can check for environment variables, etc that are required for the test.
|
|
|
|
# The script should exit with a non-zero status to indicate the test requirements are missing
|
|
|
|
# and the test should be skipped
|
|
|
|
if ! bash require.sh; then
|
|
|
|
echo "${folder} SKIP"
|
|
|
|
cd ..
|
|
|
|
return 0
|
|
|
|
fi
|
|
|
|
fi
|
|
|
|
|
2022-09-10 17:58:32 +00:00
|
|
|
# false positive since it's used in delta calculations below
|
|
|
|
# shellcheck disable=SC2034
|
2022-06-18 14:56:53 +00:00
|
|
|
start=$(date +%s)
|
2024-10-13 23:04:11 +00:00
|
|
|
status=PASSED
|
|
|
|
verify=
|
2022-09-10 17:58:32 +00:00
|
|
|
if ! logs=$(docker compose run --rm -e SETUP_ONLY=true -e DEBUG="${DEBUG:-false}" mc 2>&1); then
|
2022-02-14 00:02:09 +00:00
|
|
|
outputContainerLog "$logs"
|
2022-01-24 04:19:25 +00:00
|
|
|
result=1
|
|
|
|
elif [ -f verify.sh ]; then
|
2024-10-13 23:04:11 +00:00
|
|
|
verify=" verify"
|
2024-07-06 14:48:47 +00:00
|
|
|
if ! docker run --rm --entrypoint bash -v "${PWD}/data":/data -v "${PWD}/verify.sh":/verify "${IMAGE_TO_TEST}" -e /verify; then
|
2024-10-13 23:04:11 +00:00
|
|
|
status=FAILED
|
2022-02-14 00:02:09 +00:00
|
|
|
outputContainerLog "$logs"
|
2022-01-24 04:19:25 +00:00
|
|
|
result=1
|
|
|
|
fi
|
|
|
|
fi
|
2024-10-13 23:04:11 +00:00
|
|
|
echo "${folder} ${status}${verify} in $(delta start)"
|
2022-01-24 04:19:25 +00:00
|
|
|
|
2022-07-12 03:27:07 +00:00
|
|
|
docker compose down -v --remove-orphans >& /dev/null
|
2022-01-20 23:09:34 +00:00
|
|
|
cd ..
|
2022-01-24 04:19:25 +00:00
|
|
|
|
|
|
|
return $result
|
2022-01-20 23:09:34 +00:00
|
|
|
}
|
|
|
|
|
2024-10-13 23:04:11 +00:00
|
|
|
foldersList=("$@")
|
|
|
|
image=""
|
|
|
|
|
|
|
|
# Go through each folder in setuponly and test setups
|
|
|
|
if (( $# == 0 )); then
|
2022-01-24 04:19:25 +00:00
|
|
|
readarray -t folders < <(find . -maxdepth 2 -mindepth 2 -name docker-compose.yml -printf '%h\n')
|
2024-10-13 23:04:11 +00:00
|
|
|
foldersList=("${folders[@]}")
|
|
|
|
image=" using $IMAGE_TO_TEST"
|
2022-01-24 04:19:25 +00:00
|
|
|
fi
|
2024-10-13 23:04:11 +00:00
|
|
|
|
|
|
|
for folder in "${foldersList[@]}"; do
|
|
|
|
echo "Starting Tests in ${folder}${image}"
|
|
|
|
setupOnlyMinecraftTest "$folder"
|
|
|
|
done
|