mirror of
https://github.com/kdave/btrfs-progs
synced 2025-01-07 14:09:35 +00:00
2f8aac5375
Commit 31f477ee
("btrfs-progs: mkfs-tests: skip test if truncate fails
with EFBIG") tried to detect a failure in truncate command by checking
the $? expecting it to be an errno, when it actually returns 0 or 1.
To fix this test just check if the command failed (returned 1) and look
for the output, skipping the test if the OS cannot create a 6E file.
Fixes: #241
Tested-by: Erhard Furtner <erhard_f@mailbox.org>
Signed-off-by: Marcos Paulo de Souza <mpdesouza@suse.com>
Signed-off-by: David Sterba <dsterba@suse.com>
36 lines
955 B
Bash
Executable File
36 lines
955 B
Bash
Executable File
#!/bin/bash
|
|
# test if mkfs.btrfs will create file systems that overflow total_bytes
|
|
|
|
source "$TEST_TOP/common"
|
|
|
|
check_prereq mkfs.btrfs
|
|
check_prereq btrfs
|
|
|
|
setup_root_helper
|
|
prepare_test_dev
|
|
|
|
# create a temporary btrfs filesystem for the images to make sure the
|
|
# exabyte-scale files will be reliably created
|
|
run_check_mkfs_test_dev
|
|
run_check_mount_test_dev
|
|
|
|
# truncate can fail with EFBIG if the OS cannot create a 6EiB file
|
|
out=$(run_mayfail_stdout $SUDO_HELPER truncate -s 6E "$TEST_MNT/img1" 2>&1)
|
|
ret=$?
|
|
|
|
if [ $ret -ne 0 ]; then
|
|
run_check_umount_test_dev
|
|
if [[ "$out" == *"File too large"* ]]; then
|
|
_not_run "current kernel could not create a 6EiB file"
|
|
fi
|
|
_fail "command 'truncate -s 6E' failed: $out"
|
|
fi
|
|
|
|
run_check $SUDO_HELPER truncate -s 6E "$TEST_MNT/img2"
|
|
run_check $SUDO_HELPER truncate -s 6E "$TEST_MNT/img3"
|
|
|
|
run_mustfail "mkfs for too-large images" \
|
|
$SUDO_HELPER "$TOP/mkfs.btrfs" -f "$TEST_MNT"/img[123]
|
|
|
|
run_check_umount_test_dev
|