]> git.sur5r.net Git - u-boot/blobdiff - test/fs/fs-test.sh
dm: Simple Watchdog uclass
[u-boot] / test / fs / fs-test.sh
index a4fb0559625d07ff24bed8224f6d53da2ec29280..b19486419e9209dce3386ca56fbf7ab540b23bce 100755 (executable)
@@ -9,14 +9,14 @@
 # It currently tests the fs/sb and native commands for ext4 and fat partitions
 # Expected results are as follows:
 # EXT4 tests:
-# fs-test.sb.ext4.out: Summary: PASS: 17 FAIL: 2
-# fs-test.ext4.out: Summary: PASS: 11 FAIL: 8
-# fs-test.fs.ext4.out: Summary: PASS: 11 FAIL: 8
+# fs-test.sb.ext4.out: Summary: PASS: 23 FAIL: 0
+# fs-test.ext4.out: Summary: PASS: 23 FAIL: 0
+# fs-test.fs.ext4.out: Summary: PASS: 23 FAIL: 0
 # FAT tests:
-# fs-test.sb.fat.out: Summary: PASS: 17 FAIL: 2
-# fs-test.fat.out: Summary: PASS: 19 FAIL: 0
-# fs-test.fs.fat.out: Summary: PASS: 19 FAIL: 0
-# Total Summary: TOTAL PASS: 94 TOTAL FAIL: 20
+# fs-test.sb.fat.out: Summary: PASS: 23 FAIL: 0
+# fs-test.fat.out: Summary: PASS: 20 FAIL: 3
+# fs-test.fs.fat.out: Summary: PASS: 20 FAIL: 3
+# Total Summary: TOTAL PASS: 132 TOTAL FAIL: 6
 
 # pre-requisite binaries list.
 PREREQ_BINS="md5sum mkfs mount umount dd fallocate mkdir"
@@ -58,7 +58,7 @@ GB2p5="${MOUNT_DIR}/${BIG_FILE}"
 # Check if the prereq binaries exist, or exit
 function check_prereq() {
        for prereq in $PREREQ_BINS; do
-               if [ ! -x `which $prereq` ]; then
+               if [ ! -x "`which $prereq`" ]; then
                        echo "Missing $prereq binary. Exiting!"
                        exit
                fi
@@ -100,7 +100,7 @@ function compile_sandbox() {
 # We save time by not deleting and recreating the file system images
 function prepare_env() {
        rm -f ${MD5_FILE}.* ${OUT}.*
-       mkdir ${OUT_DIR}
+       mkdir -p ${OUT_DIR}
 }
 
 # 1st parameter is the name of the image file to be created
@@ -115,30 +115,26 @@ function create_image() {
        fi
        if [ ! -f "$1" ]; then
                fallocate -l 3G "$1" &> /dev/null
+               if [ $? -ne 0 ]; then
+                       echo fallocate failed - using dd instead
+                       dd if=/dev/zero of=$1 bs=1024 count=$((3 * 1024 * 1024))
+                       if [ $? -ne 0 ]; then
+                               echo Could not create empty disk image
+                               exit $?
+                       fi
+               fi
                mkfs -t "$2" $MKFS_OPTION "$1" &> /dev/null
                if [ $? -ne 0 -a "$2" = "fat" ]; then
                        # If we fail and we did fat, try vfat.
                        mkfs -t vfat $MKFS_OPTION "$1" &> /dev/null
                fi
+               if [ $? -ne 0 ]; then
+                       echo Could not create filesystem
+                       exit $?
+               fi
        fi
 }
 
-# 1st parameter is the FS type: fat/ext4
-# 2nd parameter is the name of small file
-# Returns filename which can be used for fat or ext4 for writing
-function fname_for_write() {
-       case $1 in
-               ext4)
-                       # ext4 needs absolute path name of file
-                       echo /${2}.w
-                       ;;
-
-               *)
-                       echo ${2}.w
-                       ;;
-       esac
-}
-
 # 1st parameter is image file
 # 2nd parameter is file system type - fat/ext4
 # 3rd parameter is name of small file
@@ -154,11 +150,14 @@ function test_image() {
 
        case "$2" in
                fat)
+               FPATH=""
                PREFIX="fat"
                WRITE="write"
                ;;
 
                ext4)
+               # ext4 needs absolute path
+               FPATH="/"
                PREFIX="ext4"
                WRITE="write"
                ;;
