2021-08-24 18:06:23 -04:00
|
|
|
#!/bin/bash -e
|
2020-01-10 05:35:06 -05:00
|
|
|
#
|
|
|
|
|
|
|
|
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"
|
2020-01-27 04:26:36 -05:00
|
|
|
MINIO=( "$PWD/minio" --config-dir "$MINIO_CONFIG_DIR" server )
|
2020-01-10 05:35:06 -05:00
|
|
|
|
|
|
|
function start_minio_3_node() {
|
2021-01-05 13:22:57 -05:00
|
|
|
export MINIO_ROOT_USER=minio
|
|
|
|
export MINIO_ROOT_PASSWORD=minio123
|
2020-06-29 16:07:26 -04:00
|
|
|
export MINIO_ERASURE_SET_DRIVE_COUNT=6
|
2020-01-10 05:35:06 -05:00
|
|
|
|
2020-04-01 03:04:25 -04:00
|
|
|
start_port=$(shuf -i 10000-65000 -n 1)
|
2020-12-05 16:00:44 -05:00
|
|
|
args=""
|
2020-01-10 05:35:06 -05:00
|
|
|
for i in $(seq 1 3); do
|
2020-12-05 16:00:44 -05:00
|
|
|
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/"
|
2020-01-10 05:35:06 -05:00
|
|
|
done
|
|
|
|
|
2020-12-05 16:00:44 -05:00
|
|
|
"${MINIO[@]}" --address ":$[$start_port+1]" $args > "${WORK_DIR}/dist-minio-server1.log" 2>&1 &
|
|
|
|
disown $!
|
2020-01-10 05:35:06 -05:00
|
|
|
|
2020-12-05 16:00:44 -05:00
|
|
|
"${MINIO[@]}" --address ":$[$start_port+2]" $args > "${WORK_DIR}/dist-minio-server2.log" 2>&1 &
|
|
|
|
disown $!
|
2020-01-10 05:35:06 -05:00
|
|
|
|
2020-12-05 16:00:44 -05:00
|
|
|
"${MINIO[@]}" --address ":$[$start_port+3]" $args > "${WORK_DIR}/dist-minio-server3.log" 2>&1 &
|
|
|
|
disown $!
|
2020-01-10 05:35:06 -05:00
|
|
|
|
|
|
|
sleep "$1"
|
2020-12-05 16:00:44 -05:00
|
|
|
if [ "$(pgrep -c minio)" -ne 3 ]; then
|
|
|
|
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
|
|
|
|
fi
|
|
|
|
if ! pkill minio; then
|
|
|
|
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
|
|
|
|
fi
|
|
|
|
|
|
|
|
sleep 1;
|
|
|
|
if pgrep minio; then
|
2020-04-01 03:04:25 -04:00
|
|
|
# forcibly killing, to proceed further properly.
|
2020-12-05 16:00:44 -05:00
|
|
|
if ! pkill -9 minio; then
|
|
|
|
echo "no minio process running anymore, proceed."
|
|
|
|
fi
|
|
|
|
fi
|
2020-01-10 05:35:06 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
function check_online() {
|
2021-08-24 18:06:23 -04:00
|
|
|
if grep -q 'Unable to initialize sub-systems' ${WORK_DIR}/dist-minio-*.log; then
|
2020-04-01 03:04:25 -04:00
|
|
|
echo "1"
|
|
|
|
fi
|
2020-01-10 05:35:06 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
function purge()
|
|
|
|
{
|
|
|
|
rm -rf "$1"
|
|
|
|
}
|
|
|
|
|
|
|
|
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"
|
|
|
|
}
|
|
|
|
|
2020-02-21 00:59:57 -05:00
|
|
|
function perform_test() {
|
2021-08-24 18:06:23 -04:00
|
|
|
start_minio_3_node 120
|
2020-01-10 05:35:06 -05:00
|
|
|
|
2020-02-21 00:59:57 -05:00
|
|
|
echo "Testing Distributed Erasure setup healing of drives"
|
|
|
|
echo "Remove the contents of the disks belonging to '${1}' erasure set"
|
2020-01-10 05:35:06 -05:00
|
|
|
|
2020-02-21 00:59:57 -05:00
|
|
|
rm -rf ${WORK_DIR}/${1}/*/
|
2020-01-10 05:35:06 -05:00
|
|
|
|
2021-08-24 17:41:05 -04:00
|
|
|
start_minio_3_node 120
|
2020-01-10 05:35:06 -05:00
|
|
|
|
|
|
|
rv=$(check_online)
|
|
|
|
if [ "$rv" == "1" ]; then
|
|
|
|
for i in $(seq 1 3); do
|
|
|
|
echo "server$i log:"
|
2020-04-01 03:04:25 -04:00
|
|
|
cat "${WORK_DIR}/dist-minio-server$i.log"
|
2020-01-10 05:35:06 -05:00
|
|
|
done
|
2021-08-23 04:13:47 -04:00
|
|
|
pkill -9 minio
|
2020-01-10 05:35:06 -05:00
|
|
|
echo "FAILED"
|
|
|
|
purge "$WORK_DIR"
|
|
|
|
exit 1
|
|
|
|
fi
|
|
|
|
}
|
|
|
|
|
|
|
|
function main()
|
|
|
|
{
|
2020-02-21 00:59:57 -05:00
|
|
|
perform_test "2"
|
|
|
|
perform_test "1"
|
|
|
|
perform_test "3"
|
2020-01-10 05:35:06 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
( __init__ "$@" && main "$@" )
|
|
|
|
rv=$?
|
|
|
|
purge "$WORK_DIR"
|
|
|
|
exit "$rv"
|