From: Jeff Mahoney Date: Mon, 27 Jun 2016 20:14:11 +0000 (-0400) Subject: btrfs/048: extend _filter_btrfs_prop_error to handle additional errors X-Git-Tag: v2022.05.01~2464 X-Git-Url: http://git.apps.os.sepia.ceph.com/?a=commitdiff_plain;h=2831b8b43bb5e6c40300c5e593fb3164dbf1c30a;p=xfstests-dev.git btrfs/048: extend _filter_btrfs_prop_error to handle additional errors btrfsprogs v4.5.3 changed the formatting of some error messages. This patch extends the filter for btrfs prop to handle those. Signed-off-by: Jeff Mahoney Reviewed-by: Eryu Guan Signed-off-by: Eryu Guan --- diff --git a/common/filter.btrfs b/common/filter.btrfs index 9970f4d4..0cf7f0d3 100644 --- a/common/filter.btrfs +++ b/common/filter.btrfs @@ -72,15 +72,19 @@ _filter_btrfs_compress_property() sed -e "s/compression=\(lzo\|zlib\)/COMPRESSION=XXX/g" } -# filter name of the property from the output, optionally verify against $1 +# filter error messages from btrfs prop, optionally verify against $1 # recognized message(s): # "object is not compatible with property: label" +# "invalid value for property:{, value}" +# "failed to {get,set} compression for $PATH[.:]: Invalid argument" _filter_btrfs_prop_error() { if ! [ -z "$1" ]; then - sed -e "s/\(compatible with property\): $1/\1/" + sed -e "s#\(compatible with property\): $1#\1#" \ + -e "s#^\(.*failed to [sg]et compression for $1\)[:.] \(.*\)#\1: \2#" else - sed -e "s/^\(.*compatible with property\).*/\1/" + sed -e "s#^\(.*compatible with property\).*#\1#" \ + -e "s#^\(.*invalid value for property\)[:.].*#\1#" fi } diff --git a/tests/btrfs/048 b/tests/btrfs/048 index 4a363036..0b907b03 100755 --- a/tests/btrfs/048 +++ b/tests/btrfs/048 @@ -79,7 +79,8 @@ echo -e "\nTesting subvolume ro property" _run_btrfs_util_prog subvolume create $SCRATCH_MNT/sv1 $BTRFS_UTIL_PROG property get $SCRATCH_MNT/sv1 ro echo "***" -$BTRFS_UTIL_PROG property set $SCRATCH_MNT/sv1 ro foo +$BTRFS_UTIL_PROG property set $SCRATCH_MNT/sv1 ro foo 2>&1 | + _filter_btrfs_prop_error echo "***" $BTRFS_UTIL_PROG property set $SCRATCH_MNT/sv1 ro true echo "***" @@ -99,7 +100,8 @@ $BTRFS_UTIL_PROG property get $SCRATCH_MNT/testdir/file1 compression $BTRFS_UTIL_PROG property get $SCRATCH_MNT/testdir/subdir1 compression echo "***" $BTRFS_UTIL_PROG property set $SCRATCH_MNT/testdir/file1 compression \ - foo 2>&1 | _filter_scratch + foo 2>&1 | _filter_scratch | + _filter_btrfs_prop_error SCRATCH_MNT/testdir/file1 echo "***" $BTRFS_UTIL_PROG property set $SCRATCH_MNT/testdir/file1 compression lzo $BTRFS_UTIL_PROG property get $SCRATCH_MNT/testdir/file1 compression diff --git a/tests/btrfs/048.out b/tests/btrfs/048.out index 0b20d0b5..3e4e3d28 100644 --- a/tests/btrfs/048.out +++ b/tests/btrfs/048.out @@ -15,7 +15,7 @@ ERROR: object is not compatible with property Testing subvolume ro property ro=false *** -ERROR: invalid value for property. +ERROR: invalid value for property *** *** ro=true @@ -27,7 +27,7 @@ ro=false Testing compression property *** -ERROR: failed to set compression for SCRATCH_MNT/testdir/file1. Invalid argument +ERROR: failed to set compression for SCRATCH_MNT/testdir/file1: Invalid argument *** compression=lzo compression=lzo