2022-07-04 14:02:54 -07:00
|
|
|
#!/bin/bash
|
|
|
|
|
2022-07-16 19:35:24 -07:00
|
|
|
if [ -n "$TEST_DEBUG" ]; then
|
2023-05-25 22:07:25 -07:00
|
|
|
set -x
|
2022-07-04 14:02:54 -07:00
|
|
|
fi
|
|
|
|
|
|
|
|
pkill minio
|
|
|
|
rm -rf /tmp/xl
|
2023-03-16 07:48:05 -07:00
|
|
|
rm -rf /tmp/xltier
|
2022-07-04 14:02:54 -07:00
|
|
|
|
2022-07-16 19:35:24 -07:00
|
|
|
if [ ! -f ./mc ]; then
|
2023-05-25 22:07:25 -07:00
|
|
|
wget --quiet -O mc https://dl.minio.io/client/mc/release/linux-amd64/mc &&
|
|
|
|
chmod +x mc
|
2022-07-16 19:35:24 -07:00
|
|
|
fi
|
2022-07-04 14:02:54 -07:00
|
|
|
|
|
|
|
export CI=true
|
2023-11-20 21:33:47 -08:00
|
|
|
export MINIO_SCANNER_SPEED=fastest
|
2022-07-16 19:35:24 -07:00
|
|
|
|
2024-01-17 15:19:09 -08:00
|
|
|
(minio server http://localhost:9000/tmp/xl/{1...10}/disk{0...1} 2>&1 >/tmp/decom.log) &
|
2022-07-04 14:02:54 -07:00
|
|
|
pid=$!
|
|
|
|
|
2024-01-10 10:04:04 +05:30
|
|
|
sleep 30
|
2022-07-04 14:02:54 -07:00
|
|
|
|
|
|
|
export MC_HOST_myminio="http://minioadmin:minioadmin@localhost:9000/"
|
|
|
|
|
|
|
|
./mc admin user add myminio/ minio123 minio123
|
|
|
|
./mc admin user add myminio/ minio12345 minio12345
|
|
|
|
|
2023-03-20 23:38:06 -07:00
|
|
|
./mc admin policy create myminio/ rw ./docs/distributed/rw.json
|
|
|
|
./mc admin policy create myminio/ lake ./docs/distributed/rw.json
|
2022-07-04 14:02:54 -07:00
|
|
|
|
2023-03-20 23:38:06 -07:00
|
|
|
./mc admin policy attach myminio/ rw --user=minio123
|
2023-07-10 07:55:38 -07:00
|
|
|
./mc admin policy attach myminio/ lake --user=minio12345
|
2022-07-04 14:02:54 -07:00
|
|
|
|
|
|
|
./mc mb -l myminio/versioned
|
2022-07-05 07:37:24 -07:00
|
|
|
|
|
|
|
./mc mirror internal myminio/versioned/ --quiet >/dev/null
|
|
|
|
|
|
|
|
## Soft delete (creates delete markers)
|
|
|
|
./mc rm -r --force myminio/versioned >/dev/null
|
|
|
|
|
|
|
|
## mirror again to create another set of version on top
|
2022-07-04 14:02:54 -07:00
|
|
|
./mc mirror internal myminio/versioned/ --quiet >/dev/null
|
|
|
|
|
2022-07-16 19:35:24 -07:00
|
|
|
expected_checksum=$(./mc cat internal/dsync/drwmutex.go | md5sum)
|
|
|
|
|
2022-07-04 14:02:54 -07:00
|
|
|
user_count=$(./mc admin user list myminio/ | wc -l)
|
|
|
|
policy_count=$(./mc admin policy list myminio/ | wc -l)
|
|
|
|
|
2023-03-16 07:48:05 -07:00
|
|
|
## create a warm tier instance
|
2024-01-17 15:19:09 -08:00
|
|
|
(minio server /tmp/xltier/{1...4}/disk{0...1} --address :9002 2>&1 >/dev/null) &
|
2024-01-10 10:04:04 +05:30
|
|
|
sleep 30
|
2023-09-18 13:47:03 -07:00
|
|
|
|
2024-01-17 15:19:09 -08:00
|
|
|
export MC_HOST_mytier="http://minioadmin:minioadmin@localhost:9002/"
|
2023-03-16 07:48:05 -07:00
|
|
|
|
|
|
|
./mc mb -l myminio/bucket2
|
|
|
|
./mc mb -l mytier/tiered
|
2023-09-16 02:28:06 -07:00
|
|
|
|
2023-03-16 07:48:05 -07:00
|
|
|
## create a tier and set up ilm policy to tier immediately
|
2024-01-17 15:19:09 -08:00
|
|
|
./mc admin tier add minio myminio TIER1 --endpoint http://localhost:9002 --access-key minioadmin --secret-key minioadmin --bucket tiered --prefix prefix5/
|
2023-03-16 07:48:05 -07:00
|
|
|
./mc ilm add myminio/bucket2 --transition-days 0 --transition-tier TIER1 --transition-days 0
|
2023-09-16 02:28:06 -07:00
|
|
|
|
2023-03-16 07:48:05 -07:00
|
|
|
## mirror some content to bucket2 and capture versions tiered
|
|
|
|
./mc mirror internal myminio/bucket2/ --quiet >/dev/null
|
2023-05-25 22:07:25 -07:00
|
|
|
./mc ls -r myminio/bucket2/ >bucket2_ns.txt
|
|
|
|
./mc ls -r --versions myminio/bucket2/ >bucket2_ns_versions.txt
|
2023-09-16 02:28:06 -07:00
|
|
|
|
2023-11-20 21:33:47 -08:00
|
|
|
sleep 30
|
2023-09-16 02:28:06 -07:00
|
|
|
|
2023-05-25 22:07:25 -07:00
|
|
|
./mc ls -r --versions mytier/tiered/ >tiered_ns_versions.txt
|
2023-03-16 07:48:05 -07:00
|
|
|
|
2022-07-04 14:02:54 -07:00
|
|
|
kill $pid
|
2024-01-17 15:19:09 -08:00
|
|
|
|
|
|
|
(minio server http://localhost:9000/tmp/xl/{1...10}/disk{0...1} http://localhost:9001/tmp/xl/{11...30}/disk{0...3} 2>&1 >/tmp/expanded_1.log) &
|
|
|
|
pid_1=$!
|
|
|
|
|
|
|
|
(minio server --address ":9001" http://localhost:9000/tmp/xl/{1...10}/disk{0...1} http://localhost:9001/tmp/xl/{11...30}/disk{0...3} 2>&1 >/tmp/expanded_2.log) &
|
|
|
|
pid_2=$!
|
2022-07-04 14:02:54 -07:00
|
|
|
|
2023-09-18 13:47:03 -07:00
|
|
|
sleep 30
|
2022-07-04 14:02:54 -07:00
|
|
|
|
|
|
|
expanded_user_count=$(./mc admin user list myminio/ | wc -l)
|
|
|
|
expanded_policy_count=$(./mc admin policy list myminio/ | wc -l)
|
|
|
|
|
|
|
|
if [ $user_count -ne $expanded_user_count ]; then
|
2023-05-25 22:07:25 -07:00
|
|
|
echo "BUG: original user count differs from expanded setup"
|
|
|
|
exit 1
|
2022-07-04 14:02:54 -07:00
|
|
|
fi
|
|
|
|
|
|
|
|
if [ $policy_count -ne $expanded_policy_count ]; then
|
2023-05-25 22:07:25 -07:00
|
|
|
echo "BUG: original policy count differs from expanded setup"
|
|
|
|
exit 1
|
2022-07-04 14:02:54 -07:00
|
|
|
fi
|
|
|
|
|
|
|
|
./mc version info myminio/versioned | grep -q "versioning is enabled"
|
|
|
|
ret=$?
|
|
|
|
if [ $ret -ne 0 ]; then
|
2023-05-25 22:07:25 -07:00
|
|
|
echo "expected versioning enabled after expansion"
|
|
|
|
exit 1
|
2022-07-04 14:02:54 -07:00
|
|
|
fi
|
|
|
|
|
|
|
|
./mc mirror cmd myminio/versioned/ --quiet >/dev/null
|
2022-07-05 07:37:24 -07:00
|
|
|
|
2023-05-25 22:07:25 -07:00
|
|
|
./mc ls -r myminio/versioned/ >expanded_ns.txt
|
|
|
|
./mc ls -r --versions myminio/versioned/ >expanded_ns_versions.txt
|
2022-07-04 14:02:54 -07:00
|
|
|
|
2024-01-17 15:19:09 -08:00
|
|
|
./mc admin decom start myminio/ http://localhost:9000/tmp/xl/{1...10}/disk{0...1}
|
2022-07-04 14:02:54 -07:00
|
|
|
|
2023-12-06 01:09:22 -08:00
|
|
|
count=0
|
2023-05-25 22:07:25 -07:00
|
|
|
until $(./mc admin decom status myminio/ | grep -q Complete); do
|
|
|
|
echo "waiting for decom to finish..."
|
2023-12-06 01:09:22 -08:00
|
|
|
count=$((count + 1))
|
|
|
|
if [ ${count} -eq 120 ]; then
|
2024-01-17 15:19:09 -08:00
|
|
|
./mc cat /tmp/expanded_*.log
|
2023-12-06 01:09:22 -08:00
|
|
|
fi
|
2023-05-25 22:07:25 -07:00
|
|
|
sleep 1
|
2022-07-04 14:02:54 -07:00
|
|
|
done
|
|
|
|
|
2024-01-17 15:19:09 -08:00
|
|
|
kill $pid_1
|
|
|
|
kill $pid_2
|
|
|
|
|
|
|
|
sleep 5
|
2022-07-04 14:02:54 -07:00
|
|
|
|
2024-01-17 15:19:09 -08:00
|
|
|
(minio server --address ":9001" http://localhost:9001/tmp/xl/{11...30}/disk{0...3} 2>&1 >/tmp/removed.log) &
|
2022-07-04 14:02:54 -07:00
|
|
|
pid=$!
|
|
|
|
|
2024-01-10 10:04:04 +05:30
|
|
|
sleep 30
|
2022-07-04 14:02:54 -07:00
|
|
|
|
2024-01-17 15:19:09 -08:00
|
|
|
export MC_HOST_myminio="http://minioadmin:minioadmin@localhost:9001/"
|
|
|
|
|
2022-07-04 14:02:54 -07:00
|
|
|
decom_user_count=$(./mc admin user list myminio/ | wc -l)
|
|
|
|
decom_policy_count=$(./mc admin policy list myminio/ | wc -l)
|
|
|
|
|
|
|
|
if [ $user_count -ne $decom_user_count ]; then
|
2023-05-25 22:07:25 -07:00
|
|
|
echo "BUG: original user count differs after decommission"
|
|
|
|
exit 1
|
2022-07-04 14:02:54 -07:00
|
|
|
fi
|
|
|
|
|
|
|
|
if [ $policy_count -ne $decom_policy_count ]; then
|
2023-05-25 22:07:25 -07:00
|
|
|
echo "BUG: original policy count differs after decommission"
|
|
|
|
exit 1
|
2022-07-04 14:02:54 -07:00
|
|
|
fi
|
|
|
|
|
|
|
|
./mc version info myminio/versioned | grep -q "versioning is enabled"
|
|
|
|
ret=$?
|
|
|
|
if [ $ret -ne 0 ]; then
|
2023-05-25 22:07:25 -07:00
|
|
|
echo "BUG: expected versioning enabled after decommission"
|
|
|
|
exit 1
|
2022-07-04 14:02:54 -07:00
|
|
|
fi
|
|
|
|
|
2023-05-25 22:07:25 -07:00
|
|
|
./mc ls -r myminio/versioned >decommissioned_ns.txt
|
|
|
|
./mc ls -r --versions myminio/versioned >decommissioned_ns_versions.txt
|
2022-07-04 14:02:54 -07:00
|
|
|
|
|
|
|
out=$(diff -qpruN expanded_ns.txt decommissioned_ns.txt)
|
|
|
|
ret=$?
|
|
|
|
if [ $ret -ne 0 ]; then
|
2023-05-25 22:07:25 -07:00
|
|
|
echo "BUG: expected no missing entries after decommission: $out"
|
|
|
|
exit 1
|
2022-07-04 14:02:54 -07:00
|
|
|
fi
|
|
|
|
|
2022-07-05 07:37:24 -07:00
|
|
|
out=$(diff -qpruN expanded_ns_versions.txt decommissioned_ns_versions.txt)
|
|
|
|
ret=$?
|
|
|
|
if [ $ret -ne 0 ]; then
|
2023-05-25 22:07:25 -07:00
|
|
|
echo "BUG: expected no missing entries after decommission: $out"
|
|
|
|
exit 1
|
2022-07-16 19:35:24 -07:00
|
|
|
fi
|
|
|
|
|
|
|
|
got_checksum=$(./mc cat myminio/versioned/dsync/drwmutex.go | md5sum)
|
|
|
|
if [ "${expected_checksum}" != "${got_checksum}" ]; then
|
2023-05-25 22:07:25 -07:00
|
|
|
echo "BUG: decommission failed on encrypted objects: expected ${expected_checksum} got ${got_checksum}"
|
|
|
|
exit 1
|
2022-07-05 07:37:24 -07:00
|
|
|
fi
|
|
|
|
|
2023-03-16 07:48:05 -07:00
|
|
|
# after decommissioning, compare listings in bucket2 and tiered
|
|
|
|
./mc version info myminio/bucket2 | grep -q "versioning is enabled"
|
|
|
|
ret=$?
|
|
|
|
if [ $ret -ne 0 ]; then
|
2023-05-25 22:07:25 -07:00
|
|
|
echo "BUG: expected versioning enabled after decommission on bucket2"
|
|
|
|
exit 1
|
2023-03-16 07:48:05 -07:00
|
|
|
fi
|
|
|
|
|
2023-05-25 22:07:25 -07:00
|
|
|
./mc ls -r myminio/bucket2 >decommissioned_bucket2_ns.txt
|
|
|
|
./mc ls -r --versions myminio/bucket2 >decommissioned_bucket2_ns_versions.txt
|
|
|
|
./mc ls -r --versions mytier/tiered/ >tiered_ns_versions2.txt
|
2023-03-16 07:48:05 -07:00
|
|
|
|
|
|
|
out=$(diff -qpruN bucket2_ns.txt decommissioned_bucket2_ns.txt)
|
|
|
|
ret=$?
|
|
|
|
if [ $ret -ne 0 ]; then
|
2023-05-25 22:07:25 -07:00
|
|
|
echo "BUG: expected no missing entries after decommission in bucket2: $out"
|
|
|
|
exit 1
|
2023-03-16 07:48:05 -07:00
|
|
|
fi
|
|
|
|
|
|
|
|
out=$(diff -qpruN bucket2_ns_versions.txt decommissioned_bucket2_ns_versions.txt)
|
|
|
|
ret=$?
|
|
|
|
if [ $ret -ne 0 ]; then
|
2023-05-25 22:07:25 -07:00
|
|
|
echo "BUG: expected no missing entries after decommission in bucket2x: $out"
|
|
|
|
exit 1
|
2023-03-16 07:48:05 -07:00
|
|
|
fi
|
|
|
|
|
|
|
|
out=$(diff -qpruN tiered_ns_versions.txt tiered_ns_versions2.txt)
|
|
|
|
ret=$?
|
|
|
|
if [ $ret -ne 0 ]; then
|
2023-05-25 22:07:25 -07:00
|
|
|
echo "BUG: expected no missing entries after decommission in warm tier: $out"
|
|
|
|
exit 1
|
2023-03-16 07:48:05 -07:00
|
|
|
fi
|
|
|
|
|
|
|
|
got_checksum=$(./mc cat myminio/bucket2/dsync/drwmutex.go | md5sum)
|
|
|
|
if [ "${expected_checksum}" != "${got_checksum}" ]; then
|
2023-05-25 22:07:25 -07:00
|
|
|
echo "BUG: decommission failed on encrypted objects with tiering: expected ${expected_checksum} got ${got_checksum}"
|
|
|
|
exit 1
|
2023-03-16 07:48:05 -07:00
|
|
|
fi
|
|
|
|
|
2022-07-04 14:02:54 -07:00
|
|
|
kill $pid
|