From: "Darrick J. Wong" <djwong@kernel.org>
To: Zorro Lang <zlang@redhat.com>
Cc: linux-xfs@vger.kernel.org, fstests@vger.kernel.org
Subject: Re: [PATCH 05/10] common: refactor metadump v1 and v2 tests
Date: Fri, 2 Feb 2024 08:47:08 -0800 [thread overview]
Message-ID: <20240202164708.GL616564@frogsfrogsfrogs> (raw)
In-Reply-To: <20240201062922.n6wbf77jctbiopq4@dell-per750-06-vm-08.rhts.eng.pek2.redhat.com>
On Thu, Feb 01, 2024 at 02:29:22PM +0800, Zorro Lang wrote:
> On Wed, Jan 31, 2024 at 11:24:33AM -0800, Darrick J. Wong wrote:
> > On Wed, Jan 31, 2024 at 10:09:19PM +0800, Zorro Lang wrote:
> > > On Mon, Jan 29, 2024 at 05:32:07PM -0800, Darrick J. Wong wrote:
> > > > On Sun, Jan 28, 2024 at 09:23:04PM +0800, Zorro Lang wrote:
> > > > > On Sat, Jan 27, 2024 at 09:22:22AM -0800, Darrick J. Wong wrote:
> > > > > > On Sat, Jan 27, 2024 at 04:47:14PM +0800, Zorro Lang wrote:
> > > > > > > On Thu, Jan 25, 2024 at 11:05:16AM -0800, Darrick J. Wong wrote:
> > > > > > > > From: Darrick J. Wong <djwong@kernel.org>
> > > > > > > >
> > > > > > > > Refactor the copy-pasta'd code in xfs/129, xfs/234, xfs/253, xfs/291,
> > > > > > > > xfs/432, xfs/503, and xfs/605 so that we don't have to maintain nearly
> > > > > > > > duplicate copies of the same code.
> > > > > > > >
> > > > > > > > While we're at it, fix the fsck so that it includes xfs_scrub.
> > > > > > > >
> > > > > > > > Signed-off-by: Darrick J. Wong <djwong@kernel.org>
> > > > > > > > ---
> > > > > > > > common/rc | 10 ----
> > > > > > > > common/xfs | 14 +++++
> > > > > > > > common/xfs_metadump_tests | 123 +++++++++++++++++++++++++++++++++++++++++++++
> > > > > > > > tests/xfs/129 | 90 ++-------------------------------
> > > > > > > > tests/xfs/234 | 91 ++-------------------------------
> > > > > > > > tests/xfs/253 | 89 ++-------------------------------
> > > > > > > > tests/xfs/291 | 31 ++++-------
> > > > > > > > tests/xfs/432 | 30 ++---------
> > > > > > > > tests/xfs/503 | 60 +++-------------------
> > > > > > > > tests/xfs/605 | 84 ++-----------------------------
> > > > > > > > 10 files changed, 181 insertions(+), 441 deletions(-)
> > > > > > > > create mode 100644 common/xfs_metadump_tests
> > > > > > > >
> > > > > > > >
> > > > > > > > diff --git a/common/rc b/common/rc
> > > > > > > > index 524ffa02aa..0b69f7f54f 100644
> > > > > > > > --- a/common/rc
> > > > > > > > +++ b/common/rc
> > > > > > > > @@ -3320,15 +3320,7 @@ _check_scratch_fs()
> > > > > > > >
> > > > > > > > case $FSTYP in
> > > > > > > > xfs)
> > > > > > > > - local scratch_log="none"
> > > > > > > > - local scratch_rt="none"
> > > > > > > > - [ "$USE_EXTERNAL" = yes -a ! -z "$SCRATCH_LOGDEV" ] && \
> > > > > > > > - scratch_log="$SCRATCH_LOGDEV"
> > > > > > > > -
> > > > > > > > - [ "$USE_EXTERNAL" = yes -a ! -z "$SCRATCH_RTDEV" ] && \
> > > > > > > > - scratch_rt="$SCRATCH_RTDEV"
> > > > > > > > -
> > > > > > > > - _check_xfs_filesystem $device $scratch_log $scratch_rt
> > > > > > > > + _check_xfs_scratch_fs $device
> > > > > > > > ;;
> > > > > > > > udf)
> > > > > > > > _check_udf_filesystem $device $udf_fsize
> > > > > > > > diff --git a/common/xfs b/common/xfs
> > > > > > > > index 248ccefda3..6a48960a7f 100644
> > > > > > > > --- a/common/xfs
> > > > > > > > +++ b/common/xfs
> > > > > > > > @@ -1035,6 +1035,20 @@ _check_xfs_test_fs()
> > > > > > > > return $?
> > > > > > > > }
> > > > > > > >
> > > > > > > > +_check_xfs_scratch_fs()
> > > > > > > > +{
> > > > > > > > + local device="${1:-$SCRATCH_DEV}"
> > > > > > > > + local scratch_log="none"
> > > > > > > > + local scratch_rt="none"
> > > > > > > > + [ "$USE_EXTERNAL" = yes -a ! -z "$SCRATCH_LOGDEV" ] && \
> > > > > > > > + scratch_log="$SCRATCH_LOGDEV"
> > > > > > > > +
> > > > > > > > + [ "$USE_EXTERNAL" = yes -a ! -z "$SCRATCH_RTDEV" ] && \
> > > > > > > > + scratch_rt="$SCRATCH_RTDEV"
> > > > > > > > +
> > > > > > > > + _check_xfs_filesystem $device $scratch_log $scratch_rt
> > > > > > > > +}
> > > > > > > > +
> > > > > > > > # modeled after _scratch_xfs_repair
> > > > > > > > _test_xfs_repair()
> > > > > > > > {
> > > > > > > > diff --git a/common/xfs_metadump_tests b/common/xfs_metadump_tests
> > > > > > >
> > > > > > > Hi Darrick,
> > > > > > >
> > > > > > > Thanks for this improvement.
> > > > > > >
> > > > > > > I'm wondering do we need a separated common file only for xfs metadump
> > > > > > > helpers ? Can't they be in common/xfs ? There're already _xfs_metadump(),
> > > > > > > _xfs_mdrestore(), _scratch_xfs_metadump(), _scratch_xfs_mdrestore() etc
> > > > > > > in common/xfs.
> > > > > >
> > > > > > Yes, that's certainly possible, but keep in mind that common/$FSTYP
> > > > > > files are getting big:
> > > > > >
> > > > > > 509 fstests/common/overlay
> > > > > > 523 fstests/common/quota
> > > > > > 550 fstests/common/reflink
> > > > > > 638 fstests/common/log
> > > > > > 640 fstests/common/punch
> > > > > > 663 fstests/common/filter
> > > > > > 794 fstests/common/btrfs
> > > > > > 936 fstests/common/config
> > > > > > 1030 fstests/common/encrypt
> > > > > > 1162 fstests/common/populate
> > > > > > 1519 fstests/common/fuzzy
> > > > > > 1531 fstests/common/dump
> > > > > > 2218 fstests/common/xfs
> > > > > > 5437 fstests/common/rc
> > > > > >
> > > > > > with common/xfs being particularly larger than most everything else.
> > > > >
> > > > > Haha, maybe we'll have a common/xfs/ directory in one day :)
> > > > >
> > > > > >
> > > > > > Since the common/xfs_metadump_tests functions are shared helper
> > > > > > functions for testing metadump/mdrestore that are not use by most tests,
> > > > > > I decided that a split was appropriate both to maintain the (ha!)
> > > > > > cohesion of common/xfs and not add more bash parsing costs to every
> > > > > > single testcase.
> > > > >
> > > > > OK, a split makes sense, but I have 3 questions:
> > > > > 1) Will you move all metadump helpers from common/xfs to this new file?
> > > >
> > > > I don't really want to, because that's another patch and would require
> > > > careful auditing of all the tests to find the ones that want to use
> > > > metadump but aren't themselves functional tests of metadump.
> > > >
> > > > IOWs, this new file really is for shared metadump functional testing and
> > > > not much else.
> > >
> > > OK, I think we can care about this part step by step in the future.
> >
> > <nod>
> >
> > > >
> > > > > 2) Can we call it common/metadump? (Not sure if any other fs has metadump
> > > > > things:)
> > > >
> > > > Yes, e2image does this for ext*.
> > >
> > > OK, I'll rename this file to common/metadump, and change other patches to
> > > souce the new name when I merge this patchset. Is that good to you?
> >
> > Sorry, I realized that my statement was ambiguous -- the "yes" applies
> > to "Not sure if any other fs has metadump things", not "Can we call it
> > common/metadump?". The code in common/xfs_metadump_tests is specific to
> > xfs and is not used for e2image testing, so let's leave the name as-is.
>
> Oh, maybe it can be used for e2image or other metadump helpers later, if
> we call it common/metadump?
Sounds ok to me. Want me to respin?
--D
> >
> > --D
> >
> > > Thanks,
> > > Zorro
> > >
> > > >
> > > > > 3) Or move to common/dump directly? (looks not proper ;-)
> > > >
> > > > dump != metadump; one is for all the files in the fs and none of the
> > > > non-file metadata; the other is for metadata and none of the files.
> > > >
> > > > --D
> > > >
> > > > > Thanks,
> > > > > Zorro
> > > > >
> > > > > >
> > > > > > --D
> > > > > >
> > > > > > > Thanks,
> > > > > > > Zorro
> > > > > > >
> > > > > > > > new file mode 100644
> > > > > > > > index 0000000000..dd3dec1fb4
> > > > > > > > --- /dev/null
> > > > > > > > +++ b/common/xfs_metadump_tests
> > > > > > > > @@ -0,0 +1,123 @@
> > > > > > > > +#
> > > > > > > > +# XFS specific metadump testing functions.
> > > > > > > > +#
> > > > > > > > +
> > > > > > > > +# Set up environment variables for a metadump test. Requires the test and
> > > > > > > > +# scratch devices. Sets XFS_METADUMP_{FILE,IMG} and MAX_XFS_METADUMP_VERSION.
> > > > > > > > +_setup_verify_metadump()
> > > > > > > > +{
> > > > > > > > + XFS_METADUMP_FILE="$TEST_DIR/${seq}_metadump"
> > > > > > > > + XFS_METADUMP_IMG="$TEST_DIR/${seq}_image"
> > > > > > > > + MAX_XFS_METADUMP_VERSION="$(_xfs_metadump_max_version)"
> > > > > > > > +
> > > > > > > > + rm -f "$XFS_METADUMP_FILE" "$XFS_METADUMP_IMG"*
> > > > > > > > +}
> > > > > > > > +
> > > > > > > > +_cleanup_verify_metadump()
> > > > > > > > +{
> > > > > > > > + _scratch_unmount &>> $seqres.full
> > > > > > > > +
> > > > > > > > + losetup -n -a -O BACK-FILE,NAME | grep "^$XFS_METADUMP_IMG" | while read backing ldev; do
> > > > > > > > + losetup -d "$ldev"
> > > > > > > > + done
> > > > > > > > + rm -f "$XFS_METADUMP_FILE" "$XFS_METADUMP_IMG"*
> > > > > > > > +}
> > > > > > > > +
> > > > > > > > +# Create a metadump in v1 format, restore it to fs image files, then mount the
> > > > > > > > +# images and fsck them.
> > > > > > > > +_verify_metadump_v1()
> > > > > > > > +{
> > > > > > > > + local metadump_args="$1"
> > > > > > > > + local extra_test="$2"
> > > > > > > > +
> > > > > > > > + local metadump_file="$XFS_METADUMP_FILE"
> > > > > > > > + local version=""
> > > > > > > > + local data_img="$XFS_METADUMP_IMG.data"
> > > > > > > > + local data_loop
> > > > > > > > +
> > > > > > > > + # Force v1 if we detect v2 support
> > > > > > > > + if [[ $MAX_XFS_METADUMP_FORMAT > 1 ]]; then
> > > > > > > > + version="-v 1"
> > > > > > > > + fi
> > > > > > > > +
> > > > > > > > + # Capture metadump, which creates metadump_file
> > > > > > > > + _scratch_xfs_metadump $metadump_file $metadump_args $version
> > > > > > > > +
> > > > > > > > + # Restore metadump, which creates data_img
> > > > > > > > + SCRATCH_DEV=$data_img _scratch_xfs_mdrestore $metadump_file
> > > > > > > > +
> > > > > > > > + # Create loopdev for data device so we can mount the fs
> > > > > > > > + data_loop=$(_create_loop_device $data_img)
> > > > > > > > +
> > > > > > > > + # Mount fs, run an extra test, fsck, and unmount
> > > > > > > > + SCRATCH_DEV=$data_loop _scratch_mount
> > > > > > > > + if [ -n "$extra_test" ]; then
> > > > > > > > + SCRATCH_DEV=$data_loop $extra_test
> > > > > > > > + fi
> > > > > > > > + SCRATCH_DEV=$data_loop _check_xfs_scratch_fs
> > > > > > > > + SCRATCH_DEV=$data_loop _scratch_unmount
> > > > > > > > +
> > > > > > > > + # Tear down what we created
> > > > > > > > + _destroy_loop_device $data_loop
> > > > > > > > + rm -f $data_img
> > > > > > > > +}
> > > > > > > > +
> > > > > > > > +# Create a metadump in v2 format, restore it to fs image files, then mount the
> > > > > > > > +# images and fsck them.
> > > > > > > > +_verify_metadump_v2()
> > > > > > > > +{
> > > > > > > > + local metadump_args="$1"
> > > > > > > > + local extra_test="$2"
> > > > > > > > +
> > > > > > > > + local metadump_file="$XFS_METADUMP_FILE"
> > > > > > > > + local version="-v 2"
> > > > > > > > + local data_img="$XFS_METADUMP_IMG.data"
> > > > > > > > + local data_loop
> > > > > > > > + local log_img=""
> > > > > > > > + local log_loop
> > > > > > > > +
> > > > > > > > + # Capture metadump, which creates metadump_file
> > > > > > > > + _scratch_xfs_metadump $metadump_file $metadump_args $version
> > > > > > > > +
> > > > > > > > + #
> > > > > > > > + # Metadump v2 files can contain contents dumped from an external log
> > > > > > > > + # device. Use a temporary file to hold the log device contents restored
> > > > > > > > + # from such a metadump file.
> > > > > > > > + test -n "$SCRATCH_LOGDEV" && log_img="$XFS_METADUMP_IMG.log"
> > > > > > > > +
> > > > > > > > + # Restore metadump, which creates data_img and log_img
> > > > > > > > + SCRATCH_DEV=$data_img SCRATCH_LOGDEV=$log_img \
> > > > > > > > + _scratch_xfs_mdrestore $metadump_file
> > > > > > > > +
> > > > > > > > + # Create loopdev for data device so we can mount the fs
> > > > > > > > + data_loop=$(_create_loop_device $data_img)
> > > > > > > > +
> > > > > > > > + # Create loopdev for log device if we recovered anything
> > > > > > > > + test -s "$log_img" && log_loop=$(_create_loop_device $log_img)
> > > > > > > > +
> > > > > > > > + # Mount fs, run an extra test, fsck, and unmount
> > > > > > > > + SCRATCH_DEV=$data_loop SCRATCH_LOGDEV=$log_loop _scratch_mount
> > > > > > > > + if [ -n "$extra_test" ]; then
> > > > > > > > + SCRATCH_DEV=$data_loop SCRATCH_LOGDEV=$log_loop $extra_test
> > > > > > > > + fi
> > > > > > > > + SCRATCH_DEV=$data_loop SCRATCH_LOGDEV=$log_loop _check_xfs_scratch_fs
> > > > > > > > + SCRATCH_DEV=$data_loop _scratch_unmount
> > > > > > > > +
> > > > > > > > + # Tear down what we created
> > > > > > > > + if [ -b "$log_loop" ]; then
> > > > > > > > + _destroy_loop_device $log_loop
> > > > > > > > + rm -f $log_img
> > > > > > > > + fi
> > > > > > > > + _destroy_loop_device $data_loop
> > > > > > > > + rm -f $data_img
> > > > > > > > +}
> > > > > > > > +
> > > > > > > > +# Verify both metadump formats if possible
> > > > > > > > +_verify_metadumps()
> > > > > > > > +{
> > > > > > > > + _verify_metadump_v1 "$@"
> > > > > > > > +
> > > > > > > > + if [[ $MAX_XFS_METADUMP_FORMAT == 2 ]]; then
> > > > > > > > + _verify_metadump_v2 "$@"
> > > > > > > > + fi
> > > > > > > > +}
> > > > > > > > diff --git a/tests/xfs/129 b/tests/xfs/129
> > > > > > > > index cdac2349df..c3a9bcefee 100755
> > > > > > > > --- a/tests/xfs/129
> > > > > > > > +++ b/tests/xfs/129
> > > > > > > > @@ -16,98 +16,23 @@ _cleanup()
> > > > > > > > {
> > > > > > > > cd /
> > > > > > > > _scratch_unmount > /dev/null 2>&1
> > > > > > > > - [[ -n $logdev && $logdev != "none" && $logdev != $SCRATCH_LOGDEV ]] && \
> > > > > > > > - _destroy_loop_device $logdev
> > > > > > > > - [[ -n $datadev ]] && _destroy_loop_device $datadev
> > > > > > > > - rm -rf $tmp.* $testdir $metadump_file $TEST_DIR/data-image \
> > > > > > > > - $TEST_DIR/log-image
> > > > > > > > + _cleanup_verify_metadump
> > > > > > > > + rm -rf $tmp.* $testdir
> > > > > > > > }
> > > > > > > >
> > > > > > > > # Import common functions.
> > > > > > > > . ./common/filter
> > > > > > > > . ./common/reflink
> > > > > > > > +. ./common/xfs_metadump_tests
> > > > > > > >
> > > > > > > > # real QA test starts here
> > > > > > > > _supported_fs xfs
> > > > > > > > _require_command "$XFS_MDRESTORE_PROG" "xfs_mdrestore"
> > > > > > > > _require_loop
> > > > > > > > _require_scratch_reflink
> > > > > > > > -
> > > > > > > > -metadump_file=$TEST_DIR/${seq}_metadump
> > > > > > > > -
> > > > > > > > -verify_metadump_v1()
> > > > > > > > -{
> > > > > > > > - local max_version=$1
> > > > > > > > - local version=""
> > > > > > > > -
> > > > > > > > - if [[ $max_version == 2 ]]; then
> > > > > > > > - version="-v 1"
> > > > > > > > - fi
> > > > > > > > -
> > > > > > > > - _scratch_xfs_metadump $metadump_file $version
> > > > > > > > -
> > > > > > > > - SCRATCH_DEV=$TEST_DIR/data-image SCRATCH_LOGDEV="" \
> > > > > > > > - _scratch_xfs_mdrestore $metadump_file
> > > > > > > > -
> > > > > > > > - datadev=$(_create_loop_device $TEST_DIR/data-image)
> > > > > > > > -
> > > > > > > > - SCRATCH_DEV=$datadev _scratch_mount
> > > > > > > > - SCRATCH_DEV=$datadev _scratch_unmount
> > > > > > > > -
> > > > > > > > - logdev=$SCRATCH_LOGDEV
> > > > > > > > - [[ -z $logdev ]] && logdev=none
> > > > > > > > - _check_xfs_filesystem $datadev $logdev none
> > > > > > > > -
> > > > > > > > - _destroy_loop_device $datadev
> > > > > > > > - datadev=""
> > > > > > > > - rm -f $TEST_DIR/data-image
> > > > > > > > -}
> > > > > > > > -
> > > > > > > > -verify_metadump_v2()
> > > > > > > > -{
> > > > > > > > - version="-v 2"
> > > > > > > > -
> > > > > > > > - _scratch_xfs_metadump $metadump_file $version
> > > > > > > > -
> > > > > > > > - # Metadump v2 files can contain contents dumped from an external log
> > > > > > > > - # device. Use a temporary file to hold the log device contents restored
> > > > > > > > - # from such a metadump file.
> > > > > > > > - slogdev=""
> > > > > > > > - if [[ -n $SCRATCH_LOGDEV ]]; then
> > > > > > > > - slogdev=$TEST_DIR/log-image
> > > > > > > > - fi
> > > > > > > > -
> > > > > > > > - SCRATCH_DEV=$TEST_DIR/data-image SCRATCH_LOGDEV=$slogdev \
> > > > > > > > - _scratch_xfs_mdrestore $metadump_file
> > > > > > > > -
> > > > > > > > - datadev=$(_create_loop_device $TEST_DIR/data-image)
> > > > > > > > -
> > > > > > > > - logdev=${SCRATCH_LOGDEV}
> > > > > > > > - if [[ -s $TEST_DIR/log-image ]]; then
> > > > > > > > - logdev=$(_create_loop_device $TEST_DIR/log-image)
> > > > > > > > - fi
> > > > > > > > -
> > > > > > > > - SCRATCH_DEV=$datadev SCRATCH_LOGDEV=$logdev _scratch_mount
> > > > > > > > - SCRATCH_DEV=$datadev SCRATCH_LOGDEV=$logdev _scratch_unmount
> > > > > > > > -
> > > > > > > > - [[ -z $logdev ]] && logdev=none
> > > > > > > > - _check_xfs_filesystem $datadev $logdev none
> > > > > > > > -
> > > > > > > > - if [[ -s $TEST_DIR/log-image ]]; then
> > > > > > > > - _destroy_loop_device $logdev
> > > > > > > > - logdev=""
> > > > > > > > - rm -f $TEST_DIR/log-image
> > > > > > > > - fi
> > > > > > > > -
> > > > > > > > - _destroy_loop_device $datadev
> > > > > > > > - datadev=""
> > > > > > > > - rm -f $TEST_DIR/data-image
> > > > > > > > -}
> > > > > > > > +_setup_verify_metadump
> > > > > > > >
> > > > > > > > _scratch_mkfs >/dev/null 2>&1
> > > > > > > > -
> > > > > > > > -max_md_version=$(_xfs_metadump_max_version)
> > > > > > > > -
> > > > > > > > _scratch_mount
> > > > > > > >
> > > > > > > > testdir=$SCRATCH_MNT/test-$seq
> > > > > > > > @@ -127,12 +52,7 @@ done
> > > > > > > > _scratch_unmount
> > > > > > > >
> > > > > > > > echo "Create metadump file, restore it and check restored fs"
> > > > > > > > -
> > > > > > > > -verify_metadump_v1 $max_md_version
> > > > > > > > -
> > > > > > > > -if [[ $max_md_version == 2 ]]; then
> > > > > > > > - verify_metadump_v2
> > > > > > > > -fi
> > > > > > > > +_verify_metadumps
> > > > > > > >
> > > > > > > > # success, all done
> > > > > > > > status=0
> > > > > > > > diff --git a/tests/xfs/234 b/tests/xfs/234
> > > > > > > > index f4f8af6d3a..8f808c7507 100755
> > > > > > > > --- a/tests/xfs/234
> > > > > > > > +++ b/tests/xfs/234
> > > > > > > > @@ -15,16 +15,13 @@ _begin_fstest auto quick rmap punch metadump
> > > > > > > > _cleanup()
> > > > > > > > {
> > > > > > > > cd /
> > > > > > > > - _scratch_unmount > /dev/null 2>&1
> > > > > > > > - [[ -n $logdev && $logdev != "none" && $logdev != $SCRATCH_LOGDEV ]] && \
> > > > > > > > - _destroy_loop_device $logdev
> > > > > > > > - [[ -n $datadev ]] && _destroy_loop_device $datadev
> > > > > > > > - rm -rf $tmp.* $testdir $metadump_file $TEST_DIR/image \
> > > > > > > > - $TEST_DIR/log-image
> > > > > > > > + _cleanup_verify_metadump
> > > > > > > > + rm -rf $tmp.* $testdir
> > > > > > > > }
> > > > > > > >
> > > > > > > > # Import common functions.
> > > > > > > > . ./common/filter
> > > > > > > > +. ./common/xfs_metadump_tests
> > > > > > > >
> > > > > > > > # real QA test starts here
> > > > > > > > _supported_fs xfs
> > > > > > > > @@ -32,82 +29,9 @@ _require_command "$XFS_MDRESTORE_PROG" "xfs_mdrestore"
> > > > > > > > _require_loop
> > > > > > > > _require_xfs_scratch_rmapbt
> > > > > > > > _require_xfs_io_command "fpunch"
> > > > > > > > -
> > > > > > > > -metadump_file=$TEST_DIR/${seq}_metadump
> > > > > > > > -
> > > > > > > > -verify_metadump_v1()
> > > > > > > > -{
> > > > > > > > - local max_version=$1
> > > > > > > > - local version=""
> > > > > > > > -
> > > > > > > > - if [[ $max_version == 2 ]]; then
> > > > > > > > - version="-v 1"
> > > > > > > > - fi
> > > > > > > > -
> > > > > > > > - _scratch_xfs_metadump $metadump_file $version
> > > > > > > > -
> > > > > > > > - SCRATCH_DEV=$TEST_DIR/data-image SCRATCH_LOGDEV="" \
> > > > > > > > - _scratch_xfs_mdrestore $metadump_file
> > > > > > > > -
> > > > > > > > - datadev=$(_create_loop_device $TEST_DIR/data-image)
> > > > > > > > -
> > > > > > > > - SCRATCH_DEV=$datadev _scratch_mount
> > > > > > > > - SCRATCH_DEV=$datadev _scratch_unmount
> > > > > > > > -
> > > > > > > > - logdev=$SCRATCH_LOGDEV
> > > > > > > > - [[ -z $logdev ]] && logdev=none
> > > > > > > > - _check_xfs_filesystem $datadev $logdev none
> > > > > > > > -
> > > > > > > > - _destroy_loop_device $datadev
> > > > > > > > - datadev=""
> > > > > > > > - rm -f $TEST_DIR/data-image
> > > > > > > > -}
> > > > > > > > -
> > > > > > > > -verify_metadump_v2()
> > > > > > > > -{
> > > > > > > > - version="-v 2"
> > > > > > > > -
> > > > > > > > - _scratch_xfs_metadump $metadump_file $version
> > > > > > > > -
> > > > > > > > - # Metadump v2 files can contain contents dumped from an external log
> > > > > > > > - # device. Use a temporary file to hold the log device contents restored
> > > > > > > > - # from such a metadump file.
> > > > > > > > - slogdev=""
> > > > > > > > - if [[ -n $SCRATCH_LOGDEV ]]; then
> > > > > > > > - slogdev=$TEST_DIR/log-image
> > > > > > > > - fi
> > > > > > > > -
> > > > > > > > - SCRATCH_DEV=$TEST_DIR/data-image SCRATCH_LOGDEV=$slogdev \
> > > > > > > > - _scratch_xfs_mdrestore $metadump_file
> > > > > > > > -
> > > > > > > > - datadev=$(_create_loop_device $TEST_DIR/data-image)
> > > > > > > > -
> > > > > > > > - logdev=${SCRATCH_LOGDEV}
> > > > > > > > - if [[ -s $TEST_DIR/log-image ]]; then
> > > > > > > > - logdev=$(_create_loop_device $TEST_DIR/log-image)
> > > > > > > > - fi
> > > > > > > > -
> > > > > > > > - SCRATCH_DEV=$datadev SCRATCH_LOGDEV=$logdev _scratch_mount
> > > > > > > > - SCRATCH_DEV=$datadev SCRATCH_LOGDEV=$logdev _scratch_unmount
> > > > > > > > -
> > > > > > > > - [[ -z $logdev ]] && logdev=none
> > > > > > > > - _check_xfs_filesystem $datadev $logdev none
> > > > > > > > -
> > > > > > > > - if [[ -s $TEST_DIR/log-image ]]; then
> > > > > > > > - _destroy_loop_device $logdev
> > > > > > > > - logdev=""
> > > > > > > > - rm -f $TEST_DIR/log-image
> > > > > > > > - fi
> > > > > > > > -
> > > > > > > > - _destroy_loop_device $datadev
> > > > > > > > - datadev=""
> > > > > > > > - rm -f $TEST_DIR/data-image
> > > > > > > > -}
> > > > > > > > +_setup_verify_metadump
> > > > > > > >
> > > > > > > > _scratch_mkfs >/dev/null 2>&1
> > > > > > > > -
> > > > > > > > -max_md_version=$(_xfs_metadump_max_version)
> > > > > > > > -
> > > > > > > > _scratch_mount
> > > > > > > >
> > > > > > > > testdir=$SCRATCH_MNT/test-$seq
> > > > > > > > @@ -127,12 +51,7 @@ done
> > > > > > > > _scratch_unmount
> > > > > > > >
> > > > > > > > echo "Create metadump file, restore it and check restored fs"
> > > > > > > > -
> > > > > > > > -verify_metadump_v1 $max_md_version
> > > > > > > > -
> > > > > > > > -if [[ $max_md_version == 2 ]]; then
> > > > > > > > - verify_metadump_v2
> > > > > > > > -fi
> > > > > > > > +_verify_metadumps
> > > > > > > >
> > > > > > > > # success, all done
> > > > > > > > status=0
> > > > > > > > diff --git a/tests/xfs/253 b/tests/xfs/253
> > > > > > > > index 3b567999d8..6623c435e5 100755
> > > > > > > > --- a/tests/xfs/253
> > > > > > > > +++ b/tests/xfs/253
> > > > > > > > @@ -26,23 +26,21 @@ _cleanup()
> > > > > > > > cd /
> > > > > > > > rm -f $tmp.*
> > > > > > > > rm -rf "${OUTPUT_DIR}"
> > > > > > > > - rm -f "${METADUMP_FILE}"
> > > > > > > > - [[ -n $logdev && $logdev != $SCRATCH_LOGDEV ]] && \
> > > > > > > > - _destroy_loop_device $logdev
> > > > > > > > - [[ -n $datadev ]] && _destroy_loop_device $datadev
> > > > > > > > + _cleanup_verify_metadump
> > > > > > > > }
> > > > > > > >
> > > > > > > > # Import common functions.
> > > > > > > > . ./common/filter
> > > > > > > > +. ./common/xfs_metadump_tests
> > > > > > > >
> > > > > > > > _require_command "$XFS_MDRESTORE_PROG" "xfs_mdrestore"
> > > > > > > > _require_test
> > > > > > > > _require_scratch
> > > > > > > > +_setup_verify_metadump
> > > > > > > >
> > > > > > > > # real QA test starts here
> > > > > > > >
> > > > > > > > OUTPUT_DIR="${SCRATCH_MNT}/test_${seq}"
> > > > > > > > -METADUMP_FILE="${TEST_DIR}/${seq}_metadump"
> > > > > > > > ORPHANAGE="lost+found"
> > > > > > > >
> > > > > > > > _supported_fs xfs
> > > > > > > > @@ -52,24 +50,7 @@ function create_file() {
> > > > > > > > touch $(printf "$@")
> > > > > > > > }
> > > > > > > >
> > > > > > > > -verify_metadump_v1()
> > > > > > > > -{
> > > > > > > > - local max_version=$1
> > > > > > > > - local version=""
> > > > > > > > -
> > > > > > > > - if [[ $max_version == 2 ]]; then
> > > > > > > > - version="-v 1"
> > > > > > > > - fi
> > > > > > > > -
> > > > > > > > - _scratch_xfs_metadump $METADUMP_FILE $version
> > > > > > > > -
> > > > > > > > - SCRATCH_DEV=$TEST_DIR/data-image SCRATCH_LOGDEV="" \
> > > > > > > > - _scratch_xfs_mdrestore $METADUMP_FILE
> > > > > > > > -
> > > > > > > > - datadev=$(_create_loop_device $TEST_DIR/data-image)
> > > > > > > > -
> > > > > > > > - SCRATCH_DEV=$datadev _scratch_mount
> > > > > > > > -
> > > > > > > > +extra_test() {
> > > > > > > > cd "${SCRATCH_MNT}"
> > > > > > > >
> > > > > > > > # Get a listing of all the files after obfuscation
> > > > > > > > @@ -78,60 +59,6 @@ verify_metadump_v1()
> > > > > > > > ls -R | od -c >> $seqres.full
> > > > > > > >
> > > > > > > > cd /
> > > > > > > > -
> > > > > > > > - SCRATCH_DEV=$datadev _scratch_unmount
> > > > > > > > -
> > > > > > > > - _destroy_loop_device $datadev
> > > > > > > > - datadev=""
> > > > > > > > - rm -f $TEST_DIR/data-image
> > > > > > > > -}
> > > > > > > > -
> > > > > > > > -verify_metadump_v2()
> > > > > > > > -{
> > > > > > > > - version="-v 2"
> > > > > > > > -
> > > > > > > > - _scratch_xfs_metadump $METADUMP_FILE $version
> > > > > > > > -
> > > > > > > > - # Metadump v2 files can contain contents dumped from an external log
> > > > > > > > - # device. Use a temporary file to hold the log device contents restored
> > > > > > > > - # from such a metadump file.
> > > > > > > > - slogdev=""
> > > > > > > > - if [[ -n $SCRATCH_LOGDEV ]]; then
> > > > > > > > - slogdev=$TEST_DIR/log-image
> > > > > > > > - fi
> > > > > > > > -
> > > > > > > > - SCRATCH_DEV=$TEST_DIR/data-image SCRATCH_LOGDEV=$slogdev \
> > > > > > > > - _scratch_xfs_mdrestore $METADUMP_FILE
> > > > > > > > -
> > > > > > > > - datadev=$(_create_loop_device $TEST_DIR/data-image)
> > > > > > > > -
> > > > > > > > - logdev=${SCRATCH_LOGDEV}
> > > > > > > > - if [[ -s $TEST_DIR/log-image ]]; then
> > > > > > > > - logdev=$(_create_loop_device $TEST_DIR/log-image)
> > > > > > > > - fi
> > > > > > > > -
> > > > > > > > - SCRATCH_DEV=$datadev SCRATCH_LOGDEV=$logdev _scratch_mount
> > > > > > > > -
> > > > > > > > - cd "${SCRATCH_MNT}"
> > > > > > > > -
> > > > > > > > - # Get a listing of all the files after obfuscation
> > > > > > > > - echo "Metadump v2" >> $seqres.full
> > > > > > > > - ls -R >> $seqres.full
> > > > > > > > - ls -R | od -c >> $seqres.full
> > > > > > > > -
> > > > > > > > - cd /
> > > > > > > > -
> > > > > > > > - SCRATCH_DEV=$datadev SCRATCH_LOGDEV=$logdev _scratch_unmount
> > > > > > > > -
> > > > > > > > - if [[ -s $TEST_DIR/log-image ]]; then
> > > > > > > > - _destroy_loop_device $logdev
> > > > > > > > - logdev=""
> > > > > > > > - rm -f $TEST_DIR/log-image
> > > > > > > > - fi
> > > > > > > > -
> > > > > > > > - _destroy_loop_device $datadev
> > > > > > > > - datadev=""
> > > > > > > > - rm -f $TEST_DIR/data-image
> > > > > > > > }
> > > > > > > >
> > > > > > > > echo "Disciplyne of silence is goed."
> > > > > > > > @@ -233,13 +160,7 @@ cd $here
> > > > > > > >
> > > > > > > > _scratch_unmount
> > > > > > > >
> > > > > > > > -max_md_version=$(_xfs_metadump_max_version)
> > > > > > > > -
> > > > > > > > -verify_metadump_v1 $max_md_version
> > > > > > > > -
> > > > > > > > -if [[ $max_md_version == 2 ]]; then
> > > > > > > > - verify_metadump_v2
> > > > > > > > -fi
> > > > > > > > +_verify_metadumps '' extra_test
> > > > > > > >
> > > > > > > > # Finally, re-make the filesystem since to ensure we don't
> > > > > > > > # leave a directory with duplicate entries lying around.
> > > > > > > > diff --git a/tests/xfs/291 b/tests/xfs/291
> > > > > > > > index 1433140821..c475d89ad9 100755
> > > > > > > > --- a/tests/xfs/291
> > > > > > > > +++ b/tests/xfs/291
> > > > > > > > @@ -9,11 +9,21 @@
> > > > > > > > . ./common/preamble
> > > > > > > > _begin_fstest auto repair metadump
> > > > > > > >
> > > > > > > > +# Override the default cleanup function.
> > > > > > > > +_cleanup()
> > > > > > > > +{
> > > > > > > > + cd /
> > > > > > > > + rm -r -f $tmp.*
> > > > > > > > + _cleanup_verify_metadump
> > > > > > > > +}
> > > > > > > > +
> > > > > > > > # Import common functions.
> > > > > > > > . ./common/filter
> > > > > > > > +. ./common/xfs_metadump_tests
> > > > > > > >
> > > > > > > > _supported_fs xfs
> > > > > > > > _require_command "$XFS_MDRESTORE_PROG" "xfs_mdrestore"
> > > > > > > > +_setup_verify_metadump
> > > > > > > >
> > > > > > > > # real QA test starts here
> > > > > > > > _require_scratch
> > > > > > > > @@ -92,26 +102,7 @@ _scratch_xfs_check >> $seqres.full 2>&1 || _fail "xfs_check failed"
> > > > > > > >
> > > > > > > > # Yes they can! Now...
> > > > > > > > # Can xfs_metadump cope with this monster?
> > > > > > > > -max_md_version=$(_xfs_metadump_max_version)
> > > > > > > > -
> > > > > > > > -for md_version in $(seq 1 $max_md_version); do
> > > > > > > > - version=""
> > > > > > > > - if [[ $max_md_version == 2 ]]; then
> > > > > > > > - version="-v $md_version"
> > > > > > > > - fi
> > > > > > > > -
> > > > > > > > - _scratch_xfs_metadump $tmp.metadump -a -o $version || \
> > > > > > > > - _fail "xfs_metadump failed"
> > > > > > > > -
> > > > > > > > - slogdev=$SCRATCH_LOGDEV
> > > > > > > > - if [[ -z $version || $version == "-v 1" ]]; then
> > > > > > > > - slogdev=""
> > > > > > > > - fi
> > > > > > > > - SCRATCH_DEV=$tmp.img SCRATCH_LOGDEV=$slogdev _scratch_xfs_mdrestore \
> > > > > > > > - $tmp.metadump || _fail "xfs_mdrestore failed"
> > > > > > > > - SCRATCH_DEV=$tmp.img _scratch_xfs_repair -f &>> $seqres.full || \
> > > > > > > > - _fail "xfs_repair of metadump failed"
> > > > > > > > -done
> > > > > > > > +_verify_metadumps '-a -o'
> > > > > > > >
> > > > > > > > # Yes it can; success, all done
> > > > > > > > status=0
> > > > > > > > diff --git a/tests/xfs/432 b/tests/xfs/432
> > > > > > > > index 7e402aa88f..579e1b556a 100755
> > > > > > > > --- a/tests/xfs/432
> > > > > > > > +++ b/tests/xfs/432
> > > > > > > > @@ -20,16 +20,19 @@ _begin_fstest auto quick dir metadata metadump
> > > > > > > > _cleanup()
> > > > > > > > {
> > > > > > > > cd /
> > > > > > > > - rm -f "$tmp".* $metadump_file $metadump_img
> > > > > > > > + rm -f "$tmp".*
> > > > > > > > + _cleanup_verify_metadump
> > > > > > > > }
> > > > > > > >
> > > > > > > > # Import common functions.
> > > > > > > > . ./common/filter
> > > > > > > > +. ./common/xfs_metadump_tests
> > > > > > > >
> > > > > > > > # real QA test starts here
> > > > > > > > _supported_fs xfs
> > > > > > > > _require_command "$XFS_MDRESTORE_PROG" "xfs_mdrestore"
> > > > > > > > _require_scratch
> > > > > > > > +_setup_verify_metadump
> > > > > > > >
> > > > > > > > rm -f "$seqres.full"
> > > > > > > >
> > > > > > > > @@ -54,9 +57,6 @@ echo "Format and mount"
> > > > > > > > _scratch_mkfs -b size=1k -n size=64k > "$seqres.full" 2>&1
> > > > > > > > _scratch_mount >> "$seqres.full" 2>&1
> > > > > > > >
> > > > > > > > -metadump_file="$TEST_DIR/meta-$seq"
> > > > > > > > -metadump_img="$TEST_DIR/img-$seq"
> > > > > > > > -rm -f $metadump_file $metadump_img
> > > > > > > > testdir="$SCRATCH_MNT/test-$seq"
> > > > > > > > max_fname_len=255
> > > > > > > > blksz=$(_get_block_size $SCRATCH_MNT)
> > > > > > > > @@ -87,27 +87,7 @@ echo "qualifying extent: $extlen blocks" >> $seqres.full
> > > > > > > > test -n "$extlen" || _notrun "could not create dir extent > 1000 blocks"
> > > > > > > >
> > > > > > > > echo "Try to metadump, restore and check restored metadump image"
> > > > > > > > -max_md_version=$(_xfs_metadump_max_version)
> > > > > > > > -
> > > > > > > > -for md_version in $(seq 1 $max_md_version); do
> > > > > > > > - version=""
> > > > > > > > - if [[ $max_md_version == 2 ]]; then
> > > > > > > > - version="-v $md_version"
> > > > > > > > - fi
> > > > > > > > -
> > > > > > > > - _scratch_xfs_metadump $metadump_file -a -o -w $version
> > > > > > > > -
> > > > > > > > - slogdev=$SCRATCH_LOGDEV
> > > > > > > > - if [[ -z $version || $version == "-v 1" ]]; then
> > > > > > > > - slogdev=""
> > > > > > > > - fi
> > > > > > > > -
> > > > > > > > - SCRATCH_DEV=$metadump_img SCRATCH_LOGDEV=$slogdev \
> > > > > > > > - _scratch_xfs_mdrestore $metadump_file
> > > > > > > > -
> > > > > > > > - SCRATCH_DEV=$metadump_img _scratch_xfs_repair -n &>> $seqres.full || \
> > > > > > > > - echo "xfs_repair on restored fs returned $?"
> > > > > > > > -done
> > > > > > > > +_verify_metadumps '-a -o -w'
> > > > > > > >
> > > > > > > > # success, all done
> > > > > > > > status=0
> > > > > > > > diff --git a/tests/xfs/503 b/tests/xfs/503
> > > > > > > > index 8643c3d483..ff6b344a9c 100755
> > > > > > > > --- a/tests/xfs/503
> > > > > > > > +++ b/tests/xfs/503
> > > > > > > > @@ -17,11 +17,13 @@ _cleanup()
> > > > > > > > {
> > > > > > > > cd /
> > > > > > > > rm -rf $tmp.* $testdir
> > > > > > > > + _cleanup_verify_metadump
> > > > > > > > }
> > > > > > > >
> > > > > > > > # Import common functions.
> > > > > > > > . ./common/filter
> > > > > > > > . ./common/populate
> > > > > > > > +. ./common/xfs_metadump_tests
> > > > > > > >
> > > > > > > > testdir=$TEST_DIR/test-$seq
> > > > > > > >
> > > > > > > > @@ -35,6 +37,7 @@ _require_scratch_nocheck
> > > > > > > > _require_populate_commands
> > > > > > > > _xfs_skip_online_rebuild
> > > > > > > > _xfs_skip_offline_rebuild
> > > > > > > > +_setup_verify_metadump
> > > > > > > >
> > > > > > > > echo "Format and populate"
> > > > > > > > _scratch_populate_cached nofill > $seqres.full 2>&1
> > > > > > > > @@ -43,66 +46,17 @@ mkdir -p $testdir
> > > > > > > > metadump_file=$testdir/scratch.md
> > > > > > > > copy_file=$testdir/copy.img
> > > > > > > >
> > > > > > > > -check_restored_metadump_image()
> > > > > > > > -{
> > > > > > > > - local image=$1
> > > > > > > > -
> > > > > > > > - loop_dev=$(_create_loop_device $image)
> > > > > > > > - SCRATCH_DEV=$loop_dev _scratch_mount
> > > > > > > > - SCRATCH_DEV=$loop_dev _check_scratch_fs
> > > > > > > > - SCRATCH_DEV=$loop_dev _scratch_unmount
> > > > > > > > - _destroy_loop_device $loop_dev
> > > > > > > > -}
> > > > > > > > -
> > > > > > > > -max_md_version=$(_xfs_metadump_max_version)
> > > > > > > > -
> > > > > > > > echo "metadump and mdrestore"
> > > > > > > > -for md_version in $(seq 1 $max_md_version); do
> > > > > > > > - version=""
> > > > > > > > - if [[ $max_md_version == 2 ]]; then
> > > > > > > > - version="-v $md_version"
> > > > > > > > - fi
> > > > > > > > -
> > > > > > > > - _scratch_xfs_metadump $metadump_file -a -o $version >> $seqres.full
> > > > > > > > - SCRATCH_DEV=$TEST_DIR/image _scratch_xfs_mdrestore $metadump_file
> > > > > > > > - check_restored_metadump_image $TEST_DIR/image
> > > > > > > > -done
> > > > > > > > +_verify_metadumps '-a -o'
> > > > > > > >
> > > > > > > > echo "metadump a and mdrestore"
> > > > > > > > -for md_version in $(seq 1 $max_md_version); do
> > > > > > > > - version=""
> > > > > > > > - if [[ $max_md_version == 2 ]]; then
> > > > > > > > - version="-v $md_version"
> > > > > > > > - fi
> > > > > > > > -
> > > > > > > > - _scratch_xfs_metadump $metadump_file -a $version >> $seqres.full
> > > > > > > > - SCRATCH_DEV=$TEST_DIR/image _scratch_xfs_mdrestore $metadump_file
> > > > > > > > - check_restored_metadump_image $TEST_DIR/image
> > > > > > > > -done
> > > > > > > > +_verify_metadumps '-a'
> > > > > > > >
> > > > > > > > echo "metadump g and mdrestore"
> > > > > > > > -for md_version in $(seq 1 $max_md_version); do
> > > > > > > > - version=""
> > > > > > > > - if [[ $max_md_version == 2 ]]; then
> > > > > > > > - version="-v $md_version"
> > > > > > > > - fi
> > > > > > > > -
> > > > > > > > - _scratch_xfs_metadump $metadump_file -g $version >> $seqres.full
> > > > > > > > - SCRATCH_DEV=$TEST_DIR/image _scratch_xfs_mdrestore $metadump_file
> > > > > > > > - check_restored_metadump_image $TEST_DIR/image
> > > > > > > > -done
> > > > > > > > +_verify_metadumps '-g' >> $seqres.full
> > > > > > > >
> > > > > > > > echo "metadump ag and mdrestore"
> > > > > > > > -for md_version in $(seq 1 $max_md_version); do
> > > > > > > > - version=""
> > > > > > > > - if [[ $max_md_version == 2 ]]; then
> > > > > > > > - version="-v $md_version"
> > > > > > > > - fi
> > > > > > > > -
> > > > > > > > - _scratch_xfs_metadump $metadump_file -a -g $version >> $seqres.full
> > > > > > > > - SCRATCH_DEV=$TEST_DIR/image _scratch_xfs_mdrestore $metadump_file
> > > > > > > > - check_restored_metadump_image $TEST_DIR/image
> > > > > > > > -done
> > > > > > > > +_verify_metadumps '-a -g' >> $seqres.full
> > > > > > > >
> > > > > > > > echo copy
> > > > > > > > $XFS_COPY_PROG $SCRATCH_DEV $copy_file >> $seqres.full
> > > > > > > > diff --git a/tests/xfs/605 b/tests/xfs/605
> > > > > > > > index f2cd7aba98..af917f0f32 100755
> > > > > > > > --- a/tests/xfs/605
> > > > > > > > +++ b/tests/xfs/605
> > > > > > > > @@ -15,17 +15,13 @@ _cleanup()
> > > > > > > > {
> > > > > > > > cd /
> > > > > > > > rm -r -f $tmp.*
> > > > > > > > - _scratch_unmount > /dev/null 2>&1
> > > > > > > > - [[ -n $logdev && $logdev != "none" && $logdev != $SCRATCH_LOGDEV ]] && \
> > > > > > > > - _destroy_loop_device $logdev
> > > > > > > > - [[ -n $datadev ]] && _destroy_loop_device $datadev
> > > > > > > > - rm -r -f $metadump_file $TEST_DIR/data-image \
> > > > > > > > - $TEST_DIR/log-image
> > > > > > > > + _cleanup_verify_metadump
> > > > > > > > }
> > > > > > > >
> > > > > > > > # Import common functions.
> > > > > > > > . ./common/dmflakey
> > > > > > > > . ./common/inject
> > > > > > > > +. ./common/xfs_metadump_tests
> > > > > > > >
> > > > > > > > # real QA test starts here
> > > > > > > > _supported_fs xfs
> > > > > > > > @@ -37,85 +33,22 @@ _require_xfs_io_error_injection log_item_pin
> > > > > > > > _require_dm_target flakey
> > > > > > > > _require_xfs_io_command "pwrite"
> > > > > > > > _require_test_program "punch-alternating"
> > > > > > > > +_setup_verify_metadump
> > > > > > > >
> > > > > > > > -metadump_file=${TEST_DIR}/${seq}.md
> > > > > > > > testfile=${SCRATCH_MNT}/testfile
> > > > > > > >
> > > > > > > > echo "Format filesystem on scratch device"
> > > > > > > > _scratch_mkfs >> $seqres.full 2>&1
> > > > > > > >
> > > > > > > > -max_md_version=$(_xfs_metadump_max_version)
> > > > > > > > -
> > > > > > > > external_log=0
> > > > > > > > if [[ $USE_EXTERNAL = yes && -n "$SCRATCH_LOGDEV" ]]; then
> > > > > > > > external_log=1
> > > > > > > > fi
> > > > > > > >
> > > > > > > > -if [[ $max_md_version == 1 && $external_log == 1 ]]; then
> > > > > > > > +if [[ $MAX_XFS_METADUMP_FORMAT == 1 && $external_log == 1 ]]; then
> > > > > > > > _notrun "metadump v1 does not support external log device"
> > > > > > > > fi
> > > > > > > >
> > > > > > > > -verify_metadump_v1()
> > > > > > > > -{
> > > > > > > > - local version=""
> > > > > > > > - if [[ $max_md_version == 2 ]]; then
> > > > > > > > - version="-v 1"
> > > > > > > > - fi
> > > > > > > > -
> > > > > > > > - _scratch_xfs_metadump $metadump_file -a -o $version
> > > > > > > > -
> > > > > > > > - SCRATCH_DEV=$TEST_DIR/data-image _scratch_xfs_mdrestore $metadump_file
> > > > > > > > -
> > > > > > > > - datadev=$(_create_loop_device $TEST_DIR/data-image)
> > > > > > > > -
> > > > > > > > - SCRATCH_DEV=$datadev _scratch_mount
> > > > > > > > - SCRATCH_DEV=$datadev _check_scratch_fs
> > > > > > > > - SCRATCH_DEV=$datadev _scratch_unmount
> > > > > > > > -
> > > > > > > > - _destroy_loop_device $datadev
> > > > > > > > - datadev=""
> > > > > > > > - rm -f $TEST_DIR/data-image
> > > > > > > > -}
> > > > > > > > -
> > > > > > > > -verify_metadump_v2()
> > > > > > > > -{
> > > > > > > > - local version="-v 2"
> > > > > > > > -
> > > > > > > > - _scratch_xfs_metadump $metadump_file -a -o $version
> > > > > > > > -
> > > > > > > > - # Metadump v2 files can contain contents dumped from an external log
> > > > > > > > - # device. Use a temporary file to hold the log device contents restored
> > > > > > > > - # from such a metadump file.
> > > > > > > > - slogdev=""
> > > > > > > > - if [[ -n $SCRATCH_LOGDEV ]]; then
> > > > > > > > - slogdev=$TEST_DIR/log-image
> > > > > > > > - fi
> > > > > > > > -
> > > > > > > > - SCRATCH_DEV=$TEST_DIR/data-image SCRATCH_LOGDEV=$slogdev \
> > > > > > > > - _scratch_xfs_mdrestore $metadump_file
> > > > > > > > -
> > > > > > > > - datadev=$(_create_loop_device $TEST_DIR/data-image)
> > > > > > > > -
> > > > > > > > - logdev=""
> > > > > > > > - if [[ -s $slogdev ]]; then
> > > > > > > > - logdev=$(_create_loop_device $slogdev)
> > > > > > > > - fi
> > > > > > > > -
> > > > > > > > - SCRATCH_DEV=$datadev SCRATCH_LOGDEV=$logdev _scratch_mount
> > > > > > > > - SCRATCH_DEV=$datadev SCRATCH_LOGDEV=$logdev _check_scratch_fs
> > > > > > > > - SCRATCH_DEV=$datadev SCRATCH_LOGDEV=$logdev _scratch_unmount
> > > > > > > > -
> > > > > > > > - if [[ -s $logdev ]]; then
> > > > > > > > - _destroy_loop_device $logdev
> > > > > > > > - logdev=""
> > > > > > > > - rm -f $slogdev
> > > > > > > > - fi
> > > > > > > > -
> > > > > > > > - _destroy_loop_device $datadev
> > > > > > > > - datadev=""
> > > > > > > > - rm -f $TEST_DIR/data-image
> > > > > > > > -}
> > > > > > > > -
> > > > > > > > echo "Initialize and mount filesystem on flakey device"
> > > > > > > > _init_flakey
> > > > > > > > _load_flakey_table $FLAKEY_ALLOW_WRITES
> > > > > > > > @@ -160,14 +93,7 @@ echo -n "Filesystem has a "
> > > > > > > > _print_logstate
> > > > > > > >
> > > > > > > > echo "Create metadump file, restore it and check restored fs"
> > > > > > > > -
> > > > > > > > -if [[ $external_log == 0 ]]; then
> > > > > > > > - verify_metadump_v1 $max_md_version
> > > > > > > > -fi
> > > > > > > > -
> > > > > > > > -if [[ $max_md_version == 2 ]]; then
> > > > > > > > - verify_metadump_v2
> > > > > > > > -fi
> > > > > > > > +_verify_metadumps '-a -o'
> > > > > > > >
> > > > > > > > # Mount the fs to replay the contents from the dirty log.
> > > > > > > > _scratch_mount
> > > > > > > >
> > > > > > >
> > > > > >
> > > > >
> > > > >
> > > >
> > >
> > >
> >
>
>
next prev parent reply other threads:[~2024-02-02 16:47 UTC|newest]
Thread overview: 36+ messages / expand[flat|nested] mbox.gz Atom feed top
2024-01-25 19:04 [PATCHSET] fstests: random fixes for v2024.01.14 Darrick J. Wong
2024-01-25 19:04 ` [PATCH 01/10] generic/256: constrain runtime with TIME_FACTOR Darrick J. Wong
2024-01-26 12:32 ` Andrey Albershteyn
2024-01-26 13:30 ` Christoph Hellwig
2024-01-25 19:04 ` [PATCH 02/10] common/xfs: simplify maximum metadump format detection Darrick J. Wong
2024-01-26 13:31 ` Christoph Hellwig
2024-01-25 19:04 ` [PATCH 03/10] common/populate: always metadump full metadata blocks Darrick J. Wong
2024-01-26 13:32 ` Christoph Hellwig
2024-01-25 19:05 ` [PATCH 04/10] xfs/336: fix omitted -a and -o in metadump call Darrick J. Wong
2024-01-26 13:33 ` Christoph Hellwig
2024-01-25 19:05 ` [PATCH 05/10] common: refactor metadump v1 and v2 tests Darrick J. Wong
2024-01-26 13:34 ` Christoph Hellwig
2024-01-27 8:47 ` Zorro Lang
2024-01-27 17:22 ` Darrick J. Wong
2024-01-28 13:23 ` Zorro Lang
2024-01-30 1:32 ` Darrick J. Wong
2024-01-31 14:09 ` Zorro Lang
2024-01-31 19:24 ` Darrick J. Wong
2024-02-01 6:29 ` Zorro Lang
2024-02-02 16:47 ` Darrick J. Wong [this message]
2024-02-04 6:59 ` Zorro Lang
2024-02-04 7:14 ` Zorro Lang
2024-02-05 9:37 ` Zorro Lang
2024-02-05 16:48 ` Darrick J. Wong
2024-01-25 19:05 ` [PATCH 06/10] xfs/{129,234,253,605}: disable metadump v1 testing with external devices Darrick J. Wong
2024-01-26 13:34 ` Christoph Hellwig
2024-01-25 19:05 ` [PATCH 07/10] xfs/503: test metadump obfuscation, not progressbars Darrick J. Wong
2024-01-26 13:35 ` Christoph Hellwig
2024-01-25 19:06 ` [PATCH 08/10] xfs/503: split copy and metadump into two tests Darrick J. Wong
2024-01-26 13:36 ` Christoph Hellwig
2024-01-26 16:45 ` Darrick J. Wong
2024-01-25 19:06 ` [PATCH 09/10] common/xfs: only pass -l in _xfs_mdrestore for v2 metadumps Darrick J. Wong
2024-01-26 13:36 ` Christoph Hellwig
2024-01-25 19:06 ` [PATCH 10/10] xfs/122: fix for xfs_attr_shortform removal in 6.8 Darrick J. Wong
2024-01-26 12:38 ` Andrey Albershteyn
2024-01-26 13:37 ` Christoph Hellwig
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=20240202164708.GL616564@frogsfrogsfrogs \
--to=djwong@kernel.org \
--cc=fstests@vger.kernel.org \
--cc=linux-xfs@vger.kernel.org \
--cc=zlang@redhat.com \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).