mirror of
https://github.com/minio/minio.git
synced 2025-01-26 06:03:17 -05:00
64fde1ab95
Zone abstraction of object layer was returning `nil` incorrectly under situations where disk healing is not required. Returning `nil` is considered as healing successful, which leads to unexpected ReloadFormat() peer notification calls during startup. This PR fixes this behavior properly for zones.
198 lines
5.0 KiB
Bash
Executable File
198 lines
5.0 KiB
Bash
Executable File
#!/bin/bash
|
|
#
|
|
# MinIO Cloud Storage, (C) 2020 MinIO, Inc.
|
|
#
|
|
# Licensed under the Apache License, Version 2.0 (the "License");
|
|
# you may not use this file except in compliance with the License.
|
|
# You may obtain a copy of the License at
|
|
#
|
|
# http://www.apache.org/licenses/LICENSE-2.0
|
|
#
|
|
# Unless required by applicable law or agreed to in writing, software
|
|
# distributed under the License is distributed on an "AS IS" BASIS,
|
|
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
# See the License for the specific language governing permissions and
|
|
# limitations under the License.
|
|
#
|
|
|
|
set -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" )
|
|
|
|
function start_minio_3_node() {
|
|
declare -a minio_pids
|
|
export MINIO_ACCESS_KEY=minio
|
|
export MINIO_SECRET_KEY=minio123
|
|
|
|
for i in $(seq 1 3); do
|
|
ARGS+=("http://127.0.0.1:$[9000+$i]${WORK_DIR}/$i/1/ http://127.0.0.1:$[9000+$i]${WORK_DIR}/$i/2/ http://127.0.0.1:$[9000+$i]${WORK_DIR}/$i/3/ http://127.0.0.1:$[9000+$i]${WORK_DIR}/$i/4/ http://127.0.0.1:$[9000+$i]${WORK_DIR}/$i/5/ http://127.0.0.1:$[9000+$i]${WORK_DIR}/$i/6/")
|
|
done
|
|
|
|
"${MINIO[@]}" server --address ":9001" ${ARGS[@]} > "${WORK_DIR}/dist-minio-9001.log" 2>&1 &
|
|
minio_pids[0]=$!
|
|
|
|
"${MINIO[@]}" server --address ":9002" ${ARGS[@]} > "${WORK_DIR}/dist-minio-9002.log" 2>&1 &
|
|
minio_pids[1]=$!
|
|
|
|
"${MINIO[@]}" server --address ":9003" ${ARGS[@]} > "${WORK_DIR}/dist-minio-9003.log" 2>&1 &
|
|
minio_pids[2]=$!
|
|
|
|
sleep "$1"
|
|
echo "${minio_pids[@]}"
|
|
}
|
|
|
|
|
|
function check_online() {
|
|
for i in $(seq 1 3); do
|
|
if grep -q 'Server switching to safe mode' ${WORK_DIR}/dist-minio-$[9000+$i].log; then
|
|
echo "1"
|
|
fi
|
|
done
|
|
}
|
|
|
|
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"
|
|
}
|
|
|
|
function perform_test_1() {
|
|
minio_pids=( $(start_minio_3_node 60) )
|
|
for pid in "${minio_pids[@]}"; do
|
|
kill "$pid"
|
|
done
|
|
|
|
echo "Testing in Distributed Erasure setup healing test case 1"
|
|
echo "Remove the contents of the disks belonging to '2' erasure set"
|
|
|
|
rm -rf ${WORK_DIR}/2/*
|
|
|
|
minio_pids=( $(start_minio_3_node 60) )
|
|
for pid in "${minio_pids[@]}"; do
|
|
if ! kill "$pid"; then
|
|
cat "${WORK_DIR}/*.log"
|
|
echo "FAILED"
|
|
purge "$WORK_DIR"
|
|
exit 1
|
|
fi
|
|
done
|
|
|
|
rv=$(check_online)
|
|
if [ "$rv" == "1" ]; then
|
|
for pid in "${minio_pids[@]}"; do
|
|
kill -9 "$pid"
|
|
done
|
|
for i in $(seq 1 3); do
|
|
echo "server$i log:"
|
|
cat "${WORK_DIR}/dist-minio-$[9000+$i].log"
|
|
done
|
|
echo "FAILED"
|
|
purge "$WORK_DIR"
|
|
exit 1
|
|
fi
|
|
}
|
|
|
|
function perform_test_2() {
|
|
minio_pids=( $(start_minio_3_node 60) )
|
|
for pid in "${minio_pids[@]}"; do
|
|
kill "$pid"
|
|
done
|
|
|
|
echo "Testing in Distributed Erasure setup healing test case 2"
|
|
echo "Remove the contents of the disks belonging to '1' erasure set"
|
|
|
|
rm -rf ${WORK_DIR}/1/*/
|
|
|
|
minio_pids=( $(start_minio_3_node 60) )
|
|
for pid in "${minio_pids[@]}"; do
|
|
if ! kill "$pid"; then
|
|
cat "${WORK_DIR}/*.log"
|
|
echo "FAILED"
|
|
purge "$WORK_DIR"
|
|
exit 1
|
|
fi
|
|
done
|
|
|
|
rv=$(check_online)
|
|
|
|
if [ "$rv" == "1" ]; then
|
|
for pid in "${minio_pids[@]}"; do
|
|
kill -9 "$pid"
|
|
done
|
|
for i in $(seq 1 3); do
|
|
echo "server$i log:"
|
|
cat "${WORK_DIR}/dist-minio-$[9000+$i].log"
|
|
done
|
|
echo "FAILED"
|
|
purge "$WORK_DIR"
|
|
exit 1
|
|
fi
|
|
}
|
|
|
|
function perform_test_3() {
|
|
minio_pids=( $(start_minio_3_node 60) )
|
|
for pid in "${minio_pids[@]}"; do
|
|
kill "$pid"
|
|
done
|
|
|
|
echo "Testing in Distributed Erasure setup healing test case 3"
|
|
echo "Remove the contents of the disks belonging to '3' erasure set"
|
|
|
|
rm -rf ${WORK_DIR}/3/*/
|
|
|
|
minio_pids=( $(start_minio_3_node 60) )
|
|
for pid in "${minio_pids[@]}"; do
|
|
if ! kill "$pid"; then
|
|
cat "${WORK_DIR}/*.log"
|
|
echo "FAILED"
|
|
purge "$WORK_DIR"
|
|
exit 1
|
|
fi
|
|
done
|
|
|
|
rv=$(check_online)
|
|
|
|
if [ "$rv" == "1" ]; then
|
|
for pid in "${minio_pids[@]}"; do
|
|
kill -9 "$pid"
|
|
done
|
|
for i in $(seq 1 3); do
|
|
echo "server$i log:"
|
|
cat "${WORK_DIR}/dist-minio-$[9000+$i].log"
|
|
done
|
|
echo "FAILED"
|
|
purge "$WORK_DIR"
|
|
exit 1
|
|
fi
|
|
}
|
|
|
|
function main()
|
|
{
|
|
perform_test_1
|
|
perform_test_2
|
|
perform_test_3
|
|
}
|
|
|
|
( __init__ "$@" && main "$@" )
|
|
rv=$?
|
|
purge "$WORK_DIR"
|
|
exit "$rv"
|