2024-04-25 17:55:41 -04:00
|
|
|
#!/bin/bash -e
|
|
|
|
#
|
|
|
|
|
|
|
|
set -E
|
|
|
|
set -o pipefail
|
|
|
|
|
|
|
|
if [ ! -x "$PWD/minio" ]; then
|
|
|
|
echo "minio executable binary not found in current directory"
|
|
|
|
exit 1
|
|
|
|
fi
|
|
|
|
|
|
|
|
WORK_DIR="$PWD/.verify-$RANDOM"
|
|
|
|
MINIO_CONFIG_DIR="$WORK_DIR/.minio"
|
|
|
|
MINIO=("$PWD/minio" --config-dir "$MINIO_CONFIG_DIR" server)
|
|
|
|
|
|
|
|
function start_minio_3_node() {
|
|
|
|
export MINIO_ROOT_USER=minio
|
|
|
|
export MINIO_ROOT_PASSWORD=minio123
|
|
|
|
export MINIO_ERASURE_SET_DRIVE_COUNT=6
|
|
|
|
export MINIO_CI_CD=1
|
|
|
|
|
2024-05-27 15:17:46 -04:00
|
|
|
start_port=$1
|
2024-04-25 17:55:41 -04:00
|
|
|
args=""
|
|
|
|
for i in $(seq 1 3); do
|
|
|
|
args="$args http://127.0.0.1:$((start_port + i))${WORK_DIR}/$i/1/ http://127.0.0.1:$((start_port + i))${WORK_DIR}/$i/2/ http://127.0.0.1:$((start_port + i))${WORK_DIR}/$i/3/ http://127.0.0.1:$((start_port + i))${WORK_DIR}/$i/4/ http://127.0.0.1:$((start_port + i))${WORK_DIR}/$i/5/ http://127.0.0.1:$((start_port + i))${WORK_DIR}/$i/6/"
|
|
|
|
done
|
|
|
|
|
|
|
|
"${MINIO[@]}" --address ":$((start_port + 1))" $args >"${WORK_DIR}/dist-minio-server1.log" 2>&1 &
|
|
|
|
pid1=$!
|
|
|
|
disown ${pid1}
|
|
|
|
|
|
|
|
"${MINIO[@]}" --address ":$((start_port + 2))" $args >"${WORK_DIR}/dist-minio-server2.log" 2>&1 &
|
|
|
|
pid2=$!
|
|
|
|
disown $pid2
|
|
|
|
|
|
|
|
"${MINIO[@]}" --address ":$((start_port + 3))" $args >"${WORK_DIR}/dist-minio-server3.log" 2>&1 &
|
|
|
|
pid3=$!
|
|
|
|
disown $pid3
|
|
|
|
|
2024-05-27 15:17:46 -04:00
|
|
|
export MC_HOST_myminio="http://minio:minio123@127.0.0.1:$((start_port + 1))"
|
2024-05-31 10:48:50 -04:00
|
|
|
|
2024-06-19 12:00:38 -04:00
|
|
|
timeout 15m /tmp/mc ready myminio || fail
|
2024-04-25 17:55:41 -04:00
|
|
|
|
2024-05-31 10:48:50 -04:00
|
|
|
# Wait for all drives to be online and formatted
|
|
|
|
while [ $(/tmp/mc admin info --json myminio | jq '.info.servers[].drives[].state | select(. != "ok")' | wc -l) -gt 0 ]; do sleep 1; done
|
|
|
|
# Wait for all drives to be healed
|
|
|
|
while [ $(/tmp/mc admin info --json myminio | jq '.info.servers[].drives[].healing | select(. != null) | select(. == true)' | wc -l) -gt 0 ]; do sleep 1; done
|
|
|
|
|
|
|
|
# Wait for Status: in MinIO output
|
|
|
|
while true; do
|
|
|
|
rv=$(check_online)
|
|
|
|
if [ "$rv" != "1" ]; then
|
|
|
|
# success
|
|
|
|
break
|
|
|
|
fi
|
|
|
|
|
|
|
|
# Check if we should retry
|
|
|
|
retry=$((retry + 1))
|
|
|
|
if [ $retry -le 20 ]; then
|
|
|
|
sleep 5
|
|
|
|
continue
|
|
|
|
fi
|
|
|
|
|
|
|
|
# Failure
|
2024-06-19 12:00:38 -04:00
|
|
|
fail
|
2024-05-31 10:48:50 -04:00
|
|
|
done
|
|
|
|
|
2024-04-25 17:55:41 -04:00
|
|
|
if ! ps -p $pid1 1>&2 >/dev/null; then
|
2024-06-19 12:00:38 -04:00
|
|
|
echo "minio-server-1 is not running." && fail
|
2024-04-25 17:55:41 -04:00
|
|
|
fi
|
|
|
|
|
|
|
|
if ! ps -p $pid2 1>&2 >/dev/null; then
|
2024-06-19 12:00:38 -04:00
|
|
|
echo "minio-server-2 is not running." && fail
|
2024-04-25 17:55:41 -04:00
|
|
|
fi
|
|
|
|
|
|
|
|
if ! ps -p $pid3 1>&2 >/dev/null; then
|
2024-06-19 12:00:38 -04:00
|
|
|
echo "minio-server-3 is not running." && fail
|
2024-04-25 17:55:41 -04:00
|
|
|
fi
|
|
|
|
|
|
|
|
if ! pkill minio; then
|
2024-06-19 12:00:38 -04:00
|
|
|
fail
|
2024-04-25 17:55:41 -04:00
|
|
|
fi
|
|
|
|
|
|
|
|
sleep 1
|
|
|
|
if pgrep minio; then
|
|
|
|
# forcibly killing, to proceed further properly.
|
|
|
|
if ! pkill -9 minio; then
|
|
|
|
echo "no minio process running anymore, proceed."
|
|
|
|
fi
|
|
|
|
fi
|
|
|
|
}
|
|
|
|
|
2024-06-19 12:00:38 -04:00
|
|
|
function fail() {
|
|
|
|
for i in $(seq 1 3); do
|
|
|
|
echo "server$i log:"
|
|
|
|
cat "${WORK_DIR}/dist-minio-server$i.log"
|
|
|
|
done
|
|
|
|
echo "FAILED"
|
|
|
|
purge "$WORK_DIR"
|
|
|
|
exit 1
|
|
|
|
}
|
|
|
|
|
2024-04-25 17:55:41 -04:00
|
|
|
function check_online() {
|
2024-07-12 16:51:54 -04:00
|
|
|
if ! grep -q 'API:' ${WORK_DIR}/dist-minio-*.log; then
|
2024-04-25 17:55:41 -04:00
|
|
|
echo "1"
|
|
|
|
fi
|
|
|
|
}
|
|
|
|
|
|
|
|
function purge() {
|
2024-05-31 10:48:50 -04:00
|
|
|
echo rm -rf "$1"
|
2024-04-25 17:55:41 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
function __init__() {
|
|
|
|
echo "Initializing environment"
|
|
|
|
mkdir -p "$WORK_DIR"
|
|
|
|
mkdir -p "$MINIO_CONFIG_DIR"
|
|
|
|
|
|
|
|
## version is purposefully set to '3' for minio to migrate configuration file
|
|
|
|
echo '{"version": "3", "credential": {"accessKey": "minio", "secretKey": "minio123"}, "region": "us-east-1"}' >"$MINIO_CONFIG_DIR/config.json"
|
2024-05-27 15:17:46 -04:00
|
|
|
|
|
|
|
if [ ! -f /tmp/mc ]; then
|
|
|
|
wget --quiet -O /tmp/mc https://dl.minio.io/client/mc/release/linux-amd64/mc &&
|
|
|
|
chmod +x /tmp/mc
|
|
|
|
fi
|
2024-04-25 17:55:41 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
function perform_test() {
|
2024-05-27 15:17:46 -04:00
|
|
|
start_minio_3_node $2
|
2024-04-25 17:55:41 -04:00
|
|
|
|
|
|
|
echo "Testing Distributed Erasure setup healing of drives"
|
|
|
|
echo "Remove the contents of the disks belonging to '${1}' erasure set"
|
|
|
|
|
|
|
|
rm -rf ${WORK_DIR}/${1}/*/
|
|
|
|
|
|
|
|
set -x
|
2024-05-27 15:17:46 -04:00
|
|
|
start_minio_3_node $2
|
2024-04-25 17:55:41 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
function main() {
|
|
|
|
# use same ports for all tests
|
|
|
|
start_port=$(shuf -i 10000-65000 -n 1)
|
|
|
|
|
|
|
|
perform_test "2" ${start_port}
|
|
|
|
perform_test "1" ${start_port}
|
|
|
|
perform_test "3" ${start_port}
|
|
|
|
}
|
|
|
|
|
|
|
|
(__init__ "$@" && main "$@")
|
|
|
|
rv=$?
|
|
|
|
purge "$WORK_DIR"
|
|
|
|
exit "$rv"
|