mirror of
https://github.com/linux-apfs/apfstests.git
synced 2026-05-01 15:01:44 -07:00
generic: test reflink side effects
Test that ctime gets updated and suid is cleared when we reflink. Ensure we can't reflink about RLIMIT_FSIZE. Ensure that we can't expose stale preallocation block data when reflinking above EOF. Make sure dedupe actually catches a single different byte. Signed-off-by: Darrick J. Wong <darrick.wong@oracle.com> Reviewed-by: Eryu Guan <guaneryu@gmail.com> Signed-off-by: Eryu Guan <guaneryu@gmail.com>
This commit is contained in:
committed by
Eryu Guan
parent
da8ac46681
commit
298be055a0
Executable
+62
@@ -0,0 +1,62 @@
|
||||
#! /bin/bash
|
||||
# SPDX-License-Identifier: GPL-2.0
|
||||
# Copyright (c) 2018 Oracle, Inc. All Rights Reserved.
|
||||
#
|
||||
# FS QA Test No. 513
|
||||
#
|
||||
# Ensure that ctime is updated and capabilities are cleared when reflinking.
|
||||
#
|
||||
seq=`basename $0`
|
||||
seqres=$RESULT_DIR/$seq
|
||||
echo "QA output created by $seq"
|
||||
tmp=/tmp/$$
|
||||
status=1 # failure is the default!
|
||||
trap "_cleanup; exit \$status" 0 1 2 3 15
|
||||
|
||||
_cleanup()
|
||||
{
|
||||
cd /
|
||||
rm -f $tmp.*
|
||||
}
|
||||
|
||||
# get standard environment, filters and checks
|
||||
. ./common/rc
|
||||
. ./common/filter
|
||||
. ./common/reflink
|
||||
|
||||
# real QA test starts here
|
||||
_supported_fs generic
|
||||
_supported_os Linux
|
||||
_require_scratch_reflink
|
||||
_require_command "$GETCAP_PROG" getcap
|
||||
_require_command "$SETCAP_PROG" setcap
|
||||
|
||||
rm -f $seqres.full
|
||||
|
||||
_scratch_mkfs >>$seqres.full 2>&1
|
||||
_scratch_mount
|
||||
|
||||
$XFS_IO_PROG -f -c "pwrite -S 0x18 0 1m" $SCRATCH_MNT/foo >>$seqres.full
|
||||
$XFS_IO_PROG -f -c "pwrite -S 0x20 0 1m" $SCRATCH_MNT/bar >>$seqres.full
|
||||
|
||||
$SETCAP_PROG cap_setgid,cap_setuid+ep $SCRATCH_MNT/bar
|
||||
|
||||
before_cap="$($GETCAP_PROG -v $SCRATCH_MNT/bar)"
|
||||
before_ctime="$(stat -c '%z' $SCRATCH_MNT/bar)"
|
||||
|
||||
sleep 1
|
||||
|
||||
$XFS_IO_PROG -c "reflink $SCRATCH_MNT/foo" $SCRATCH_MNT/bar >> $seqres.full 2>&1
|
||||
|
||||
after_cap="$($GETCAP_PROG -v $SCRATCH_MNT/bar)"
|
||||
after_ctime="$(stat -c '%z' $SCRATCH_MNT/bar)"
|
||||
|
||||
echo "$before_cap $before_ctime" >> $seqres.full
|
||||
echo "$after_cap $after_ctime" >> $seqres.full
|
||||
|
||||
test "$before_cap" != "$after_cap" || echo "Expected capabilities to drop."
|
||||
test "$before_ctime" != "$after_ctime" || echo "Expected ctime to change."
|
||||
|
||||
echo Silence is golden.
|
||||
status=0
|
||||
exit
|
||||
@@ -0,0 +1,2 @@
|
||||
QA output created by 513
|
||||
Silence is golden.
|
||||
Executable
+49
@@ -0,0 +1,49 @@
|
||||
#! /bin/bash
|
||||
# SPDX-License-Identifier: GPL-2.0
|
||||
# Copyright (c) 2018 Oracle, Inc. All Rights Reserved.
|
||||
#
|
||||
# FS QA Test No. 514
|
||||
#
|
||||
# Ensure that file size resource limits are respected when reflinking.
|
||||
#
|
||||
seq=`basename $0`
|
||||
seqres=$RESULT_DIR/$seq
|
||||
echo "QA output created by $seq"
|
||||
tmp=/tmp/$$
|
||||
status=1 # failure is the default!
|
||||
trap "_cleanup; exit \$status" 0 1 2 3 15
|
||||
|
||||
_cleanup()
|
||||
{
|
||||
cd /
|
||||
rm -f $tmp.*
|
||||
}
|
||||
|
||||
# get standard environment, filters and checks
|
||||
. ./common/rc
|
||||
. ./common/filter
|
||||
. ./common/reflink
|
||||
|
||||
# real QA test starts here
|
||||
_supported_fs generic
|
||||
_supported_os Linux
|
||||
_require_scratch_reflink
|
||||
_require_user
|
||||
|
||||
rm -f $seqres.full
|
||||
|
||||
_scratch_mkfs >>$seqres.full 2>&1
|
||||
_scratch_mount
|
||||
|
||||
chmod a+rwx $SCRATCH_MNT
|
||||
$XFS_IO_PROG -f -c "pwrite -S 0x18 0 1m" $SCRATCH_MNT/foo >>$seqres.full
|
||||
su -s/bin/bash - $qa_user -c "ulimit -f 64 ; $XFS_IO_PROG -f -c \"reflink $SCRATCH_MNT/foo\" $SCRATCH_MNT/bar" >> $seqres.full 2>&1
|
||||
|
||||
sz="$(stat -c '%s' $SCRATCH_MNT/bar)"
|
||||
if [ "$sz" -ne 0 ] && [ "$sz" -ne 65536 ]; then
|
||||
echo "Oddball file size $sz??"
|
||||
fi
|
||||
|
||||
echo Silence is golden.
|
||||
status=0
|
||||
exit
|
||||
@@ -0,0 +1,2 @@
|
||||
QA output created by 514
|
||||
Silence is golden.
|
||||
Executable
+68
@@ -0,0 +1,68 @@
|
||||
#! /bin/bash
|
||||
# SPDX-License-Identifier: GPL-2.0
|
||||
# Copyright (c) 2018 Oracle, Inc. All Rights Reserved.
|
||||
#
|
||||
# FS QA Test No. 515
|
||||
#
|
||||
# Ensure that reflinking into a file well beyond EOF zeroes everything between
|
||||
# the old EOF and the start of the newly linked chunk. This is an adaptation
|
||||
# of a reproducer script that Eric Sandeen formulated from a stale data
|
||||
# exposure bug uncovered by shared/010.
|
||||
#
|
||||
seq=`basename $0`
|
||||
seqres=$RESULT_DIR/$seq
|
||||
echo "QA output created by $seq"
|
||||
tmp=/tmp/$$
|
||||
status=1 # failure is the default!
|
||||
trap "_cleanup; exit \$status" 0 1 2 3 15
|
||||
|
||||
_cleanup()
|
||||
{
|
||||
cd /
|
||||
rm -f $tmp.*
|
||||
}
|
||||
|
||||
# get standard environment, filters and checks
|
||||
. ./common/rc
|
||||
. ./common/filter
|
||||
. ./common/reflink
|
||||
|
||||
# real QA test starts here
|
||||
_supported_fs generic
|
||||
_supported_os Linux
|
||||
_require_scratch_reflink
|
||||
|
||||
rm -f $seqres.full
|
||||
|
||||
# Fill disk with a well known pattern so that stale data exposure becomes much
|
||||
# more obvious.
|
||||
$XFS_IO_PROG -c "pwrite -S 0x58 -b 1m 0 300m" $SCRATCH_DEV >> $seqres.full
|
||||
_scratch_mkfs_sized $((300 * 1048576)) >>$seqres.full 2>&1
|
||||
_scratch_mount
|
||||
|
||||
DONOR1=$SCRATCH_MNT/a
|
||||
TARGET=$SCRATCH_MNT/b
|
||||
blksz=65536
|
||||
|
||||
$XFS_IO_PROG -f -c "pwrite -S 0x72 0 $blksz" $DONOR1 >> $seqres.full
|
||||
|
||||
$XFS_IO_PROG -f \
|
||||
-c "falloc -k $((blksz*2)) $blksz" \
|
||||
-c "pwrite -S 0x57 $((blksz*16)) 8192" \
|
||||
-c "fdatasync" \
|
||||
-c 'stat' \
|
||||
-c "reflink $DONOR1 0 $((blksz*17)) $blksz" \
|
||||
$TARGET >> $seqres.full
|
||||
|
||||
od -tx1 -Ad -c $TARGET >> $seqres.full
|
||||
md5sum $DONOR1 | _filter_scratch
|
||||
md5sum $TARGET | _filter_scratch
|
||||
|
||||
_scratch_cycle_mount
|
||||
|
||||
od -tx1 -Ad -c $TARGET >> $seqres.full
|
||||
md5sum $DONOR1 | _filter_scratch
|
||||
md5sum $TARGET | _filter_scratch
|
||||
|
||||
status=0
|
||||
exit
|
||||
@@ -0,0 +1,5 @@
|
||||
QA output created by 515
|
||||
34a4daf52c562253a2f6108c5123605a SCRATCH_MNT/a
|
||||
4fe4dfe3d2244bd380adcefdc5006e37 SCRATCH_MNT/b
|
||||
34a4daf52c562253a2f6108c5123605a SCRATCH_MNT/a
|
||||
4fe4dfe3d2244bd380adcefdc5006e37 SCRATCH_MNT/b
|
||||
Executable
+81
@@ -0,0 +1,81 @@
|
||||
#! /bin/bash
|
||||
# SPDX-License-Identifier: GPL-2.0
|
||||
# Copyright (c) 2018, Oracle and/or its affiliates. All Rights Reserved.
|
||||
#
|
||||
# FS QA Test No. 516
|
||||
#
|
||||
# Ensuring that we cannot dedupe non-matching parts of files:
|
||||
# - Fail to dedupe non-identical parts of two different files
|
||||
# - Check that nothing changes in either file
|
||||
#
|
||||
seq=`basename $0`
|
||||
seqres=$RESULT_DIR/$seq
|
||||
echo "QA output created by $seq"
|
||||
|
||||
here=`pwd`
|
||||
tmp=/tmp/$$
|
||||
status=1 # failure is the default!
|
||||
trap "_cleanup; exit \$status" 0 1 2 3 15
|
||||
|
||||
_cleanup()
|
||||
{
|
||||
cd /
|
||||
rm -rf $tmp.* $testdir
|
||||
}
|
||||
|
||||
# get standard environment, filters and checks
|
||||
. ./common/rc
|
||||
. ./common/filter
|
||||
. ./common/reflink
|
||||
|
||||
# real QA test starts here
|
||||
_supported_os Linux
|
||||
_require_test_dedupe
|
||||
|
||||
rm -f $seqres.full
|
||||
|
||||
testdir=$TEST_DIR/test-$seq
|
||||
rm -rf $testdir
|
||||
mkdir $testdir
|
||||
|
||||
echo "Create the original files"
|
||||
blksz=65536
|
||||
_pwrite_byte 0x61 $((blksz * 2)) $((blksz * 6)) $testdir/file1 >> $seqres.full
|
||||
_pwrite_byte 0x61 $((blksz * 2)) $((blksz * 6)) $testdir/file2 >> $seqres.full
|
||||
_pwrite_byte 0x62 $(((blksz * 6) - 33)) 1 $testdir/file2 >> $seqres.full
|
||||
_test_cycle_mount
|
||||
|
||||
md5sum $testdir/file1 | _filter_test_dir
|
||||
md5sum $testdir/file2 | _filter_test_dir
|
||||
|
||||
_compare_range $testdir/file1 0 $testdir/file2 0 "$((blksz * 8))" \
|
||||
|| echo "Files 1-2 do not match (intentional)"
|
||||
|
||||
echo "(partial) dedupe the middle blocks together"
|
||||
free_before=$(stat -f -c '%a' $testdir)
|
||||
_dedupe_range $testdir/file1 $((blksz * 4)) $testdir/file2 \
|
||||
$((blksz * 4)) $((blksz * 2)) 2>&1 | _filter_xfs_io_numbers | _filter_dedupe_error
|
||||
_test_cycle_mount
|
||||
${FILEFRAG_PROG} -v $testdir/file1 >> $seqres.full
|
||||
${FILEFRAG_PROG} -v $testdir/file2 >> $seqres.full
|
||||
free_after=$(stat -f -c '%a' $testdir)
|
||||
echo "freesp changed by $free_before -> $free_after" >> $seqres.full
|
||||
|
||||
echo "Compare sections"
|
||||
md5sum $testdir/file1 | _filter_test_dir
|
||||
md5sum $testdir/file2 | _filter_test_dir
|
||||
|
||||
_compare_range $testdir/file1 0 $testdir/file2 0 $((blksz * 4)) \
|
||||
|| echo "Start sections do not match (error)"
|
||||
|
||||
_compare_range $testdir/file1 $((blksz * 4)) $testdir/file2 \
|
||||
$((blksz * 4)) $((blksz * 2)) \
|
||||
|| echo "Middle sections do not match (intentional)"
|
||||
|
||||
_compare_range $testdir/file1 $((blksz * 6)) $testdir/file2 \
|
||||
$((blksz * 6)) $((blksz * 2)) \
|
||||
|| echo "End sections do not match (error)"
|
||||
|
||||
# success, all done
|
||||
status=0
|
||||
exit
|
||||
@@ -0,0 +1,11 @@
|
||||
QA output created by 516
|
||||
Create the original files
|
||||
35ac8d7917305c385c30f3d82c30a8f6 TEST_DIR/test-516/file1
|
||||
39578c21e2cb9f6049b1cf7fc7be12a6 TEST_DIR/test-516/file2
|
||||
Files 1-2 do not match (intentional)
|
||||
(partial) dedupe the middle blocks together
|
||||
XFS_IOC_FILE_EXTENT_SAME: Extents did not match.
|
||||
Compare sections
|
||||
35ac8d7917305c385c30f3d82c30a8f6 TEST_DIR/test-516/file1
|
||||
39578c21e2cb9f6049b1cf7fc7be12a6 TEST_DIR/test-516/file2
|
||||
Middle sections do not match (intentional)
|
||||
@@ -515,3 +515,7 @@
|
||||
510 auto quick log
|
||||
511 auto quick rw zero
|
||||
512 auto quick log prealloc
|
||||
513 auto quick clone
|
||||
514 auto quick clone
|
||||
515 auto quick clone
|
||||
516 auto quick dedupe clone
|
||||
|
||||
Reference in New Issue
Block a user