From: Koen De Wit Date: Fri, 24 Jan 2014 01:06:31 +0000 (+1100) Subject: xfstests: btrfs: cross-subvolume sparse copy X-Git-Tag: v2022.05.01~3271 X-Git-Url: http://git.apps.os.sepia.ceph.com/?p=xfstests-dev.git;a=commitdiff_plain;h=0c58766aacb11d7c9534d1edbe3913170eed0862 xfstests: btrfs: cross-subvolume sparse copy This testscript creates reflinks to files on different subvolumes, overwrites the original files and reflinks, and moves reflinked files between subvolumes. Signed-off-by: Koen De Wit Reviewed-by: David Sterba Signed-off-by: Dave Chinner --- diff --git a/tests/btrfs/031 b/tests/btrfs/031 new file mode 100644 index 00000000..e158a57d --- /dev/null +++ b/tests/btrfs/031 @@ -0,0 +1,138 @@ +#! /bin/bash +# FS QA Test No. 031 +# +# Testing cross-subvolume sparse copy on btrfs +# - Create two subvolumes, mount one of them +# - Create a file on each (sub/root)volume, +# reflink them on the other volumes +# - Change one original and two reflinked files +# - Move reflinked files between subvolumes +# +#----------------------------------------------------------------------- +# Copyright (c) 2014, Oracle and/or its affiliates. All Rights Reserved. +# +# This program is free software; you can redistribute it and/or +# modify it under the terms of the GNU General Public License as +# published by the Free Software Foundation. +# +# This program is distributed in the hope that it would be useful, +# but WITHOUT ANY WARRANTY; without even the implied warranty of +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the +# GNU General Public License for more details. +# +# You should have received a copy of the GNU General Public License +# along with this program; if not, write the Free Software Foundation, +# Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA +#----------------------------------------------------------------------- + +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() +{ + umount $SCRATCH_MNT + rm -rf $TESTDIR1 + rm -rf $TESTDIR2 + $BTRFS_UTIL_PROG subvolume delete $SUBVOL1 >> $seqres.full + $BTRFS_UTIL_PROG subvolume delete $SUBVOL2 >> $seqres.full + cd / + rm -f $tmp.* +} + +# get standard environment, filters and checks +. ./common/rc +. ./common/filter + +# real QA test starts here +_supported_fs btrfs +_supported_os Linux + +_require_scratch +_require_cp_reflink + +_checksum_files() { + for F in file1 file2 file3 + do + echo "$F:" + for D in $TESTDIR1 $SCRATCH_MNT $SUBVOL2 + do + _md5_checksum $D/$F + done + done +} + +TESTDIR1=$TEST_DIR/test-$seq-1 +TESTDIR2=$TEST_DIR/test-$seq-2 +SUBVOL1=$TEST_DIR/subvol-$seq-1 +SUBVOL2=$TEST_DIR/subvol-$seq-2 + +_scratch_unmount 2>/dev/null +rm -rf $seqres.full +rm -rf $TESTDIR1 $TESTDIR2 +$BTRFS_UTIL_PROG subvolume delete $SUBVOL1 >/dev/null 2>&1 +$BTRFS_UTIL_PROG subvolume delete $SUBVOL2 >/dev/null 2>&1 + +mkdir $TESTDIR1 +mkdir $TESTDIR2 +$BTRFS_UTIL_PROG subvolume create $SUBVOL1 >> $seqres.full +$BTRFS_UTIL_PROG subvolume create $SUBVOL2 >> $seqres.full +_mount -t btrfs -o subvol=subvol-$seq-1 $TEST_DEV $SCRATCH_MNT + +echo "Create initial files" +# TESTDIR1/file1 is very small and will be inlined +$XFS_IO_PROG -f -c 'pwrite -S 0x61 0 10' $TESTDIR1/file1 \ + >> $seqres.full +$XFS_IO_PROG -f -c 'pwrite -S 0x62 0 13000' $SCRATCH_MNT/file2 \ + >> $seqres.full +$XFS_IO_PROG -f -c 'pwrite -S 0x63 0 17000' $SUBVOL2/file3 \ + >> $seqres.full + +echo "Create reflinks to the initial files on other subvolumes" +cp --reflink=always $TESTDIR1/file1 $SUBVOL1 +cp --reflink=always $TESTDIR1/file1 $SUBVOL2 +cp --reflink=always $SUBVOL1/file2 $TESTDIR1/ +cp --reflink=always $SUBVOL1/file2 $SUBVOL2 +cp --reflink=always $SUBVOL2/file3 $TESTDIR1/ +cp --reflink=always $SUBVOL2/file3 $SUBVOL1 + +echo "Verify the reflinks" +_verify_reflink $SCRATCH_MNT/file2 $TESTDIR1/file2 +_verify_reflink $SCRATCH_MNT/file2 $SUBVOL2/file2 +_verify_reflink $SUBVOL2/file3 $TESTDIR1/file3 +_verify_reflink $SUBVOL2/file3 $SCRATCH_MNT/file3 +echo "Verify the file contents:" +_checksum_files + +echo -e "---\nOverwrite some files with new content" +$XFS_IO_PROG -c 'pwrite -S 0x64 0 20' $TESTDIR1/file1 >> $seqres.full +$XFS_IO_PROG -c 'pwrite -S 0x66 0 21000' $SUBVOL2/file2 >> $seqres.full +$XFS_IO_PROG -c 'pwrite -S 0x65 5000 5000' $SCRATCH_MNT/file3 \ + >> $seqres.full + +echo -n "Verify that non-overwritten reflinks " +echo "still have the same data blocks" +_verify_reflink $TESTDIR1/file2 $SCRATCH_MNT/file2 +_verify_reflink $TESTDIR1/file3 $SUBVOL2/file3 +echo "Verify the file contents:" +_checksum_files + +echo -e "---\nShuffle files between directories" +mv $TESTDIR1/file* $TESTDIR2 +mv $SCRATCH_MNT/file* $TESTDIR1/ +mv $SUBVOL2/file* $SCRATCH_MNT/ +mv $TESTDIR2/file* $SUBVOL2/ + +# No _verify_reflink here as data is copied when moving files +# between subvols +echo "Verify the file contents:" +_checksum_files + +# success, all done +status=0 +exit diff --git a/tests/btrfs/031.out b/tests/btrfs/031.out new file mode 100644 index 00000000..f6d66f69 --- /dev/null +++ b/tests/btrfs/031.out @@ -0,0 +1,48 @@ +QA output created by 031 +Create initial files +Create reflinks to the initial files on other subvolumes +Verify the reflinks +Verify the file contents: +file1: +e09c80c42fda55f9d992e59ca6b3307d +e09c80c42fda55f9d992e59ca6b3307d +e09c80c42fda55f9d992e59ca6b3307d +file2: +d7402b46310fbbfbc5e466b1dccb043b +d7402b46310fbbfbc5e466b1dccb043b +d7402b46310fbbfbc5e466b1dccb043b +file3: +5a95800e4c04b11117aa4e4de057721f +5a95800e4c04b11117aa4e4de057721f +5a95800e4c04b11117aa4e4de057721f +--- +Overwrite some files with new content +Verify that non-overwritten reflinks still have the same data blocks +Verify the file contents: +file1: +00d620f69f30327f0f8946b95c12de44 +e09c80c42fda55f9d992e59ca6b3307d +e09c80c42fda55f9d992e59ca6b3307d +file2: +d7402b46310fbbfbc5e466b1dccb043b +d7402b46310fbbfbc5e466b1dccb043b +917619ae44b38bb9968af261c3c45440 +file3: +5a95800e4c04b11117aa4e4de057721f +b9f275cd638cb784c9e61def94c622a8 +5a95800e4c04b11117aa4e4de057721f +--- +Shuffle files between directories +Verify the file contents: +file1: +e09c80c42fda55f9d992e59ca6b3307d +e09c80c42fda55f9d992e59ca6b3307d +00d620f69f30327f0f8946b95c12de44 +file2: +d7402b46310fbbfbc5e466b1dccb043b +917619ae44b38bb9968af261c3c45440 +d7402b46310fbbfbc5e466b1dccb043b +file3: +b9f275cd638cb784c9e61def94c622a8 +5a95800e4c04b11117aa4e4de057721f +5a95800e4c04b11117aa4e4de057721f diff --git a/tests/btrfs/group b/tests/btrfs/group index 3f61799e..2e2b8e12 100644 --- a/tests/btrfs/group +++ b/tests/btrfs/group @@ -33,3 +33,4 @@ 028 auto quick 029 auto quick 030 auto quick +031 auto quick