generic: add test for fsync after cloning file range

Test that if we do a buffered write to a file, fsync it, clone a
range from another file into our file that overlaps the previously
written range, fsync the file again and then power fail, after we
mount again the filesystem, no file data was lost or corrupted.

This test is motivated by a bug found in btrfs, which is fixed by a
patch for the linux kernel titled:

  "Btrfs: fix file data corruption after cloning a range and fsync"

Signed-off-by: Filipe Manana <fdmanana@suse.com>
Reviewed-by: Eryu Guan <guaneryu@gmail.com>
Signed-off-by: Eryu Guan <guaneryu@gmail.com>
This commit is contained in:
Filipe Manana
2018-07-12 01:38:11 +01:00
committed by Eryu Guan
parent 76b5a9d535
commit fcc3f3b9c3
3 changed files with 76 additions and 0 deletions
+70
View File
@@ -0,0 +1,70 @@
#! /bin/bash
# SPDX-License-Identifier: GPL-2.0
# Copyright (C) 2018 SUSE Linux Products GmbH. All Rights Reserved.
#
# FS QA Test No. 501
#
# Test that if we do a buffered write to a file, fsync it, clone a range from
# another file into our file that overlaps the previously written range, fsync
# the file again and then power fail, after we mount again the filesystem, no
# file data was lost or corrupted.
#
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()
{
_cleanup_flakey
cd /
rm -f $tmp.*
}
# get standard environment, filters and checks
. ./common/rc
. ./common/filter
. ./common/reflink
. ./common/dmflakey
# real QA test starts here
_supported_fs generic
_supported_os Linux
_require_scratch_reflink
_require_dm_target flakey
rm -f $seqres.full
_scratch_mkfs >>$seqres.full 2>&1
_require_metadata_journaling $SCRATCH_DEV
_init_flakey
_mount_flakey
$XFS_IO_PROG -f -c "pwrite -S 0x18 9000K 6908K" $SCRATCH_MNT/foo >>$seqres.full
$XFS_IO_PROG -f -c "pwrite -S 0x20 2572K 156K" $SCRATCH_MNT/bar >>$seqres.full
# We clone from file foo into a range of file bar that overlaps the existing
# extent at file bar. The destination offset of the reflink operation matches
# the eof position of file bar minus 4Kb.
$XFS_IO_PROG -c "fsync" \
-c "reflink ${SCRATCH_MNT}/foo 0 2724K 15908K" \
-c "fsync" \
$SCRATCH_MNT/bar >>$seqres.full
echo "File bar digest before power failure:"
md5sum $SCRATCH_MNT/bar | _filter_scratch
# Simulate a power failure and mount the filesystem to check that no file data
# was lost or corrupted.
_flakey_drop_and_remount
echo "File bar digest after power failure:"
md5sum $SCRATCH_MNT/bar | _filter_scratch
_unmount_flakey
_cleanup_flakey
status=0
exit
+5
View File
@@ -0,0 +1,5 @@
QA output created by 501
File bar digest before power failure:
95a95813a8c2abc9aa75a6c2914a077e SCRATCH_MNT/bar
File bar digest after power failure:
95a95813a8c2abc9aa75a6c2914a077e SCRATCH_MNT/bar
+1
View File
@@ -503,3 +503,4 @@
498 auto quick log
499 auto quick rw collapse zero
500 auto thin trim
501 auto quick clone log