mirror of
https://github.com/markusressel/zfs-inplace-rebalancing
synced 2026-02-14 18:01:10 +00:00
168 lines
4.8 KiB
Bash
Executable File
168 lines
4.8 KiB
Bash
Executable File
#!/usr/bin/env bash
|
|
|
|
# exit script on error
|
|
set -e
|
|
# exit on undeclared variable
|
|
set -u
|
|
|
|
log_std_file=./test.log
|
|
log_error_file=./error.log
|
|
test_data_src=./test/pool
|
|
test_pool_data_path=./testing_data
|
|
test_pool_data_size_path=$test_pool_data_path/size
|
|
|
|
## Color Constants
|
|
|
|
# Reset
|
|
Color_Off='\033[0m' # Text Reset
|
|
|
|
# Regular Colors
|
|
Red='\033[0;31m' # Red
|
|
Green='\033[0;32m' # Green
|
|
Yellow='\033[0;33m' # Yellow
|
|
Cyan='\033[0;36m' # Cyan
|
|
|
|
## Functions
|
|
|
|
# print a given text entirely in a given color
|
|
function color_echo () {
|
|
color=$1
|
|
text=$2
|
|
echo -e "${color}${text}${Color_Off}"
|
|
}
|
|
|
|
function prepare() {
|
|
# cleanup
|
|
rm -f $log_std_file
|
|
rm -f $log_error_file
|
|
rm -f rebalance_db.txt
|
|
rm -rf $test_pool_data_path
|
|
|
|
# setup
|
|
cp -rf $test_data_src $test_pool_data_path
|
|
}
|
|
|
|
function assertions() {
|
|
# check error log is empty
|
|
if grep -q '[^[:space:]]' $log_error_file; then
|
|
color_echo "$Red" "error log is not empty!"
|
|
cat $log_error_file
|
|
exit 1
|
|
fi
|
|
}
|
|
|
|
function assert_matching_file_copied() {
|
|
if ! grep "Copying" $log_std_file | grep -q "$1"; then
|
|
echo "File matching '$1' was not copied when it should have been!"
|
|
exit 1
|
|
fi
|
|
}
|
|
|
|
function assert_matching_file_not_copied() {
|
|
if grep "Copying" $log_std_file | grep -q "$1"; then
|
|
echo "File matching '$1' was copied when it should have been skipped!"
|
|
exit 1
|
|
fi
|
|
}
|
|
|
|
function print_time_taken(){
|
|
time_taken=$1
|
|
minute=$((time_taken / 60000))
|
|
seconde=$((time_taken % 60000 / 1000))
|
|
miliseconde=$((time_taken % 1000))
|
|
color_echo "$Yellow" "Time taken: ${minute}m ${seconde}s ${miliseconde}ms"
|
|
}
|
|
|
|
color_echo "$Cyan" "Running tests..."
|
|
|
|
color_echo "$Cyan" "Running tests with default options..."
|
|
prepare
|
|
./zfs-inplace-rebalancing.sh $test_pool_data_path >> $log_std_file 2>> $log_error_file
|
|
cat $log_std_file
|
|
assertions
|
|
color_echo "$Green" "Tests passed!"
|
|
|
|
color_echo "$Cyan" "Running tests with checksum true and 1 pass..."
|
|
prepare
|
|
./zfs-inplace-rebalancing.sh --checksum true --passes 1 $test_pool_data_path >> $log_std_file 2>> $log_error_file
|
|
cat $log_std_file
|
|
assertions
|
|
color_echo "$Green" "Tests passed!"
|
|
|
|
color_echo "$Cyan" "Running tests with checksum false..."
|
|
prepare
|
|
./zfs-inplace-rebalancing.sh --checksum false $test_pool_data_path >> $log_std_file 2>> $log_error_file
|
|
cat $log_std_file
|
|
assertions
|
|
color_echo "$Green" "Tests passed!"
|
|
|
|
color_echo "$Cyan" "Running tests with skip-hardlinks false..."
|
|
prepare
|
|
ln "$test_pool_data_path/projects/[2020] some project/mp4.txt" "$test_pool_data_path/projects/[2020] some project/mp4.txt.link"
|
|
./zfs-inplace-rebalancing.sh --skip-hardlinks false $test_pool_data_path >> $log_std_file 2>> $log_error_file
|
|
cat $log_std_file
|
|
# Both link files should be copied
|
|
assert_matching_file_copied "mp4.txt"
|
|
assert_matching_file_copied "mp4.txt.link"
|
|
assertions
|
|
color_echo "$Green" "Tests passed!"
|
|
|
|
color_echo "$Cyan" "Running tests with skip-hardlinks true..."
|
|
prepare
|
|
ln "$test_pool_data_path/projects/[2020] some project/mp4.txt" "$test_pool_data_path/projects/[2020] some project/mp4.txt.link"
|
|
./zfs-inplace-rebalancing.sh --skip-hardlinks true $test_pool_data_path >> $log_std_file 2>> $log_error_file
|
|
cat $log_std_file
|
|
# Neither file should be copied now, since they are each a hardlink
|
|
assert_matching_file_not_copied "mp4.txt.link"
|
|
assert_matching_file_not_copied "mp4.txt"
|
|
assertions
|
|
color_echo "$Green" "Tests passed!"
|
|
|
|
color_echo "$Cyan" "Running tests with different file count and size..."
|
|
prepare
|
|
|
|
mkdir -p $test_pool_data_size_path
|
|
|
|
color_echo "$Cyan" "Creating 1000 files of 1KB each..."
|
|
mkdir -p $test_pool_data_size_path/small
|
|
for i in {1..1000}; do
|
|
dd if=/dev/urandom of=$test_pool_data_size_path/small/file$i.txt bs=1024 count=1 >> /dev/null 2>&1
|
|
done
|
|
|
|
color_echo "$Cyan" "Creating 5 file of 1GB each..."
|
|
mkdir -p $test_pool_data_size_path/big
|
|
for i in {1..5}; do
|
|
dd if=/dev/urandom of=$test_pool_data_size_path/big/file$i.txt bs=1024 count=1048576 >> /dev/null 2>&1
|
|
done
|
|
|
|
color_echo "$Green" "Files created!"
|
|
|
|
echo "Running rebalancing on small files..."
|
|
# measure time taken
|
|
start_time=$(date +%s%3N)
|
|
./zfs-inplace-rebalancing.sh $test_pool_data_size_path/small >> $log_std_file 2>> $log_error_file
|
|
end_time=$(date +%s%3N)
|
|
print_time_taken $((end_time - start_time))
|
|
assertions
|
|
color_echo "$Green" "Tests passed!"
|
|
|
|
echo "Running rebalancing on big files..."
|
|
# measure time taken
|
|
start_time=$(date +%s%3N)
|
|
./zfs-inplace-rebalancing.sh $test_pool_data_size_path/big >> $log_std_file 2>> $log_error_file
|
|
end_time=$(date +%s%3N)
|
|
print_time_taken $((end_time - start_time))
|
|
assertions
|
|
color_echo "$Green" "Tests passed!"
|
|
|
|
echo "Running rebalancing on all files..."
|
|
# measure time taken whit
|
|
start_time=$(date +%s%3N)
|
|
./zfs-inplace-rebalancing.sh $test_pool_data_size_path >> $log_std_file 2>> $log_error_file
|
|
end_time=$(date +%s%3N)
|
|
print_time_taken $((end_time - start_time))
|
|
assertions
|
|
color_echo "$Green" "Tests passed!"
|
|
|
|
|
|
color_echo "$Green" "All tests passed!" |