On Fri, Jun 24, 2016 at 11:08:31AM -0400, jeffm@xxxxxxxx wrote: > From: Jeff Mahoney <jeffm@xxxxxxxx> > > 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 <jeffm@xxxxxxxx> > --- > common/filter.btrfs | 10 +++++++--- > tests/btrfs/048 | 6 ++++-- > tests/btrfs/048.out | 4 ++-- > 3 files changed, 13 insertions(+), 7 deletions(-) > > diff --git a/common/filter.btrfs b/common/filter.btrfs > index 9970f4d..54361d4 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#" I think the last regex should be - -e "s#^\(.*invalid value for property\):.*#\1#" + -e "s#^\(.*invalid value for property\)[:.].*#\1#" because... > fi > } > > diff --git a/tests/btrfs/048 b/tests/btrfs/048 > index 4a36303..0b907b0 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 0b20d0b..3e4e3d2 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 this change breaks test with older btrfs-progs, the filter didn't remove the ending "." correctly. With above fix btrfs/048 works for me with both v3.19 and v4.6 btrfs-progs. Thanks, Eryu > *** > *** > 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 > -- > 1.8.5.6 > > -- > To unsubscribe from this list: send the line "unsubscribe fstests" in > the body of a message to majordomo@xxxxxxxxxxxxxxx > More majordomo info at http://vger.kernel.org/majordomo-info.html -- To unsubscribe from this list: send the line "unsubscribe fstests" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html