2016-06-03 13:28:44 +00:00
|
|
|
#!/bin/bash
|
|
|
|
# helpers for btrfs-convert tests
|
|
|
|
|
2017-07-20 16:44:49 +00:00
|
|
|
# mount image of converted filesystem of a given type
|
|
|
|
# $1: type of the filesystem
|
|
|
|
run_check_mount_convert_dev()
|
|
|
|
{
|
|
|
|
local fstype
|
|
|
|
local loop_opt
|
|
|
|
|
|
|
|
setup_root_helper
|
|
|
|
|
|
|
|
fstype="$1"
|
|
|
|
shift
|
|
|
|
if [ -z "$fstype" ]; then
|
|
|
|
_fail "Missing source filesystem type"
|
|
|
|
fi
|
|
|
|
if [ "$fstype" = 'btrfs' ]; then
|
|
|
|
_fail "Incorrect type for converted filesystem: btrfs"
|
|
|
|
fi
|
|
|
|
|
|
|
|
if [[ -b "$TEST_DEV" ]]; then
|
|
|
|
loop_opt=""
|
|
|
|
elif [[ -f "$TEST_DEV" ]]; then
|
|
|
|
loop_opt="-o loop"
|
|
|
|
else
|
|
|
|
_fail "Invalid \$TEST_DEV: $TEST_DEV"
|
|
|
|
fi
|
|
|
|
|
|
|
|
[[ -d "$TEST_MNT" ]] || {
|
|
|
|
_fail "Invalid \$TEST_MNT: $TEST_MNT"
|
|
|
|
}
|
|
|
|
|
|
|
|
run_check $SUDO_HELPER mount $loop_opt -t "$fstype" "$@" "$TEST_DEV" "$TEST_MNT"
|
|
|
|
}
|
|
|
|
|
2016-06-03 13:28:44 +00:00
|
|
|
populate_fs() {
|
|
|
|
|
2016-10-09 15:08:12 +00:00
|
|
|
for dataset_type in 'small' 'hardlink' 'fast_symlink' 'brokenlink' 'perm' 'sparse' 'acls' 'fifo' 'slow_symlink'; do
|
2016-06-03 13:28:44 +00:00
|
|
|
generate_dataset "$dataset_type"
|
|
|
|
done
|
|
|
|
}
|
|
|
|
|
2016-06-22 09:25:33 +00:00
|
|
|
# verbose message before the test, same arguments as convert_test
|
|
|
|
convert_test_preamble() {
|
2016-06-03 13:28:44 +00:00
|
|
|
local features
|
2016-06-22 09:25:33 +00:00
|
|
|
local msg
|
2016-06-03 13:28:44 +00:00
|
|
|
|
|
|
|
features="$1"
|
2016-06-22 09:25:33 +00:00
|
|
|
msg="$2"
|
|
|
|
shift 3
|
|
|
|
echo " [TEST/conv] $msg, btrfs" "${features:-defaults}"
|
2017-08-22 16:32:57 +00:00
|
|
|
echo "creating test image with: $@" >> "$RESULTS"
|
2016-06-22 09:25:33 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
# prepare TEST_DEV before conversion, create filesystem and mount it, image
|
|
|
|
# size is 512MB
|
2017-07-20 15:53:56 +00:00
|
|
|
# $1: type of the filesystem
|
|
|
|
# $2+: free form, command to create the filesystem, with appended -F
|
2016-06-22 09:25:33 +00:00
|
|
|
convert_test_prep_fs() {
|
2017-07-20 15:53:56 +00:00
|
|
|
local fstype
|
2017-08-22 16:32:57 +00:00
|
|
|
local force
|
|
|
|
local mountopts
|
2017-07-20 15:53:56 +00:00
|
|
|
|
|
|
|
fstype="$1"
|
|
|
|
shift
|
2016-06-03 13:28:44 +00:00
|
|
|
# TEST_DEV not removed as the file might have special permissions, eg.
|
|
|
|
# when test image is on NFS and would not be writable for root
|
2016-11-11 09:12:05 +00:00
|
|
|
run_check truncate -s 0 "$TEST_DEV"
|
2016-06-03 13:28:44 +00:00
|
|
|
# 256MB is the smallest acceptable btrfs image.
|
2016-11-11 09:12:05 +00:00
|
|
|
run_check truncate -s 512M "$TEST_DEV"
|
2017-08-22 16:32:57 +00:00
|
|
|
force=
|
|
|
|
mountopts=
|
|
|
|
case "$fstype" in
|
|
|
|
ext[234])
|
|
|
|
force=-F ;;
|
|
|
|
reiserfs)
|
|
|
|
force=-ff
|
|
|
|
mountopts="-o acl,user_xattr,attrs" ;;
|
|
|
|
*)
|
|
|
|
_fail "unknown filesystem to convert: $fstype"
|
|
|
|
esac
|
|
|
|
run_check "$@" $force "$TEST_DEV"
|
2016-06-03 13:28:44 +00:00
|
|
|
|
2016-06-22 09:25:33 +00:00
|
|
|
# create a file to check btrfs-convert can convert regular file correct
|
2017-08-22 16:32:57 +00:00
|
|
|
run_check_mount_convert_dev "$fstype" $mountopts
|
2016-06-03 13:28:44 +00:00
|
|
|
|
|
|
|
# create a file inside the fs before convert, to make sure there is
|
|
|
|
# data covering btrfs backup superblock range (64M)
|
|
|
|
run_check $SUDO_HELPER dd if=/dev/zero bs=1M count=64 \
|
2016-11-11 09:12:05 +00:00
|
|
|
of="$TEST_MNT/convert_space_holder"
|
2016-06-22 09:25:33 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
# generate md5 checksums of files on $TEST_MNT
|
|
|
|
# $1: path where the checksums will be stored
|
|
|
|
convert_test_gen_checksums() {
|
2016-11-11 07:40:21 +00:00
|
|
|
_assert_path "$1"
|
2016-06-03 13:28:44 +00:00
|
|
|
|
2016-11-11 09:12:05 +00:00
|
|
|
run_check $SUDO_HELPER dd if=/dev/zero of="$TEST_MNT/test" "bs=$nodesize" \
|
2016-06-03 13:28:44 +00:00
|
|
|
count=1 >/dev/null 2>&1
|
2016-11-11 09:12:05 +00:00
|
|
|
run_check_stdout $SUDO_HELPER find "$TEST_MNT" -type f ! -name 'image' -exec md5sum {} \+ > "$1"
|
2016-06-22 09:25:33 +00:00
|
|
|
}
|
2016-09-05 19:27:36 +00:00
|
|
|
# list $TEST_MNT data set file permissions.
|
|
|
|
# $1: path where the permissions will be stored
|
|
|
|
convert_test_perm() {
|
|
|
|
local PERMTMP
|
2016-11-11 07:40:21 +00:00
|
|
|
|
|
|
|
_assert_path "$1"
|
2016-09-05 19:27:36 +00:00
|
|
|
PERMTMP="$1"
|
|
|
|
FILES_LIST=$(mktemp --tmpdir btrfs-progs-convert.fileslistXXXXXX)
|
|
|
|
|
2016-11-11 09:12:05 +00:00
|
|
|
run_check $SUDO_HELPER dd if=/dev/zero of="$TEST_MNT/test" "bs=$nodesize" \
|
2016-09-05 19:27:36 +00:00
|
|
|
count=1 >/dev/null 2>&1
|
2016-11-11 09:12:05 +00:00
|
|
|
run_check_stdout $SUDO_HELPER find "$TEST_MNT" -type f ! -name 'image' -fprint "$FILES_LIST"
|
2016-09-05 19:27:36 +00:00
|
|
|
# Fix directory entries order
|
2016-11-11 09:12:05 +00:00
|
|
|
sort "$FILES_LIST" -o "$FILES_LIST"
|
|
|
|
for file in `cat "$FILES_LIST"` ;do
|
|
|
|
run_check_stdout $SUDO_HELPER getfacl --absolute-names "$file" >> "$PERMTMP"
|
2016-09-05 19:27:36 +00:00
|
|
|
done
|
2016-11-11 09:12:05 +00:00
|
|
|
rm -- "$FILES_LIST"
|
2016-09-05 19:27:36 +00:00
|
|
|
}
|
|
|
|
# list acls of files on $TEST_MNT
|
|
|
|
# $1: path where the acls will be stored
|
|
|
|
convert_test_acl() {
|
|
|
|
local ACLSTMP
|
|
|
|
ACLTMP="$1"
|
|
|
|
FILES_LIST=$(mktemp --tmpdir btrfs-progs-convert.fileslistXXXXXX)
|
|
|
|
|
2016-11-11 09:12:05 +00:00
|
|
|
run_check_stdout $SUDO_HELPER find "$TEST_MNT/acls" -type f -fprint "$FILES_LIST"
|
2016-09-05 19:27:36 +00:00
|
|
|
# Fix directory entries order
|
2016-11-11 09:12:05 +00:00
|
|
|
sort "$FILES_LIST" -o "$FILES_LIST"
|
|
|
|
for file in `cat "$FILES_LIST"`;do
|
|
|
|
run_check_stdout $SUDO_HELPER getfattr --absolute-names -d "$file" >> "$ACLTMP"
|
2016-09-05 19:27:36 +00:00
|
|
|
done
|
2016-11-11 09:12:05 +00:00
|
|
|
rm -- "$FILES_LIST"
|
2016-09-05 19:27:36 +00:00
|
|
|
}
|
2016-06-03 13:28:44 +00:00
|
|
|
|
2016-06-22 09:25:33 +00:00
|
|
|
# do conversion with given features and nodesize, fsck afterwards
|
|
|
|
# $1: features, argument of -O, can be empty
|
|
|
|
# $2: nodesize, argument of -N, can be empty
|
|
|
|
convert_test_do_convert() {
|
2016-11-11 09:12:05 +00:00
|
|
|
run_check "$TOP/btrfs-convert" ${1:+-O "$1"} ${2:+-N "$2"} "$TEST_DEV"
|
2016-11-21 13:51:40 +00:00
|
|
|
run_check "$TOP/btrfs" check "$TEST_DEV"
|
2016-11-11 09:12:05 +00:00
|
|
|
run_check "$TOP/btrfs" inspect-internal dump-super -Ffa "$TEST_DEV"
|
2016-06-22 09:25:33 +00:00
|
|
|
}
|
|
|
|
|
2016-09-05 19:27:36 +00:00
|
|
|
# post conversion check, verify file permissions.
|
|
|
|
# $1: file with ext permissions.
|
|
|
|
convert_test_post_check_permissions() {
|
|
|
|
local EXT_PERMTMP
|
|
|
|
local BTRFS_PERMTMP
|
|
|
|
|
2016-11-11 07:40:21 +00:00
|
|
|
_assert_path "$1"
|
2016-09-05 19:27:36 +00:00
|
|
|
EXT_PERMTMP="$1"
|
|
|
|
BTRFS_PERMTMP=$(mktemp --tmpdir btrfs-progs-convert.permXXXXXX)
|
|
|
|
convert_test_perm "$BTRFS_PERMTMP"
|
|
|
|
|
2016-11-11 09:12:05 +00:00
|
|
|
btrfs_perm=`md5sum "$BTRFS_PERMTMP" | cut -f1 -d' '`
|
|
|
|
ext_perm=`md5sum "$EXT_PERMTMP" | cut -f1 -d' '`
|
2016-09-05 19:27:36 +00:00
|
|
|
|
|
|
|
if [ "$btrfs_perm" != "$ext_perm" ];
|
|
|
|
then
|
2016-11-11 09:12:05 +00:00
|
|
|
btrfs_perm_file=`md5sum "$BTRFS_PERMTMP" | cut -f2 -d' '`
|
|
|
|
ext_perm_file=`md5sum "$EXT_PERMTMP" | cut -f2 -d' '`
|
2016-09-05 19:27:36 +00:00
|
|
|
_fail "file permission failed. Mismatched BTRFS:$btrfs_perm_file:$btrfs_perm EXT:$ext_perm_file:$ext_perm"
|
|
|
|
fi
|
|
|
|
|
2016-11-11 09:12:05 +00:00
|
|
|
rm -- "$BTRFS_PERMTMP"
|
2016-09-05 19:27:36 +00:00
|
|
|
}
|
|
|
|
# post conversion check, compare BTRFS file acls against EXT.
|
|
|
|
# $1: file with ext acls.
|
|
|
|
convert_test_post_check_acl() {
|
|
|
|
local EXT_ACLTMP
|
|
|
|
local BTRFS_ACLTMP
|
|
|
|
|
2016-11-11 07:40:21 +00:00
|
|
|
_assert_path "$1"
|
2016-09-05 19:27:36 +00:00
|
|
|
EXT_ACLTMP="$1"
|
|
|
|
BTRFS_ACLTMP=$(mktemp --tmpdir btrfs-progs-convert.aclsXXXXXXX)
|
|
|
|
convert_test_acl "$BTRFS_ACLTMP"
|
|
|
|
|
2016-11-11 09:12:05 +00:00
|
|
|
btrfs_acl=`md5sum "$BTRFS_ACLTMP" | cut -f1 -d' '`
|
|
|
|
ext_acl=`md5sum "$EXT_ACLTMP" | cut -f1 -d' '`
|
2016-09-05 19:27:36 +00:00
|
|
|
|
|
|
|
if [ "$btrfs_acl" != "$ext_acl" ]
|
|
|
|
then
|
2016-11-11 09:12:05 +00:00
|
|
|
btrfs_acl_file=`md5sum "$BTRFS_ACLTMP" | cut -f2 -d' '`
|
|
|
|
ext_acl_file=`md5sum "$EXT_ACLTMP" | cut -f2 -d' '`
|
2016-09-05 19:27:36 +00:00
|
|
|
_fail "file acl failed. Mismatched BTRFS:$btrfs_acl_file:$btrfs_acl EXT:$ext_acl_file:$ext_acl"
|
|
|
|
fi
|
|
|
|
|
2016-11-11 09:12:05 +00:00
|
|
|
rm -- "$BTRFS_ACLTMP"
|
2016-09-05 19:27:36 +00:00
|
|
|
}
|
2016-11-11 00:27:39 +00:00
|
|
|
|
2016-06-22 09:25:33 +00:00
|
|
|
# post conversion checks, verify md5sums
|
2016-11-11 00:27:39 +00:00
|
|
|
convert_test_post_check_checksums() {
|
2016-11-11 07:40:21 +00:00
|
|
|
_assert_path "$1"
|
|
|
|
run_check_stdout $SUDO_HELPER md5sum -c "$1" |
|
2016-11-11 00:27:39 +00:00
|
|
|
grep -q 'FAILED' && _fail "file validation failed"
|
|
|
|
}
|
|
|
|
|
|
|
|
# post conversion checks, all three in one call, on an unmounted image
|
2016-06-22 09:25:33 +00:00
|
|
|
# $1: file with checksums
|
2016-09-05 19:27:36 +00:00
|
|
|
# $2: file with permissions.
|
|
|
|
# $3: file with acl entries.
|
2016-11-11 00:27:39 +00:00
|
|
|
convert_test_post_checks_all() {
|
2016-11-11 07:40:21 +00:00
|
|
|
_assert_path "$1"
|
|
|
|
_assert_path "$2"
|
|
|
|
_assert_path "$3"
|
2016-09-05 19:27:36 +00:00
|
|
|
|
2016-06-03 13:28:44 +00:00
|
|
|
run_check_mount_test_dev
|
2016-11-11 07:40:21 +00:00
|
|
|
convert_test_post_check_checksums "$1"
|
|
|
|
convert_test_post_check_permissions "$2"
|
|
|
|
convert_test_post_check_acl "$3"
|
2016-12-19 06:56:42 +00:00
|
|
|
|
|
|
|
# Create a large file to trigger data chunk allocation
|
|
|
|
generate_dataset "large"
|
2016-06-03 13:28:44 +00:00
|
|
|
run_check_umount_test_dev
|
2016-06-22 09:25:33 +00:00
|
|
|
}
|
2016-06-03 13:28:44 +00:00
|
|
|
|
2016-06-22 09:25:33 +00:00
|
|
|
# do rollback and fsck
|
2017-09-07 12:44:45 +00:00
|
|
|
# $1: filesystem name or alias (ext2 includes ext3 and ext4),
|
2016-06-22 09:25:33 +00:00
|
|
|
convert_test_post_rollback() {
|
2017-09-07 12:44:45 +00:00
|
|
|
local types
|
|
|
|
|
2016-11-11 09:12:05 +00:00
|
|
|
run_check "$TOP/btrfs-convert" --rollback "$TEST_DEV"
|
2017-09-07 12:44:45 +00:00
|
|
|
if [ -z "$1" ]; then
|
|
|
|
_fail "missing filesystem type to check"
|
|
|
|
fi
|
|
|
|
case "$1" in
|
|
|
|
ext[234]) types=ext2,ext3,ext4 ;;
|
|
|
|
reiserfs) types=reiserfs ;;
|
|
|
|
*) _fail "unknown filesystem type to check: $1" ;;
|
|
|
|
esac
|
|
|
|
|
|
|
|
run_check fsck -n -t "$types" "$TEST_DEV"
|
2016-06-03 13:28:44 +00:00
|
|
|
}
|
|
|
|
|
2016-06-22 09:25:33 +00:00
|
|
|
# simple wrapper for a convert test
|
2017-07-20 15:53:56 +00:00
|
|
|
# $1: type of the converted filesystem
|
|
|
|
# $2: btrfs features, argument to -O
|
|
|
|
# $3: description of the test "ext2 8k nodesize"
|
|
|
|
# $4: nodesize value
|
|
|
|
# $5 + rest: command to create the ext2 image
|
2016-06-22 09:25:33 +00:00
|
|
|
convert_test() {
|
2017-07-20 15:53:56 +00:00
|
|
|
local fstype
|
2016-06-22 09:25:33 +00:00
|
|
|
local features
|
|
|
|
local nodesize
|
|
|
|
local msg
|
|
|
|
local CHECKSUMTMP
|
2016-09-05 19:27:36 +00:00
|
|
|
local EXT_PERMTMP
|
|
|
|
local EXT_ACLTMP
|
2016-06-22 09:25:33 +00:00
|
|
|
|
2017-07-20 15:53:56 +00:00
|
|
|
fstype="$1"
|
|
|
|
features="$2"
|
|
|
|
msg="$3"
|
|
|
|
nodesize="$4"
|
|
|
|
shift 4
|
2016-06-22 09:25:33 +00:00
|
|
|
convert_test_preamble "$features" "$msg" "$nodesize" "$@"
|
2017-07-20 15:53:56 +00:00
|
|
|
convert_test_prep_fs "$fstype" "$@"
|
2016-06-22 09:25:33 +00:00
|
|
|
populate_fs
|
|
|
|
CHECKSUMTMP=$(mktemp --tmpdir btrfs-progs-convert.XXXXXXXXXX)
|
2016-09-05 19:27:36 +00:00
|
|
|
EXT_PERMTMP=$(mktemp --tmpdir btrfs-progs-convert.permXXXXXX)
|
|
|
|
EXT_ACLTMP=$(mktemp --tmpdir btrfs-progs-convert.aclsXXXXXXX)
|
2016-06-22 09:25:33 +00:00
|
|
|
convert_test_gen_checksums "$CHECKSUMTMP"
|
2016-09-05 19:27:36 +00:00
|
|
|
convert_test_perm "$EXT_PERMTMP"
|
|
|
|
convert_test_acl "$EXT_ACLTMP"
|
2016-06-22 09:25:33 +00:00
|
|
|
|
|
|
|
run_check_umount_test_dev
|
|
|
|
|
|
|
|
convert_test_do_convert "$features" "$nodesize"
|
2016-11-11 00:27:39 +00:00
|
|
|
convert_test_post_checks_all "$CHECKSUMTMP" "$EXT_PERMTMP" "$EXT_ACLTMP"
|
2016-11-11 09:12:05 +00:00
|
|
|
rm -- "$CHECKSUMTMP"
|
|
|
|
rm -- "$EXT_PERMTMP"
|
|
|
|
rm -- "$EXT_ACLTMP"
|
2016-06-22 09:25:33 +00:00
|
|
|
|
2017-09-07 12:44:45 +00:00
|
|
|
convert_test_post_rollback "$fstype"
|
2016-06-22 09:25:33 +00:00
|
|
|
}
|
2017-09-07 15:29:51 +00:00
|
|
|
|
|
|
|
load_module_reiserfs()
|
|
|
|
{
|
|
|
|
$SUDO_HELPER modprobe reiserfs
|
|
|
|
}
|
|
|
|
|
|
|
|
check_kernel_support_reiserfs()
|
|
|
|
{
|
|
|
|
if ! grep -iq 'reiserfs' /proc/filesystems; then
|
|
|
|
echo "WARNING: reiserfs filesystem not listed in /proc/filesystems, some tests might be skipped"
|
|
|
|
return 1
|
|
|
|
fi
|
|
|
|
return 0
|
|
|
|
}
|