3 # loop through all of our bad images and make sure fsck repairs them properly
6 SCRIPT_DIR=$(dirname $(readlink -f "$0"))
7 TOP=$(readlink -f "$SCRIPT_DIR/../")
9 RESULTS="$TOP/tests/fsck-tests-results.txt"
10 IMAGE="$TOP/tests/test.img"
12 source "$TOP/tests/common"
22 # test rely on corrupting blocks tool
23 check_prereq btrfs-corrupt-block
24 check_prereq btrfs-image
26 check_prereq btrfstune
33 echo " [TEST/fsck] $(basename $testname)"
35 echo "=== Entering $testname" >> "$RESULTS"
36 if [ -x test.sh ]; then
40 if [[ $TEST_LOG =~ dump ]]; then
43 _fail "test failed for case $(basename $testname)"
52 # Each dir contains one type of error for btrfsck test.
53 # Each dir must be one of the following 2 types:
54 # 1) Only btrfs-image dump
55 # Only contains one or several btrfs-image dumps (.img)
56 # Each image will be tested by generic test routine
57 # (btrfsck --repair and btrfsck).
58 # This is for case that btree-healthy images.
59 # 2) Custom test script
60 # This dir contains test.sh which will do custom image
61 # generation/check/verification.
62 # This is for case btrfs-image can't dump or case needs extra
65 for i in $(find "$TOP/tests/fsck-tests" -maxdepth 1 -mindepth 1 -type d \
66 ${TEST:+-name "$TEST"} | sort)