mirror of
https://github.com/linux-apfs/apfstests.git
synced 2026-05-01 15:01:44 -07:00
common: create _test_block_boundaries in common/punch
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>
This commit is contained in:
committed by
Dave Chinner
parent
212f48fdf5
commit
9589e15873
+106
@@ -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
|
||||
}
|
||||
|
||||
+2
-38
@@ -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
|
||||
|
||||
+11
-2
@@ -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)
|
||||
|
||||
Reference in New Issue
Block a user