common: create _test_block_boundaries in common/punch
authorLukas Czerner <lczerner@redhat.com>
Thu, 13 Mar 2014 04:18:56 +0000 (15:18 +1100)
committerDave Chinner <david@fromorbit.com>
Thu, 13 Mar 2014 04:18:56 +0000 (15:18 +1100)
Create new function _test_block_boundaries() which is testing content of
the blocks after the operation such as zero, or punch hole. The test is
doing the operation around block boundaries to assure correct behaviour
of the operation on block unaligned ranges.

This has been based on test xfs/290 which has been changed to use this
new function. A small change to the output file was required.

Signed-off-by: Lukas Czerner <lczerner@redhat.com>
Reviewed-by: Christoph Hellwig <hch@lst.de>
Signed-off-by: Dave Chinner <david@fromorbit.com>
common/punch
tests/xfs/290
tests/xfs/290.out

index 9340d3bf542091e620876060d62ace57c33d63c4..f2d538c1d3e73656ede38c30715f1b77391bea9b 100644 (file)
@@ -566,3 +566,109 @@ _test_generic_punch()
        [ $? -ne 0 ] && die_now
        od -x $testfile | head -n -1
 }
+
+_test_block_boundaries()
+{
+
+       remove_testfile=1
+       sync_cmd="-c fsync"
+       unwritten_tests=1
+       OPTIND=1
+       while getopts 'dk' OPTION
+       do
+               case $OPTION in
+               k)      remove_testfile=
+               ;;
+               d)      sync_cmd=
+               ;;
+               ?)      echo Invalid flag
+               exit 1
+               ;;
+               esac
+       done
+       shift $(($OPTIND - 1))
+
+       bs=$1
+       zero_cmd=$2
+       filter_cmd=$3
+       testfile=$4
+
+       # Block size plus 1
+       bs_p1=$(($bs + 1))
+       # Block size plus 2
+       bs_p2=$(($bs + 2))
+
+       # Block size minus 1
+       bs_m1=$(($bs - 1))
+
+       # Block size multiplied by 2
+       bs_t2=$(($bs * 2))
+
+       # Block size divided by 2
+       bs_d2=$(($bs / 2))
+
+       echo "zero 0, 1"
+       $XFS_IO_PROG -f -t -c "pwrite -S 0x41 0 $bs" \
+                          -c "pwrite -S 0x42 $bs $bs" \
+                          -c "$zero_cmd 0 1" \
+                          -c "pread -v 0 $bs_t2" \
+                          $testfile | $filter_cmd
+
+       echo "zero 0, $bs_m1"
+       $XFS_IO_PROG -f -t -c "pwrite -S 0x41 0 $bs" \
+                          -c "pwrite -S 0x42 $bs $bs" \
+                          -c "$zero_cmd 0 $bs_m1" \
+                          -c "pread -v 0 $bs_t2" \
+                          $testfile | $filter_cmd
+
+       echo "zero 0, $bs"
+       $XFS_IO_PROG -f -t -c "pwrite -S 0x41 0 $bs" \
+                          -c "pwrite -S 0x42 $bs $bs" \
+                          -c "$zero_cmd 0 $bs" \
+                          -c "pread -v 0 $bs_t2" \
+                          $testfile | $filter_cmd
+
+       echo "zero 0, $bs_p1"
+       $XFS_IO_PROG -f -t -c "pwrite -S 0x41 0 $bs" \
+                          -c "pwrite -S 0x42 $bs $bs" \
+                          -c "$zero_cmd 0 $bs_p1" \
+                          -c "pread -v 0 $bs_t2" \
+                          $testfile | $filter_cmd
+
+       echo "zero $bs_m1, $bs"
+       $XFS_IO_PROG -f -t -c "pwrite -S 0x41 0 $bs" \
+                          -c "pwrite -S 0x42 $bs $bs" \
+                          -c "$zero_cmd $bs_m1 $bs" \
+                          -c "pread -v 0 $bs_t2" \
+                          $testfile | $filter_cmd
+
+       echo "zero $bs_m1, $bs_p1"
+       $XFS_IO_PROG -f -t -c "pwrite -S 0x41 0 $bs" \
+                          -c "pwrite -S 0x42 $bs $bs" \
+                          -c "$zero_cmd $bs_m1 $bs_p1" \
+                          -c "pread -v 0 $bs_t2" \
+                          $testfile | $filter_cmd
+
+       echo "zero $bs_m1, $bs_p2"
+       $XFS_IO_PROG -f -t -c "pwrite -S 0x41 0 $bs" \
+                          -c "pwrite -S 0x42 $bs $bs" \
+                          -c "$zero_cmd $bs_m1 $bs_p2" \
+                          -c "pread -v 0 $bs_t2" \
+                          $testfile | $filter_cmd
+
+
+       echo "zero $bs, $bs"
+       $XFS_IO_PROG -f -t -c "pwrite -S 0x41 0 $bs" \
+                          -c "pwrite -S 0x42 $bs $bs" \
+                          -c "$zero_cmd $bs $bs" \
+                          -c "pread -v 0 $bs_t2" \
+                          $testfile | $filter_cmd
+
+
+       echo "zero $bs_d2 , $bs"
+       $XFS_IO_PROG -f -t -c "pwrite -S 0x41 0 $bs" \
+                          -c "pwrite -S 0x42 $bs $bs" \
+                          -c "$zero_cmd $bs_d2 $bs" \
+                          -c "pread -v 0 $bs_t2" \
+                          $testfile | $filter_cmd
+}
index 547a0ba0bd708e299eef4450b0b982eb29f5fc6d..cbe7108d5bbd172a510f079c809ffa06db3e2a55 100755 (executable)
@@ -38,6 +38,7 @@ trap "exit \$status" 0 1 2 3 15
 # get standard environment, filters and checks
 . ./common/rc
 . ./common/filter
