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@xxxxxxxxxx> > > > > 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@xxxxxxxxxx> > > --- > > 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. 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. --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 > > >