On Fri, May 29, 2015 at 10:51:05AM +0800, Eryu Guan wrote: > On Fri, May 29, 2015 at 11:20:31AM +1000, Dave Chinner wrote: > > On Wed, May 27, 2015 at 11:34:04AM +0800, Eryu Guan wrote: > > > On Wed, May 27, 2015 at 12:43:37PM +1000, Dave Chinner wrote: > > > > From: Dave Chinner <dchinner@xxxxxxxxxx> > > > > > > > > in certain cases, the extent size hints can cause maximum extent > > > > size overflows resulting in extent tree corruptions. This test > > > > exercises the original reproducer, and another corner case > > > > demonstrated to expose problems on 1k block size filesystems. > > > > > > > > Signed-off-by: Dave Chinner <dchinner@xxxxxxxxxx> > > .... > > > > +rm -f $seqres.full > > > > + > > > > +_require_test > > > > +_require_xfs_io_command "falloc" > > > > + > > > > +# we use loop devices for this so that we can create large files for prealloc > > > > +# without having to care about the underlying device size. > > > > +_require_loop > > > > + > > > > +LOOP_FILE=$TESTDIR/$seq.img > > > > +LOOP_MNT=$TESTDIR/$seq.mnt > > > > > > This should be $TEST_DIR, TESTDIR is empty and ends up in /074.mnt > > > > Oops, will fix. > > > > > > +mkdir -p $LOOP_MNT > > > > +$XFS_IO_PROG -ft -c "truncate 1t" $LOOP_FILE 2>&1 > $seqres.full > > > > > > This will leave stderr to stdout, then only stdout goes to $seqres.full > > > I see "+ fallocate: No space left on device" when testing. > > > > Why would the truncate command give an "fallocate" failure? > > Oh, I mean at the "falloc" time, I should refer to the next xfs_io > command below.. > > > > > And, besides, allowing stderr to be exposed is done on purpose - an > > error in the execution of the truncate command will trigger a test > > failure because stderr is captured by the test harness... > > Then I think a comment should be added, because "2>&1 >$seqres.full" is > not a usual usage, usually it indicates a programming mistake. Or just > ">$seqres.full" and leave stderr untouched? which indicates clearly we > leave stderr unfiltered on purpose. If we had to comment on every time we are capturing stderr as the failure indication for the test, then we'd be adding comments everywhere. This is how xfstests is supposed to work - we capture *error messages* from tools because that's what is used to inform the user that there was an error. Those error messages cause golden image match failures, and that causes the test to fail. See the comments I've made previously about why "run_check" is considered harmful - it encourages tools to be silent on error and only set exit values, because that is all it checks. Users *never* check return values - there need to be error messages when an error occurs... > > > "command >$seqres.full 2>&1" will do the work. > > > > > > > +LOOP_DEV=`_create_loop_device $LOOP_FILE` > > > > + > > > > +_mkfs_dev -d size=40051712b,agcount=4 -l size=32m $LOOP_DEV > > > > +_mount $LOOP_DEV $LOOP_MNT > > > > + > > > > +# Corrupt the BMBT by creating extents larger than MAXEXTLEN > > > > +$XFS_IO_PROG -ft \ > > > > + -c "extsize 16m" \ > > > > + -c "falloc 0 30g" \ > > > > + $LOOP_MNT/foo 2>&1 > $seqres.full > > The "+ fallocate: No space left on device" error comes from this > command. Is this on purpose too? So on patched kernel the error > shouldn't be there? That's right - the falloc completes without error when the bug is fixed, so stderr is silent and the test passes. Cheers, Dave. -- Dave Chinner david@xxxxxxxxxxxxx -- 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