mirror of
https://github.com/minio/minio.git
synced 2024-12-25 22:55:54 -05:00
d1144c2c7e
we don't need to validateFormats again once we have obtained reference format, because it is possible that at this stage another server is doing a disk heal during startup, once in a while due to delays we get false positives and our server doesn't start. Format in quorum as reference format can be assumed as valid and we proceed further, until and unless HealFormat re-inits the disks after a successful heal. Also use separate port for healing tests to avoid any conflicts with regular build testing. Fixes #8884
229 lines
6.1 KiB
Bash
Executable File
229 lines
6.1 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" server )
|
|
|
|
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:$[8000+$i]${WORK_DIR}/$i/1/ http://127.0.0.1:$[8000+$i]${WORK_DIR}/$i/2/ http://127.0.0.1:$[8000+$i]${WORK_DIR}/$i/3/ http://127.0.0.1:$[8000+$i]${WORK_DIR}/$i/4/ http://127.0.0.1:$[8000+$i]${WORK_DIR}/$i/5/ http://127.0.0.1:$[8000+$i]${WORK_DIR}/$i/6/")
|
|
done
|
|
|
|
"${MINIO[@]}" --address ":8001" ${ARGS[@]} > "${WORK_DIR}/dist-minio-8001.log" 2>&1 &
|
|
minio_pids[0]=$!
|
|
|
|
"${MINIO[@]}" --address ":8002" ${ARGS[@]} > "${WORK_DIR}/dist-minio-8002.log" 2>&1 &
|
|
minio_pids[1]=$!
|
|
|
|
"${MINIO[@]}" --address ":8003" ${ARGS[@]} > "${WORK_DIR}/dist-minio-8003.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-$[8000+$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
|
|
if ! kill "$pid"; then
|
|
for i in $(seq 1 3); do
|
|
echo "server$i log:"
|
|
cat "${WORK_DIR}/dist-minio-$[8000+$i].log"
|
|
done
|
|
echo "FAILED"
|
|
purge "$WORK_DIR"
|
|
exit 1
|
|
fi
|
|
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
|
|
for i in $(seq 1 3); do
|
|
echo "server$i log:"
|
|
cat "${WORK_DIR}/dist-minio-$[8000+$i].log"
|
|
done
|
|
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-$[8000+$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
|
|
if ! kill "$pid"; then
|
|
for i in $(seq 1 3); do
|
|
echo "server$i log:"
|
|
cat "${WORK_DIR}/dist-minio-$[8000+$i].log"
|
|
done
|
|
echo "FAILED"
|
|
purge "$WORK_DIR"
|
|
exit 1
|
|
fi
|
|
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
|
|
for i in $(seq 1 3); do
|
|
echo "server$i log:"
|
|
cat "${WORK_DIR}/dist-minio-$[8000+$i].log"
|
|
done
|
|
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-$[8000+$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
|
|
if ! kill "$pid"; then
|
|
for i in $(seq 1 3); do
|
|
echo "server$i log:"
|
|
cat "${WORK_DIR}/dist-minio-$[8000+$i].log"
|
|
done
|
|
echo "FAILED"
|
|
purge "$WORK_DIR"
|
|
exit 1
|
|
fi
|
|
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
|
|
for i in $(seq 1 3); do
|
|
echo "server$i log:"
|
|
cat "${WORK_DIR}/dist-minio-$[8000+$i].log"
|
|
done
|
|
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-$[8000+$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"
|