From: Dave Chinner Subject: Re: [PATCH V2] xfstests: make 275 pass Date: Thu, 5 Jan 2012 10:17:25 +1100 Message-ID: <20120104231725.GB24466@dastard> References: <4F04A6E6.1090304@redhat.com> <4F04BC81.1000207@redhat.com> Mime-Version: 1.0 Content-Type: text/plain; charset=us-ascii Cc: xfs-oss , ext4 development , Eryu Guan To: Eric Sandeen Return-path: Received: from ipmail07.adl2.internode.on.net ([150.101.137.131]:40945 "EHLO ipmail07.adl2.internode.on.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S932073Ab2ADXR2 (ORCPT ); Wed, 4 Jan 2012 18:17:28 -0500 Content-Disposition: inline In-Reply-To: <4F04BC81.1000207@redhat.com> Sender: linux-ext4-owner@vger.kernel.org List-ID: On Wed, Jan 04, 2012 at 02:54:25PM -0600, Eric Sandeen wrote: > Ok, this is a significant rework of 275, which made too many > assumptions about details of space usage and failed on several > filesystems (it passed on xfs, but only by accident). > > This new version tries to leave about 256k free, then tries > a single 1M IO, and fails only if 0 bytes are written. > > It also sends a lot more to $seq.full for debugging on failure > and fixes a few other stylistic things. > > Signed-off-by: Eric Sandeen I just had another thought about this, Eric.... > +# And at least some of it should succeed. > +_filesize=`du $SCRATCH_MNT/tmp1 | awk '{print $1}'` > +[ $_filesize -eq 0 ] && _fail "write file err: Partial write until enospc failed; wrote 0 bytes." The question that just came to mind was this assumes that allocation succeeded so therefore the partial write succeeded. But that's not necessary the case. The partial write might not succeed leaving the file size as zero, but the underlying FS might not remove all the blocks it allocated (nothing says that it has to). Hence to determine if a partial write succeeded, we also need to check that the file size itself is greater than zero.... Cheers, Dave. -- Dave Chinner david@fromorbit.com