2023-09-30 06:13:56 -04:00
|
|
|
#!/bin/bash
|
|
|
|
|
|
|
|
set -x
|
|
|
|
|
|
|
|
## change working directory
|
|
|
|
cd .github/workflows/multipart/
|
|
|
|
|
2023-11-21 00:33:47 -05:00
|
|
|
function cleanup() {
|
|
|
|
docker-compose -f docker-compose-site1.yaml rm -s -f || true
|
|
|
|
docker-compose -f docker-compose-site2.yaml rm -s -f || true
|
|
|
|
for volume in $(docker volume ls -q | grep minio); do
|
|
|
|
docker volume rm ${volume} || true
|
|
|
|
done
|
|
|
|
|
|
|
|
docker system prune -f || true
|
|
|
|
docker volume prune -f || true
|
|
|
|
docker volume rm $(docker volume ls -q -f dangling=true) || true
|
|
|
|
}
|
|
|
|
|
|
|
|
cleanup
|
2023-09-30 06:13:56 -04:00
|
|
|
|
|
|
|
if [ ! -f ./mc ]; then
|
|
|
|
wget --quiet -O mc https://dl.minio.io/client/mc/release/linux-amd64/mc &&
|
|
|
|
chmod +x mc
|
|
|
|
fi
|
|
|
|
|
2024-04-23 13:15:52 -04:00
|
|
|
go install -v github.com/minio/minio/docs/debugging/s3-check-md5@latest
|
2023-09-30 06:13:56 -04:00
|
|
|
|
|
|
|
export RELEASE=RELEASE.2023-08-29T23-07-35Z
|
|
|
|
|
|
|
|
docker-compose -f docker-compose-site1.yaml up -d
|
|
|
|
docker-compose -f docker-compose-site2.yaml up -d
|
|
|
|
|
2023-09-30 22:59:44 -04:00
|
|
|
sleep 30s
|
2023-09-30 06:13:56 -04:00
|
|
|
|
2023-09-30 22:59:44 -04:00
|
|
|
./mc alias set site1 http://site1-nginx:9001 minioadmin minioadmin --api s3v4
|
|
|
|
./mc alias set site2 http://site2-nginx:9002 minioadmin minioadmin --api s3v4
|
2023-09-30 06:13:56 -04:00
|
|
|
|
|
|
|
./mc ready site1/
|
|
|
|
./mc ready site2/
|
|
|
|
|
|
|
|
./mc admin replicate add site1 site2
|
|
|
|
./mc mb site1/testbucket/
|
|
|
|
./mc cp -r --quiet /usr/bin site1/testbucket/
|
|
|
|
|
|
|
|
sleep 5
|
|
|
|
|
|
|
|
s3-check-md5 -h
|
|
|
|
|
|
|
|
failed_count_site1=$(s3-check-md5 -versions -access-key minioadmin -secret-key minioadmin -endpoint http://site1-nginx:9001 -bucket testbucket 2>&1 | grep FAILED | wc -l)
|
|
|
|
failed_count_site2=$(s3-check-md5 -versions -access-key minioadmin -secret-key minioadmin -endpoint http://site2-nginx:9002 -bucket testbucket 2>&1 | grep FAILED | wc -l)
|
|
|
|
|
|
|
|
if [ $failed_count_site1 -ne 0 ]; then
|
|
|
|
echo "failed with multipart on site1 uploads"
|
|
|
|
exit 1
|
|
|
|
fi
|
|
|
|
|
|
|
|
if [ $failed_count_site2 -ne 0 ]; then
|
|
|
|
echo "failed with multipart on site2 uploads"
|
|
|
|
exit 1
|
|
|
|
fi
|
|
|
|
|
|
|
|
./mc cp -r --quiet /usr/bin site1/testbucket/
|
|
|
|
|
|
|
|
sleep 5
|
|
|
|
|
|
|
|
failed_count_site1=$(s3-check-md5 -versions -access-key minioadmin -secret-key minioadmin -endpoint http://site1-nginx:9001 -bucket testbucket 2>&1 | grep FAILED | wc -l)
|
|
|
|
failed_count_site2=$(s3-check-md5 -versions -access-key minioadmin -secret-key minioadmin -endpoint http://site2-nginx:9002 -bucket testbucket 2>&1 | grep FAILED | wc -l)
|
|
|
|
|
|
|
|
## we do not need to fail here, since we are going to test
|
|
|
|
## upgrading to master, healing and being able to recover
|
|
|
|
## the last version.
|
|
|
|
if [ $failed_count_site1 -ne 0 ]; then
|
|
|
|
echo "failed with multipart on site1 uploads ${failed_count_site1}"
|
|
|
|
fi
|
|
|
|
|
|
|
|
if [ $failed_count_site2 -ne 0 ]; then
|
|
|
|
echo "failed with multipart on site2 uploads ${failed_count_site2}"
|
|
|
|
fi
|
|
|
|
|
|
|
|
export RELEASE=${1}
|
|
|
|
|
|
|
|
docker-compose -f docker-compose-site1.yaml up -d
|
|
|
|
docker-compose -f docker-compose-site2.yaml up -d
|
|
|
|
|
|
|
|
./mc ready site1/
|
|
|
|
./mc ready site2/
|
|
|
|
|
2023-09-30 22:59:44 -04:00
|
|
|
for i in $(seq 1 10); do
|
|
|
|
# mc admin heal -r --remove when used against a LB endpoint
|
|
|
|
# behaves flaky, let this run 10 times before giving up
|
|
|
|
./mc admin heal -r --remove --json site1/ 2>&1 >/dev/null
|
|
|
|
./mc admin heal -r --remove --json site2/ 2>&1 >/dev/null
|
|
|
|
done
|
2023-09-30 06:13:56 -04:00
|
|
|
|
|
|
|
failed_count_site1=$(s3-check-md5 -versions -access-key minioadmin -secret-key minioadmin -endpoint http://site1-nginx:9001 -bucket testbucket 2>&1 | grep FAILED | wc -l)
|
|
|
|
failed_count_site2=$(s3-check-md5 -versions -access-key minioadmin -secret-key minioadmin -endpoint http://site2-nginx:9002 -bucket testbucket 2>&1 | grep FAILED | wc -l)
|
|
|
|
|
|
|
|
if [ $failed_count_site1 -ne 0 ]; then
|
|
|
|
echo "failed with multipart on site1 uploads"
|
|
|
|
exit 1
|
|
|
|
fi
|
|
|
|
|
|
|
|
if [ $failed_count_site2 -ne 0 ]; then
|
|
|
|
echo "failed with multipart on site2 uploads"
|
|
|
|
exit 1
|
|
|
|
fi
|
|
|
|
|
2024-04-24 11:54:24 -04:00
|
|
|
# Add user group test
|
|
|
|
./mc admin user add site1 site-replication-issue-user site-replication-issue-password
|
|
|
|
./mc admin group add site1 site-replication-issue-group site-replication-issue-user
|
|
|
|
|
|
|
|
max_wait_attempts=30
|
|
|
|
wait_interval=5
|
|
|
|
|
|
|
|
attempt=1
|
|
|
|
while true; do
|
|
|
|
diff <(./mc admin group info site1 site-replication-issue-group) <(./mc admin group info site2 site-replication-issue-group)
|
|
|
|
|
|
|
|
if [[ $? -eq 0 ]]; then
|
|
|
|
echo "Outputs are consistent."
|
|
|
|
break
|
|
|
|
fi
|
|
|
|
|
|
|
|
remaining_attempts=$((max_wait_attempts - attempt))
|
|
|
|
if ((attempt >= max_wait_attempts)); then
|
|
|
|
echo "Outputs remain inconsistent after $max_wait_attempts attempts. Exiting with error."
|
|
|
|
exit 1
|
|
|
|
else
|
|
|
|
echo "Outputs are inconsistent. Waiting for $wait_interval seconds (attempt $attempt/$max_wait_attempts)."
|
|
|
|
sleep $wait_interval
|
|
|
|
fi
|
|
|
|
|
|
|
|
((attempt++))
|
|
|
|
done
|
|
|
|
|
|
|
|
status=$(./mc admin group info site1 site-replication-issue-group --json | jq .groupStatus | tr -d '"')
|
|
|
|
|
|
|
|
if [[ $status == "enabled" ]]; then
|
|
|
|
echo "Success"
|
|
|
|
else
|
|
|
|
echo "Expected status: enabled, actual status: $status"
|
|
|
|
exit 1
|
|
|
|
fi
|
|
|
|
|
2023-11-21 00:33:47 -05:00
|
|
|
cleanup
|
2023-09-30 06:13:56 -04:00
|
|
|
|
|
|
|
## change working directory
|
|
|
|
cd ../../../
|