On Tue, Feb 18, 2025 at 05:03:39PM -0800, Darrick J. Wong wrote: > From: Darrick J. Wong <djwong@xxxxxxxxxx> > > Create a test to check that statfs on a directory tree with a project > quota will report the quota limit and available blocks; and that the > available blocks reported doesn't exceed that of the whole filesystem. > > Signed-off-by: "Darrick J. Wong" <djwong@xxxxxxxxxx> > --- > tests/generic/1955 | 114 ++++++++++++++++++++++++++++++++++++++++++++++++ > tests/generic/1955.out | 13 +++++ > 2 files changed, 127 insertions(+) > create mode 100755 tests/generic/1955 > create mode 100644 tests/generic/1955.out > > > diff --git a/tests/generic/1955 b/tests/generic/1955 > new file mode 100755 > index 00000000000000..e431b3c4e3fd5d > --- /dev/null > +++ b/tests/generic/1955 > @@ -0,0 +1,114 @@ > +#! /bin/bash > +# SPDX-License-Identifier: GPL-2.0 > +# Copyright (c) 2024-2025 Oracle. All Rights Reserved. > +# > +# FS QA Test No. 1955 > +# > +# Make sure that statfs reporting works when project quotas are set on a > +# directory tree. > +# > +. ./common/preamble > +_begin_fstest auto quota > + > +_fixed_by_git_commit kernel XXXXXXXXXXXXXX \ > + "xfs: don't over-report free space or inodes in statvfs" Ext4 fails on this test [1], is it a known issue of ext4 besides xfs? Thanks, Zorro [1] FSTYP -- ext4 PLATFORM -- Linux/aarch64 hpe-apollo-cn99xx-14-vm-28 6.14.0-rc4+ #1 SMP PREEMPT_DYNAMIC Sat Mar 1 16:57:43 EST 2025 MKFS_OPTIONS -- -F /dev/vda3 MOUNT_OPTIONS -- -o acl,user_xattr -o context=system_u:object_r:root_t:s0 /dev/vda3 /mnt/xfstests/scratch generic/762 - output mismatch (see /var/lib/xfstests/results//generic/762.out.bad) --- tests/generic/762.out 2025-03-01 17:23:52.961878242 -0500 +++ /var/lib/xfstests/results//generic/762.out.bad 2025-03-01 19:13:03.026588012 -0500 @@ -6,8 +6,10 @@ root blocks2 is in range dir blocks2 is in range root bavail2 is in range -dir bavail2 is in range +dir bavail2 has value of 1821553 +dir bavail2 is NOT in range 360666.9 .. 367953.1 root blocks3 is in range ... (Run 'diff -u /var/lib/xfstests/tests/generic/762.out /var/lib/xfstests/results//generic/762.out.bad' to see the entire diff) HINT: You _MAY_ be missing kernel fix: XXXXXXXXXXXXXX xfs: don't over-report free space or inodes in statvfs Ran: generic/762 Failures: generic/762 Failed 1 of 1 tests > + > +. ./common/filter > +. ./common/quota > + > +_require_quota > +_require_scratch > +_require_xfs_io_command 'chproj' > +_require_xfs_io_command "falloc" > + > +_scratch_mkfs >$seqres.full 2>&1 > +_scratch_enable_pquota > +_qmount_option "prjquota" > +_qmount > +_force_vfs_quota_testing $SCRATCH_MNT > +_require_prjquota $SCRATCH_DEV > + > +mkdir $SCRATCH_MNT/dir > + > +bsize() { > + $XFS_IO_PROG -c 'statfs' $1 | grep f_bsize | awk '{print $3}' > +} > + > +blocks() { > + $XFS_IO_PROG -c 'statfs' $1 | grep f_blocks | awk '{print $3}' > +} > + > +bavail() { > + $XFS_IO_PROG -c 'statfs' $1 | grep f_bavail | awk '{print $3}' > +} > + > +bsize=$(bsize $SCRATCH_MNT) > +orig_bavail=$(bavail $SCRATCH_MNT) > +orig_blocks=$(blocks $SCRATCH_MNT) > + > +# Set a project quota limit of half the free space, make sure both report the > +# same number of blocks > +pquot_limit=$(( orig_bavail / 2 )) > +setquota -P 55 0 $((pquot_limit * bsize / 1024))K 0 0 $SCRATCH_DEV > +$XFS_IO_PROG -c 'chproj 55' -c 'chattr +P' $SCRATCH_MNT/dir > + > +# check statfs reporting > +fs_blocks=$(blocks $SCRATCH_MNT) > +dir_blocks=$(blocks $SCRATCH_MNT/dir) > + > +_within_tolerance "root blocks1" $fs_blocks $orig_blocks 1% -v > +_within_tolerance "dir blocks1" $dir_blocks $pquot_limit 1% -v > + > +fs_bavail=$(bavail $SCRATCH_MNT) > +expected_dir_bavail=$pquot_limit > +dir_bavail=$(bavail $SCRATCH_MNT/dir) > + > +_within_tolerance "root bavail1" $fs_bavail $orig_bavail 1% -v > +_within_tolerance "dir bavail1" $dir_bavail $expected_dir_bavail 1% -v > + > +# use up most of the free space in the filesystem > +rem_free=$(( orig_bavail / 10 )) # bsize blocks > +fallocate -l $(( (orig_bavail - rem_free) * bsize )) $SCRATCH_MNT/a > + > +if [ $rem_free -gt $pquot_limit ]; then > + echo "rem_free $rem_free greater than pquot_limit $pquot_limit??" > +fi > + > +# check statfs reporting > +fs_blocks=$(blocks $SCRATCH_MNT) > +dir_blocks=$(blocks $SCRATCH_MNT/dir) > + > +_within_tolerance "root blocks2" $fs_blocks $orig_blocks 1% -v > +_within_tolerance "dir blocks2" $dir_blocks $pquot_limit 1% -v > + > +fs_bavail=$(bavail $SCRATCH_MNT) > +dir_bavail=$(bavail $SCRATCH_MNT/dir) > + > +_within_tolerance "root bavail2" $fs_bavail $rem_free 1% -v > +_within_tolerance "dir bavail2" $dir_bavail $rem_free 1% -v > + > +# use up 10 blocks of project quota > +$XFS_IO_PROG -f -c "pwrite -S 0x99 0 $((bsize * 10))" -c fsync $SCRATCH_MNT/dir/a >> $seqres.full > + > +# check statfs reporting > +fs_blocks=$(blocks $SCRATCH_MNT) > +dir_blocks=$(blocks $SCRATCH_MNT/dir) > + > +_within_tolerance "root blocks3" $fs_blocks $orig_blocks 1% -v > +_within_tolerance "dir blocks3" $dir_blocks $pquot_limit 1% -v > + > +fs_bavail=$(bavail $SCRATCH_MNT) > +dir_bavail=$(bavail $SCRATCH_MNT/dir) > + > +_within_tolerance "root bavail3" $fs_bavail $rem_free 1% -v > +_within_tolerance "dir bavail3" $dir_bavail $((rem_free - 10)) 1% -v > + > +# final state diagnostics > +$XFS_IO_PROG -c 'statfs' $SCRATCH_MNT $SCRATCH_MNT/dir | grep statfs >> $seqres.full > +repquota -P $SCRATCH_DEV >> $seqres.full > +df $SCRATCH_MNT >> $seqres.full > +ls -laR $SCRATCH_MNT/ >> $seqres.full > + > +# success, all done > +status=0 > +exit > diff --git a/tests/generic/1955.out b/tests/generic/1955.out > new file mode 100644 > index 00000000000000..3601010962193e > --- /dev/null > +++ b/tests/generic/1955.out > @@ -0,0 +1,13 @@ > +QA output created by 1955 > +root blocks1 is in range > +dir blocks1 is in range > +root bavail1 is in range > +dir bavail1 is in range > +root blocks2 is in range > +dir blocks2 is in range > +root bavail2 is in range > +dir bavail2 is in range > +root blocks3 is in range > +dir blocks3 is in range > +root bavail3 is in range > +dir bavail3 is in range >