+. ./common/punch
 
 # real QA test starts here
 
@@ -49,44 +50,7 @@ _require_xfs_io_zero
 
 testfile=$TEST_DIR/290.$$
 
-test_zero()
-{
-       zero_start=$1
-       zero_len=$2
-
-       $XFS_IO_PROG -f -t -c "pwrite -S 0x41 0 4096" \
-                      -c "pwrite -S 0x42 4096 4096" \
-                      -c "zero $zero_start $zero_len" \
-                      -c "pread -v 0 8192" \
-                      $testfile | _filter_xfs_io_unique
-}
-
-# [0,1] -- Shouldn't toss anything
-test_zero    0    1
-
-#[0,4095] -- Shouldn't toss anything
-test_zero    0 4095
-
-#[0,4096] -- Should toss first page
-test_zero    0 4096
-
-#[0,4097] -- Should toss first page
-test_zero    0 4097
-
-#[4095,8191] -- Should toss last byte of first page
-test_zero 4095 4096
-
-#[4095,8192] -- Should toss second page & last byte of first page
-test_zero 4095 4097
-
-#[4095,8193] -- Should toss second page & last byte of first page
-test_zero 4095 4098
-
-#[4096,8192] -- Should toss second page
-test_zero 4096 4096
-
-#[1024,5120] -- Should toss from 1024 to end of first page
-test_zero 1024 4096
+_test_block_boundaries 4096 zero _filter_xfs_io_unique $testfile
 
 # success, all done
 status=0
index 229c2b3a1bd99216a7466ad738116ca682298838..2487a930412737f6a7b6c79126801ce5540c8c8d 100644 (file)
@@ -1,4 +1,5 @@
 QA output created by 290
+zero 0, 1
 wrote 4096/4096 bytes at offset 0
 XXX Bytes, X ops; XX:XX:XX.X (XXX YYY/sec and XXX ops/sec)
 wrote 4096/4096 bytes at offset 4096
@@ -10,6 +11,7 @@ XXX Bytes, X ops; XX:XX:XX.X (XXX YYY/sec and XXX ops/sec)
 *
 read 8192/8192 bytes at offset 0
 XXX Bytes, X ops; XX:XX:XX.X (XXX YYY/sec and XXX ops/sec)
+zero 0, 4095
 wrote 4096/4096 bytes at offset 0
 XXX Bytes, X ops; XX:XX:XX.X (XXX YYY/sec and XXX ops/sec)
 wrote 4096/4096 bytes at offset 4096
@@ -21,6 +23,7 @@ XXX Bytes, X ops; XX:XX:XX.X (XXX YYY/sec and XXX ops/sec)
 *
 read 8192/8192 bytes at offset 0
 XXX Bytes, X ops; XX:XX:XX.X (XXX YYY/sec and XXX ops/sec)