@@ -193,16 +192,15 @@ function test_image() {
 
        esac
 
-       if [ -z "$6" ]; then
-               FILE_WRITE=`fname_for_write $2 $3`
-               FILE_SMALL=$3
-               FILE_BIG=$4
-       else
-               FILE_WRITE=$6/`fname_for_write $2 $3`
-               FILE_SMALL=$6/$3
-               FILE_BIG=$6/$4
+       # sb always uses full path to mointpoint, irrespective of filesystem
+       if [ "$5" = "sb" ]; then
+               FPATH=${6}/
        fi
 
+       FILE_WRITE=${3}.w
+       FILE_SMALL=$3
+       FILE_BIG=$4
+
        # In u-boot commands, <interface> stands for host or hostfs
        # hostfs maps to the host fs.
        # host maps to the "sb bind" that we do
@@ -218,13 +216,13 @@ ${PREFIX}ls host${SUFFIX} $6
 # sb size hostfs - $3 for hostfs commands.
 # 1MB is 0x0010 0000
 # Test Case 2 - size of small file
-${PREFIX}size host${SUFFIX} $FILE_SMALL
+${PREFIX}size host${SUFFIX} ${FPATH}$FILE_SMALL
 printenv filesize
 setenv filesize
 
 # 2.5GB (1024*1024*2500) is 0x9C40 0000
 # Test Case 3 - size of big file
-${PREFIX}size host${SUFFIX} $FILE_BIG
+${PREFIX}size host${SUFFIX} ${FPATH}$FILE_BIG
 printenv filesize
 setenv filesize
 
@@ -233,14 +231,14 @@ setenv filesize
 # Last two parameters are size and offset.
 
 # Test Case 4a - Read full 1MB of small file
-${PREFIX}load host${SUFFIX} $addr $FILE_SMALL
+${PREFIX}load host${SUFFIX} $addr ${FPATH}$FILE_SMALL
 printenv filesize
 # Test Case 4b - Read full 1MB of small file
 md5sum $addr \$filesize
 setenv filesize
 
 # Test Case 5a - First 1MB of big file
-${PREFIX}load host${SUFFIX} $addr $FILE_BIG $length 0x0
+${PREFIX}load host${SUFFIX} $addr ${FPATH}$FILE_BIG $length 0x0
 printenv filesize
 # Test Case 5b - First 1MB of big file
 md5sum $addr \$filesize
@@ -248,7 +246,7 @@ setenv filesize
 
 # fails for ext as no offset support
 # Test Case 6a - Last 1MB of big file
-${PREFIX}load host${SUFFIX} $addr $FILE_BIG $length 0x9C300000
+${PREFIX}load host${SUFFIX} $addr ${FPATH}$FILE_BIG $length 0x9C300000
 printenv filesize
 # Test Case 6b - Last 1MB of big file
 md5sum $addr \$filesize
@@ -256,7 +254,7 @@ setenv filesize
 
 # fails for ext as no offset support
 # Test Case 7a - One from the last 1MB chunk of 2GB
-${PREFIX}load host${SUFFIX} $addr $FILE_BIG $length 0x7FF00000
+${PREFIX}load host${SUFFIX} $addr ${FPATH}$FILE_BIG $length 0x7FF00000
 printenv filesize
 # Test Case 7b - One from the last 1MB chunk of 2GB
 md5sum $addr \$filesize
@@ -264,7 +262,7 @@ setenv filesize
 
 # fails for ext as no offset support
 # Test Case 8a - One from the start 1MB chunk from 2GB
-${PREFIX}load host${SUFFIX} $addr $FILE_BIG $length 0x80000000
+${PREFIX}load host${SUFFIX} $addr ${FPATH}$FILE_BIG $length 0x80000000
 printenv filesize
 # Test Case 8b - One from the start 1MB chunk from 2GB
 md5sum $addr \$filesize
@@ -272,7 +270,7 @@ setenv filesize
 
 # fails for ext as no offset support
 # Test Case 9a - One 1MB chunk crossing the 2GB boundary
-${PREFIX}load host${SUFFIX} $addr $FILE_BIG $length 0x7FF80000
+${PREFIX}load host${SUFFIX} $addr ${FPATH}$FILE_BIG $length 0x7FF80000
 printenv filesize
 # Test Case 9b - One 1MB chunk crossing the 2GB boundary
 md5sum $addr \$filesize
@@ -280,21 +278,44 @@ setenv filesize
 
 # Generic failure case
 # Test Case 10 - 2MB chunk from the last 1MB of big file
-${PREFIX}load host${SUFFIX} $addr $FILE_BIG 0x00200000 0x9C300000
+${PREFIX}load host${SUFFIX} $addr ${FPATH}$FILE_BIG 0x00200000 0x9C300000
 printenv filesize
 #
 
 # Read 1MB from small file
-${PREFIX}load host${SUFFIX} $addr $FILE_SMALL
+${PREFIX}load host${SUFFIX} $addr ${FPATH}$FILE_SMALL
 # Write it back to test the writes
 # Test Case 11a - Check that the write succeeded
-${PREFIX}${WRITE} host${SUFFIX} $addr $FILE_WRITE \$filesize
+${PREFIX}${WRITE} host${SUFFIX} $addr ${FPATH}$FILE_WRITE \$filesize
 mw.b $addr 00 100
-${PREFIX}load host${SUFFIX} $addr $FILE_WRITE
+${PREFIX}load host${SUFFIX} $addr ${FPATH}$FILE_WRITE
 # Test Case 11b - Check md5 of written to is same as the one read from
 md5sum $addr \$filesize
 setenv filesize
 #
+
+# Next test case checks writing a file whose dirent
+# is the first in the block, which is always true for "."
+# The write should fail, but the lookup should work
+# Test Case 12 - Check directory traversal
+${PREFIX}${WRITE} host${SUFFIX} $addr ${FPATH}. 0x10
+
+# Read 1MB from small file
+${PREFIX}load host${SUFFIX} $addr ${FPATH}$FILE_SMALL
+# Write it via "same directory", i.e. "." dirent
+# Test Case 13a - Check directory traversal
+${PREFIX}${WRITE} host${SUFFIX} $addr ${FPATH}./${FILE_WRITE}2 \$filesize
+mw.b $addr 00 100
+${PREFIX}load host${SUFFIX} $addr ${FPATH}./${FILE_WRITE}2
+# Test Case 13b - Check md5 of written to is same as the one read from
+md5sum $addr \$filesize
+setenv filesize
+mw.b $addr 00 100
+${PREFIX}load host${SUFFIX} $addr ${FPATH}${FILE_WRITE}2
+# Test Case 13c - Check md5 of written to is same as the one read from
+md5sum $addr \$filesize
+setenv filesize
+#
 reset
 
 EOF
@@ -331,9 +352,10 @@ function create_files() {
                        &> /dev/null
        fi
 
-       # Delete the small file which possibly is written as part of a
+       # Delete the small file copies which possibly are written as part of a
        # previous test.
        sudo rm -f "${MB1}.w"
+       sudo rm -f "${MB1}.w2"
 
        # Generate the md5sums of reads that we will test against small file
        dd if="${MB1}" bs=1M skip=0 count=1 2> /dev/null | md5sum > "$2"
@@ -388,7 +410,7 @@ check_md5() {
        # md5sum in u-boot has output of form:
        # md5 for 01000008 ... 01100007 ==> <md5>
        # the 7th field is the actual md5
-       md5_src=`grep -A3 "$1" "$2" | grep "md5 for"`
+       md5_src=`grep -A2 "$1" "$2" | grep "md5 for" | tr -d '\r'`
        md5_src=($md5_src)
        md5_src=${md5_src[6]}
 
@@ -433,48 +455,60 @@ function check_results() {
        pass_fail "TC3: size of $4"
 
        # Check read full mb of 1MB.file
-       grep -A6 "Test Case 4a " "$1" | grep -q "filesize=100000"
+       grep -A4 "Test Case 4a " "$1" | grep -q "filesize=100000"
        pass_fail "TC4: load of $3 size"
        check_md5 "Test Case 4b " "$1" "$2" 1 "TC4: load from $3"
 
        # Check first mb of 2.5GB.file
-       grep -A6 "Test Case 5a " "$1" | grep -q "filesize=100000"
+       grep -A4 "Test Case 5a " "$1" | grep -q "filesize=100000"
        pass_fail "TC5: load of 1st MB from $4 size"
        check_md5 "Test Case 5b " "$1" "$2" 2 "TC5: load of 1st MB from $4"
 
        # Check last mb of 2.5GB.file
-       grep -A6 "Test Case 6a " "$1" | grep -q "filesize=100000"
+       grep -A4 "Test Case 6a " "$1" | grep -q "filesize=100000"
        pass_fail "TC6: load of last MB from $4 size"
        check_md5 "Test Case 6b " "$1" "$2" 3 "TC6: load of last MB from $4"
 
        # Check last 1mb chunk of 2gb from 2.5GB file
-       grep -A6 "Test Case 7a " "$1" | grep -q "filesize=100000"
+       grep -A4 "Test Case 7a " "$1" | grep -q "filesize=100000"
        pass_fail "TC7: load of last 1mb chunk of 2GB from $4 size"
        check_md5 "Test Case 7b " "$1" "$2" 4 \
                "TC7: load of last 1mb chunk of 2GB from $4"
 
        # Check first 1mb chunk after 2gb from 2.5GB file
-       grep -A6 "Test Case 8a " "$1" | grep -q "filesize=100000"
+       grep -A4 "Test Case 8a " "$1" | grep -q "filesize=100000"
        pass_fail "TC8: load 1st MB chunk after 2GB from $4 size"
        check_md5 "Test Case 8b " "$1" "$2" 5 \
                "TC8: load 1st MB chunk after 2GB from $4"
 
        # Check 1mb chunk crossing the 2gb boundary from 2.5GB file
-       grep -A6 "Test Case 9a " "$1" | grep -q "filesize=100000"
+       grep -A4 "Test Case 9a " "$1" | grep -q "filesize=100000"
        pass_fail "TC9: load 1MB chunk crossing 2GB boundary from $4 size"
        check_md5 "Test Case 9b " "$1" "$2" 6 \
                "TC9: load 1MB chunk crossing 2GB boundary from $4"
 
-       # Check 2mb chunk from the last 1MB of 2.5GB file - generic failure case
-       grep -A6 "Test Case 10 " "$1" | grep -q 'Error: "filesize" not defined'
-       pass_fail "TC10: load 2MB from the last 1MB of $4 - generic fail case"
+       # Check 2mb chunk from the last 1MB of 2.5GB file loads 1MB
+       grep -A5 "Test Case 10 " "$1" | grep -q "filesize=100000"
+       pass_fail "TC10: load 2MB from the last 1MB of $4 loads 1MB"
 
        # Check 1mb chunk write
-       grep -A3 "Test Case 11a " "$1" | \
-               egrep -q '1048576 bytes written|update journal'
-       pass_fail "TC11: 1MB write to $5 - write succeeded"
+       grep -A2 "Test Case 11a " "$1" | grep -q '1048576 bytes written'
+       pass_fail "TC11: 1MB write to $3.w - write succeeded"
        check_md5 "Test Case 11b " "$1" "$2" 1 \
-               "TC11: 1MB write to $5 - content verified"
+               "TC11: 1MB write to $3.w - content verified"
+
+       # Check lookup of 'dot' directory
+       grep -A4 "Test Case 12 " "$1" | grep -q 'Unable to write file'
+       pass_fail "TC12: 1MB write to . - write denied"
+
+       # Check directory traversal
+       grep -A2 "Test Case 13a " "$1" | grep -q '1048576 bytes written'
+       pass_fail "TC13: 1MB write to ./$3.w2 - write succeeded"
+       check_md5 "Test Case 13b " "$1" "$2" 1 \
+               "TC13: 1MB read from ./$3.w2 - content verified"
+       check_md5 "Test Case 13c " "$1" "$2" 1 \
+               "TC13: 1MB read from $3.w2 - content verified"
+
        echo "** End $1"
 }
 
@@ -485,11 +519,15 @@ function test_fs_nonfs() {
        echo "Creating files in $fs image if not already present."
        create_files $IMAGE $MD5_FILE_FS
 
-       OUT_FILE="${OUT}.fs.${fs}.out"
+       OUT_FILE="${OUT}.$1.${fs}.out"
        test_image $IMAGE $fs $SMALL_FILE $BIG_FILE $1 "" \
-               > ${OUT_FILE}
-       check_results $OUT_FILE $MD5_FILE_FS $SMALL_FILE $BIG_FILE \
-               $WRITE_FILE
+               > ${OUT_FILE} 2>&1
+       # strip out noise from fs code
+       grep -v -e "File System is consistent\|update journal finished" \
+               -e "reading .*\.file\|writing .*\.file.w" \
+               < ${OUT_FILE} > ${OUT_FILE}_clean
+       check_results ${OUT_FILE}_clean $MD5_FILE_FS $SMALL_FILE \
+               $BIG_FILE
        TOTAL_FAIL=$((TOTAL_FAIL + FAIL))
        TOTAL_PASS=$((TOTAL_PASS + PASS))
        echo "Summary: PASS: $PASS FAIL: $FAIL"
@@ -535,12 +573,11 @@ for fs in ext4 fat; do
 
        OUT_FILE="${OUT}.sb.${fs}.out"
        test_image $IMAGE $fs $SMALL_FILE $BIG_FILE sb `pwd`/$MOUNT_DIR \
-               > ${OUT_FILE}
+               > ${OUT_FILE} 2>&1
        sudo umount "$MOUNT_DIR"
        rmdir "$MOUNT_DIR"
 
-       check_results $OUT_FILE $MD5_FILE_FS $SMALL_FILE $BIG_FILE \
-               $WRITE_FILE
+       check_results $OUT_FILE $MD5_FILE_FS $SMALL_FILE $BIG_FILE
        TOTAL_FAIL=$((TOTAL_FAIL + FAIL))
        TOTAL_PASS=$((TOTAL_PASS + PASS))
        echo "Summary: PASS: $PASS FAIL: $FAIL"