64 lines
1.6 KiB
Bash
Executable File
64 lines
1.6 KiB
Bash
Executable File
#!/bin/bash
|
|
#
|
|
# loop through all of our bad images and make sure fsck repairs them properly
|
|
#
|
|
# It's GPL, same as everything else in this tree.
|
|
#
|
|
|
|
unset TOP
|
|
unset LANG
|
|
LANG=C
|
|
SCRIPT_DIR=$(dirname $(realpath $0))
|
|
TOP=$(realpath $SCRIPT_DIR/../)
|
|
TEST_DEV=${TEST_DEV:-}
|
|
TEST_MNT=${TEST_MNT:-$TOP/tests/mnt}
|
|
RESULTS="$TOP/tests/fsck-tests-results.txt"
|
|
|
|
source $TOP/tests/common
|
|
|
|
# Allow child test to use $TOP and $RESULTS
|
|
export TOP
|
|
export RESULTS
|
|
# For custom script needs to verfiy recovery
|
|
export TEST_MNT
|
|
export LANG
|
|
|
|
rm -f $RESULTS
|
|
mkdir -p $TEST_MNT || _fail "unable to create mount point on $TEST_MNT"
|
|
|
|
# test rely on corrupting blocks tool
|
|
check_prereq btrfs-corrupt-block
|
|
check_prereq btrfs-image
|
|
check_prereq btrfs
|
|
|
|
# Each dir contains one type of error for btrfsck test.
|
|
# Each dir must be one of the following 2 types:
|
|
# 1) Only btrfs-image dump
|
|
# Only contains one or several btrfs-image dumps (.img)
|
|
# Each image will be tested by generic test routine
|
|
# (btrfsck --repair and btrfsck).
|
|
# This is for case that btree-healthy images.
|
|
# 2) Custom test script
|
|
# This dir contains test.sh which will do custom image
|
|
# generation/check/verification.
|
|
# This is for case btrfs-image can't dump or case needs extra
|
|
# check/verify
|
|
|
|
for i in $(find $TOP/tests/fsck-tests -maxdepth 1 -mindepth 1 -type d | sort)
|
|
do
|
|
echo " [TEST] $(basename $i)"
|
|
cd $i
|
|
echo "=== Entering $i" >> $RESULTS
|
|
if [ -x test.sh ]; then
|
|
# Type 2
|
|
./test.sh
|
|
if [ $? -ne 0 ]; then
|
|
_fail "test failed for case $(basename $i)"
|
|
fi
|
|
else
|
|
# Type 1
|
|
check_all_images `pwd`
|
|
fi
|
|
cd $TOP
|
|
done
|