+zero 0, 4096
 wrote 4096/4096 bytes at offset 0
 XXX Bytes, X ops; XX:XX:XX.X (XXX YYY/sec and XXX ops/sec)
 wrote 4096/4096 bytes at offset 4096
@@ -31,6 +34,7 @@ XXX Bytes, X ops; XX:XX:XX.X (XXX YYY/sec and XXX ops/sec)
 *
 read 8192/8192 bytes at offset 0
 XXX Bytes, X ops; XX:XX:XX.X (XXX YYY/sec and XXX ops/sec)
+zero 0, 4097
 wrote 4096/4096 bytes at offset 0
 XXX Bytes, X ops; XX:XX:XX.X (XXX YYY/sec and XXX ops/sec)
 wrote 4096/4096 bytes at offset 4096
@@ -42,6 +46,7 @@ XXX Bytes, X ops; XX:XX:XX.X (XXX YYY/sec and XXX ops/sec)
 *
 read 8192/8192 bytes at offset 0
 XXX Bytes, X ops; XX:XX:XX.X (XXX YYY/sec and XXX ops/sec)
+zero 4095, 4096
 wrote 4096/4096 bytes at offset 0
 XXX Bytes, X ops; XX:XX:XX.X (XXX YYY/sec and XXX ops/sec)
 wrote 4096/4096 bytes at offset 4096
@@ -54,6 +59,7 @@ XXX Bytes, X ops; XX:XX:XX.X (XXX YYY/sec and XXX ops/sec)
 00001ff0:  00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 42  ...............B
 read 8192/8192 bytes at offset 0
 XXX Bytes, X ops; XX:XX:XX.X (XXX YYY/sec and XXX ops/sec)
+zero 4095, 4097
 wrote 4096/4096 bytes at offset 0
 XXX Bytes, X ops; XX:XX:XX.X (XXX YYY/sec and XXX ops/sec)
 wrote 4096/4096 bytes at offset 4096
@@ -65,6 +71,7 @@ XXX Bytes, X ops; XX:XX:XX.X (XXX YYY/sec and XXX ops/sec)
 *
 read 8192/8192 bytes at offset 0
 XXX Bytes, X ops; XX:XX:XX.X (XXX YYY/sec and XXX ops/sec)
+zero 4095, 4098
 wrote 4096/4096 bytes at offset 0
 XXX Bytes, X ops; XX:XX:XX.X (XXX YYY/sec and XXX ops/sec)
 wrote 4096/4096 bytes at offset 4096
@@ -76,6 +83,7 @@ XXX Bytes, X ops; XX:XX:XX.X (XXX YYY/sec and XXX ops/sec)
 *
 read 8192/8192 bytes at offset 0
 XXX Bytes, X ops; XX:XX:XX.X (XXX YYY/sec and XXX ops/sec)
+zero 4096, 4096
 wrote 4096/4096 bytes at offset 0
 XXX Bytes, X ops; XX:XX:XX.X (XXX YYY/sec and XXX ops/sec)
 wrote 4096/4096 bytes at offset 4096
@@ -86,15 +94,16 @@ XXX Bytes, X ops; XX:XX:XX.X (XXX YYY/sec and XXX ops/sec)
 *
 read 8192/8192 bytes at offset 0
 XXX Bytes, X ops; XX:XX:XX.X (XXX YYY/sec and XXX ops/sec)
+zero 2048 , 4096
 wrote 4096/4096 bytes at offset 0
 XXX Bytes, X ops; XX:XX:XX.X (XXX YYY/sec and XXX ops/sec)
 wrote 4096/4096 bytes at offset 4096
 XXX Bytes, X ops; XX:XX:XX.X (XXX YYY/sec and XXX ops/sec)
 00000000:  41 41 41 41 41 41 41 41 41 41 41 41 41 41 41 41  AAAAAAAAAAAAAAAA
 *
-00000400:  00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00  ................
+00000800:  00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00  ................
 *
-00001400:  42 42 42 42 42 42 42 42 42 42 42 42 42 42 42 42  BBBBBBBBBBBBBBBB
+00001800:  42 42 42 42 42 42 42 42 42 42 42 42 42 42 42 42  BBBBBBBBBBBBBBBB
 *
 read 8192/8192 bytes at offset 0
 XXX Bytes, X ops; XX:XX:XX.X (XXX YYY/sec and XXX ops/sec)