linux-ext4.vger.kernel.org archive mirror
 help / color / mirror / Atom feed
* [PATCH] xfstests: 220 - generic quota sanity
@ 2009-08-07 19:10 Eric Sandeen
  2009-08-10  5:13 ` Lachlan McIlroy
  0 siblings, 1 reply; 5+ messages in thread
From: Eric Sandeen @ 2009-08-07 19:10 UTC (permalink / raw)
  To: xfs-oss, ext4 development

Add some very basic quota sanity tests for generic filesystems.

This is based on test 108, but uses the generic quota tools,
not xfs_quota, and therefore cannot test project quota.

Also, the IOs are much smaller (48k) so that ext3 won't get into
indirect blocks and throw off the accounting.  This does
assume 4k blocks though.

Signed-off-by: Eric Sandeen <sandeen@redhat.com>
---

diff --git a/220 b/220
new file mode 100755
index 0000000..3b828cb
--- /dev/null
+++ b/220
@@ -0,0 +1,123 @@
+#! /bin/sh
+# FS QA Test No. 220
+#
+# Simple quota accounting test for direct/buffered/mmap IO.
+#
+#-----------------------------------------------------------------------
+# Copyright (c) 2009 Eric Sandeen.  All Rights Reserved.
+#
+# Based on test 108,
+# Copyright (c) 2005 Silicon Graphics, Inc.  All Rights Reserved.
+#
+# This program is free software; you can redistribute it and/or
+# modify it under the terms of the GNU General Public License as
+# published by the Free Software Foundation.
+#
+# This program is distributed in the hope that it would be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+# GNU General Public License for more details.
+#
+# You should have received a copy of the GNU General Public License
+# along with this program; if not, write the Free Software Foundation,
+# Inc.,  51 Franklin St, Fifth Floor, Boston, MA  02110-1301  USA
+#
+#-----------------------------------------------------------------------
+#
+# creator
+owner=sandeen@sandeen.net
+
+seq=`basename $0`
+echo "QA output created by $seq"
+
+here=`pwd`
+tmp=/tmp/$$
+status=1	# failure is the default!
+trap "rm -f $tmp.*; exit \$status" 0 1 2 3 15
+
+# get standard environment, filters and checks
+. ./common.rc
+. ./common.filter
+. ./common.quota
+
+filter_scratch()
+{
+	perl -ne "
+s,$SCRATCH_MNT,[SCR_MNT],;
+s,$SCRATCH_DEV,[SCR_DEV],;
+	print;"
+}
+
+# real QA test starts here
+_supported_fs generic
+_supported_os Linux #IRIX
+_require_scratch
+_require_quota
+
+test_files()
+{
+	echo; echo "### create files, setting up ownership (type=$type)"
+	rm -f $SCRATCH_MNT/{buffer,direct,mmap}
+	touch $SCRATCH_MNT/{buffer,direct,mmap}
+	chown $uid $SCRATCH_MNT/{buffer,direct,mmap}
+	chgrp $gid $SCRATCH_MNT/{buffer,direct,mmap}
+	for file in $SCRATCH_MNT/{buffer,direct,mmap}; do
+		$here/src/lstat64 $file | head -3 | filter_scratch
+	done
+}
+
+test_accounting()
+{
+	echo "### some controlled buffered, direct and mmapd IO (type=$type)"
+	echo "--- initiating parallel IO..." >>$seq.full
+	# Small ios here because ext3 will account for indirect blocks too ...   :( 
+	# 48k will fit w/o indirect for 4k blocks (default blocksize)
+	$XFS_IO_PROG -F -c 'pwrite 0 48k' -c 'fsync' \
+					$SCRATCH_MNT/buffer >>$seq.full 2>&1 &
+	$XFS_IO_PROG -F -c 'pwrite 0 48k' -d \
+					$SCRATCH_MNT/direct >>$seq.full 2>&1 &
+	$XFS_IO_PROG -F -c 't 48k' -c 'mm -rw 0 48k' -c 'mw 0 48k' -c 'ms -s' \
+					$SCRATCH_MNT/mmap   >>$seq.full 2>&1 &
+	wait
+	echo "--- completed parallel IO ($type)" >>$seq.full
+
+	for file in $SCRATCH_MNT/{buffer,direct,mmap}; do
+		$here/src/lstat64 $file | head -3 | filter_scratch
+	done
+
+	repquota -$type -s -n $SCRATCH_MNT  | grep -v "^#0" | filter_scratch
+}
+
+# real QA test starts here
+rm -f $seq.full
+
+uid=1
+gid=2
+
+umount $SCRATCH_DEV 2>/dev/null
+_scratch_mkfs >> $seq.full 2>&1
+_scratch_mount "-o usrquota,grpquota"
+quotacheck -u -g $SCRATCH_MNT 2>/dev/null
+quotaon $SCRATCH_MNT 2>/dev/null
+umount $SCRATCH_DEV
+
+echo; echo "### test user accounting"
+export MOUNT_OPTIONS="-o usrquota"
+_qmount
+quotaon $SCRATCH_MNT 2>/dev/null
+type=u
+test_files
+test_accounting
+umount $SCRATCH_DEV 2>/dev/null
+
+echo; echo "### test group accounting"
+export MOUNT_OPTIONS="-o grpquota"
+_qmount
+quotaon $SCRATCH_MNT 2>/dev/null
+type=g
+test_files
+test_accounting
+umount $SCRATCH_DEV 2>/dev/null
+
+status=0
+exit
diff --git a/220.out b/220.out
new file mode 100644
index 0000000..57db113
--- /dev/null
+++ b/220.out
@@ -0,0 +1,63 @@
+QA output created by 220
+
+### test user accounting
+
+### create files, setting up ownership (type=u)
+  File: "[SCR_MNT]/buffer"
+  Size: 0            Filetype: Regular File
+  Mode: (0644/-rw-r--r--)         Uid: (1)  Gid: (2)
+  File: "[SCR_MNT]/direct"
+  Size: 0            Filetype: Regular File
+  Mode: (0644/-rw-r--r--)         Uid: (1)  Gid: (2)
+  File: "[SCR_MNT]/mmap"
+  Size: 0            Filetype: Regular File
+  Mode: (0644/-rw-r--r--)         Uid: (1)  Gid: (2)
+### some controlled buffered, direct and mmapd IO (type=u)
+  File: "[SCR_MNT]/buffer"
+  Size: 53248        Filetype: Regular File
+  Mode: (0644/-rw-r--r--)         Uid: (1)  Gid: (2)
+  File: "[SCR_MNT]/direct"
+  Size: 53248        Filetype: Regular File
+  Mode: (0644/-rw-r--r--)         Uid: (1)  Gid: (2)
+  File: "[SCR_MNT]/mmap"
+  Size: 53248        Filetype: Regular File
+  Mode: (0644/-rw-r--r--)         Uid: (1)  Gid: (2)
+*** Report for user quotas on device [SCR_DEV]
+Block grace time: 7days; Inode grace time: 7days
+                        Block limits                File limits
+User            used    soft    hard  grace    used  soft  hard  grace
+----------------------------------------------------------------------
+#1        --     168       0       0              3     0     0       
+
+
+
+### test group accounting
+
+### create files, setting up ownership (type=g)
+  File: "[SCR_MNT]/buffer"
+  Size: 0            Filetype: Regular File
+  Mode: (0644/-rw-r--r--)         Uid: (1)  Gid: (2)
+  File: "[SCR_MNT]/direct"
+  Size: 0            Filetype: Regular File
+  Mode: (0644/-rw-r--r--)         Uid: (1)  Gid: (2)
+  File: "[SCR_MNT]/mmap"
+  Size: 0            Filetype: Regular File
+  Mode: (0644/-rw-r--r--)         Uid: (1)  Gid: (2)
+### some controlled buffered, direct and mmapd IO (type=g)
+  File: "[SCR_MNT]/buffer"
+  Size: 53248        Filetype: Regular File
+  Mode: (0644/-rw-r--r--)         Uid: (1)  Gid: (2)
+  File: "[SCR_MNT]/direct"
+  Size: 53248        Filetype: Regular File
+  Mode: (0644/-rw-r--r--)         Uid: (1)  Gid: (2)
+  File: "[SCR_MNT]/mmap"
+  Size: 53248        Filetype: Regular File
+  Mode: (0644/-rw-r--r--)         Uid: (1)  Gid: (2)
+*** Report for group quotas on device [SCR_DEV]
+Block grace time: 7days; Inode grace time: 7days
+                        Block limits                File limits
+Group           used    soft    hard  grace    used  soft  hard  grace
+----------------------------------------------------------------------
+#2        --     168       0       0              3     0     0       
+
+
diff --git a/common.quota b/common.quota
index a9dfb42..e2a7872 100644
--- a/common.quota
+++ b/common.quota
@@ -21,14 +21,27 @@
 #
 
 #
-# checks that the XFS quota support in the kernel is enabled
+# checks that the generic quota support in the kernel is enabled
 # and that we have valid quota user tools installed.
 #
 _require_quota()
 {
+    [ -x /usr/bin/quota ] || _notrun "Quota user tools not installed"
+    _scratch_mount "-o usrquota,grpquota"
+    ret=$?
+    umount $SCRATCH_MNT
+    [ $ret -ne 0 ] && _notrun "Installed kernel does not support quota"
+}
+
+#
+# checks that the XFS quota support in the kernel is enabled
+# and that we have valid quota user tools installed.
+#
+_require_xfs_quota()
+{
     src/feature -q $TEST_DEV
     [ $? -ne 0 ] && _notrun "Installed kernel does not support XFS quota"
-    [ -x /usr/sbin/xfs_quota ] || _notrun "Quota user tools not installed"
+    [ -x /usr/sbin/xfs_quota ] || _notrun "XFS quota user tools not installed"
 }
 
 #
diff --git a/group b/group
index e068e92..1fc280f 100644
--- a/group
+++ b/group
@@ -328,3 +328,4 @@ prealloc
 217 log metadata auto
 218 auto fsr quick
 219 auto
+220 auto quota

diff --git a/050 b/050
index abb806a..306a7b5 100755
--- a/050
+++ b/050
@@ -55,7 +55,7 @@ cp /dev/null $seq.full
 chmod a+rwx $seq.full	# arbitrary users will write here
 
 _require_scratch
-_require_quota
+_require_xfs_quota
 
 bsoft=100
 bhard=500
diff --git a/052 b/052
index 16c78de..3d8bb9e 100755
--- a/052
+++ b/052
@@ -54,7 +54,7 @@ _supported_os IRIX Linux
 rm -f $seq.full
 
 _require_scratch
-_require_quota
+_require_xfs_quota
 _require_nobody
 
 # setup a default run
diff --git a/054 b/054
index b495e51..b38efab 100755
--- a/054
+++ b/054
@@ -52,7 +52,7 @@ cp /dev/null $seq.full
 chmod ugo+rwx $seq.full
 
 _require_scratch
-_require_quota
+_require_xfs_quota
 
 _filter_stat()
 {
diff --git a/081 b/081
index 3036484..c8eba80 100755
--- a/081
+++ b/081
@@ -54,7 +54,7 @@ trap "_cleanup; exit \$status" 0 1 2 3 15
 # prelim
 rm -f $seq.full $tmp.*
 _require_scratch
-_require_quota
+_require_xfs_quota
 _require_v2log
  
 echo "*** init FS"
diff --git a/106 b/106
index 7154979..30f740b 100755
--- a/106
+++ b/106
@@ -42,7 +42,7 @@ trap "rm -f $tmp.*; exit \$status" 0 1 2 3 15
 _supported_fs xfs
 _supported_os Linux #IRIX
 _require_scratch
-_require_quota
+_require_xfs_quota
 _require_prjquota
 
 # real QA test starts here
diff --git a/107 b/107
index cfa8213..f36dc21 100755
--- a/107
+++ b/107
@@ -54,7 +54,7 @@ s/Inode: \#\d+ \(\d+ blocks, \d+ extents\)/Inode: #[INO] (X blocks, Y extents)/;
 _supported_fs xfs
 _supported_os Linux #IRIX
 _require_scratch
-_require_quota
+_require_xfs_quota
 _require_prjquota
 
 # real QA test starts here
diff --git a/108 b/108
index 3f3e1fb..3a1fee9 100755
--- a/108
+++ b/108
@@ -49,7 +49,7 @@ s,$SCRATCH_DEV,[SCR_DEV],;
 _supported_fs xfs
 _supported_os Linux #IRIX
 _require_scratch
-_require_quota
+_require_xfs_quota
 _require_prjquota
 
 test_files()
diff --git a/116 b/116
index 8394054..e902ce9 100755
--- a/116
+++ b/116
@@ -51,7 +51,7 @@ _supported_fs xfs
 _supported_os IRIX Linux
 
 _require_scratch
-_require_quota
+_require_xfs_quota
 
 mkfs.xfs -f $SCRATCH_DEV >/dev/null 2>&1
 mount -o uquota $SCRATCH_DEV $SCRATCH_MNT
diff --git a/118 b/118
index 6b28055..cb0e5ee 100755
--- a/118
+++ b/118
@@ -52,7 +52,7 @@ _supported_fs xfs
 _supported_os IRIX Linux
 
 _require_scratch
-_require_quota
+_require_xfs_quota
 
 _chowning_file()
 {
diff --git a/134 b/134
index fc2ab74..f00e1f0 100755
--- a/134
+++ b/134
@@ -50,7 +50,7 @@ _cleanup()
 _supported_fs xfs
 _supported_os Linux IRIX
 
-_require_quota
+_require_xfs_quota
 
 dir=$SCRATCH_MNT/project
 
diff --git a/196 b/196
index 7768618..5da3659 100755
--- a/196
+++ b/196
@@ -51,7 +51,7 @@ _supported_fs xfs
 _supported_os Linux
 
 _require_scratch
-_require_quota
+_require_xfs_quota
 
 #
 # Setup temporary replacements for /etc/projects and /etc/projid



^ permalink raw reply related	[flat|nested] 5+ messages in thread

* Re: [PATCH] xfstests: 220 - generic quota sanity
  2009-08-07 19:10 [PATCH] xfstests: 220 - generic quota sanity Eric Sandeen
@ 2009-08-10  5:13 ` Lachlan McIlroy
  2009-08-10 14:05   ` Eric Sandeen
  0 siblings, 1 reply; 5+ messages in thread
From: Lachlan McIlroy @ 2009-08-10  5:13 UTC (permalink / raw)
  To: Eric Sandeen; +Cc: xfs-oss, ext4 development

This looks good Eric.

Is this test just for quota accounting or should it be testing quota
enforcement too?

Lachlan

----- "Eric Sandeen" <sandeen@redhat.com> wrote:

> Add some very basic quota sanity tests for generic filesystems.
> 
> This is based on test 108, but uses the generic quota tools,
> not xfs_quota, and therefore cannot test project quota.
> 
> Also, the IOs are much smaller (48k) so that ext3 won't get into
> indirect blocks and throw off the accounting.  This does
> assume 4k blocks though.
> 
> Signed-off-by: Eric Sandeen <sandeen@redhat.com>
> ---
> 
> diff --git a/220 b/220
> new file mode 100755
> index 0000000..3b828cb
> --- /dev/null
> +++ b/220
> @@ -0,0 +1,123 @@
> +#! /bin/sh
> +# FS QA Test No. 220
> +#
> +# Simple quota accounting test for direct/buffered/mmap IO.
> +#
> +#-----------------------------------------------------------------------
> +# Copyright (c) 2009 Eric Sandeen.  All Rights Reserved.
> +#
> +# Based on test 108,
> +# Copyright (c) 2005 Silicon Graphics, Inc.  All Rights Reserved.
> +#
> +# This program is free software; you can redistribute it and/or
> +# modify it under the terms of the GNU General Public License as
> +# published by the Free Software Foundation.
> +#
> +# This program is distributed in the hope that it would be useful,
> +# but WITHOUT ANY WARRANTY; without even the implied warranty of
> +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
> +# GNU General Public License for more details.
> +#
> +# You should have received a copy of the GNU General Public License
> +# along with this program; if not, write the Free Software
> Foundation,
> +# Inc.,  51 Franklin St, Fifth Floor, Boston, MA  02110-1301  USA
> +#
> +#-----------------------------------------------------------------------
> +#
> +# creator
> +owner=sandeen@sandeen.net
> +
> +seq=`basename $0`
> +echo "QA output created by $seq"
> +
> +here=`pwd`
> +tmp=/tmp/$$
> +status=1	# failure is the default!
> +trap "rm -f $tmp.*; exit \$status" 0 1 2 3 15
> +
> +# get standard environment, filters and checks
> +. ./common.rc
> +. ./common.filter
> +. ./common.quota
> +
> +filter_scratch()
> +{
> +	perl -ne "
> +s,$SCRATCH_MNT,[SCR_MNT],;
> +s,$SCRATCH_DEV,[SCR_DEV],;
> +	print;"
> +}
> +
> +# real QA test starts here
> +_supported_fs generic
> +_supported_os Linux #IRIX
> +_require_scratch
> +_require_quota
> +
> +test_files()
> +{
> +	echo; echo "### create files, setting up ownership (type=$type)"
> +	rm -f $SCRATCH_MNT/{buffer,direct,mmap}
> +	touch $SCRATCH_MNT/{buffer,direct,mmap}
> +	chown $uid $SCRATCH_MNT/{buffer,direct,mmap}
> +	chgrp $gid $SCRATCH_MNT/{buffer,direct,mmap}
> +	for file in $SCRATCH_MNT/{buffer,direct,mmap}; do
> +		$here/src/lstat64 $file | head -3 | filter_scratch
> +	done
> +}
> +
> +test_accounting()
> +{
> +	echo "### some controlled buffered, direct and mmapd IO
> (type=$type)"
> +	echo "--- initiating parallel IO..." >>$seq.full
> +	# Small ios here because ext3 will account for indirect blocks too
> ...   :( 
> +	# 48k will fit w/o indirect for 4k blocks (default blocksize)
> +	$XFS_IO_PROG -F -c 'pwrite 0 48k' -c 'fsync' \
> +					$SCRATCH_MNT/buffer >>$seq.full 2>&1 &
> +	$XFS_IO_PROG -F -c 'pwrite 0 48k' -d \
> +					$SCRATCH_MNT/direct >>$seq.full 2>&1 &
> +	$XFS_IO_PROG -F -c 't 48k' -c 'mm -rw 0 48k' -c 'mw 0 48k' -c 'ms
> -s' \
> +					$SCRATCH_MNT/mmap   >>$seq.full 2>&1 &
> +	wait
> +	echo "--- completed parallel IO ($type)" >>$seq.full
> +
> +	for file in $SCRATCH_MNT/{buffer,direct,mmap}; do
> +		$here/src/lstat64 $file | head -3 | filter_scratch
> +	done
> +
> +	repquota -$type -s -n $SCRATCH_MNT  | grep -v "^#0" |
> filter_scratch
> +}
> +
> +# real QA test starts here
> +rm -f $seq.full
> +
> +uid=1
> +gid=2
> +
> +umount $SCRATCH_DEV 2>/dev/null
> +_scratch_mkfs >> $seq.full 2>&1
> +_scratch_mount "-o usrquota,grpquota"
> +quotacheck -u -g $SCRATCH_MNT 2>/dev/null
> +quotaon $SCRATCH_MNT 2>/dev/null
> +umount $SCRATCH_DEV
> +
> +echo; echo "### test user accounting"
> +export MOUNT_OPTIONS="-o usrquota"
> +_qmount
> +quotaon $SCRATCH_MNT 2>/dev/null
> +type=u
> +test_files
> +test_accounting
> +umount $SCRATCH_DEV 2>/dev/null
> +
> +echo; echo "### test group accounting"
> +export MOUNT_OPTIONS="-o grpquota"
> +_qmount
> +quotaon $SCRATCH_MNT 2>/dev/null
> +type=g
> +test_files
> +test_accounting
> +umount $SCRATCH_DEV 2>/dev/null
> +
> +status=0
> +exit
> diff --git a/220.out b/220.out
> new file mode 100644
> index 0000000..57db113
> --- /dev/null
> +++ b/220.out
> @@ -0,0 +1,63 @@
> +QA output created by 220
> +
> +### test user accounting
> +
> +### create files, setting up ownership (type=u)
> +  File: "[SCR_MNT]/buffer"
> +  Size: 0            Filetype: Regular File
> +  Mode: (0644/-rw-r--r--)         Uid: (1)  Gid: (2)
> +  File: "[SCR_MNT]/direct"
> +  Size: 0            Filetype: Regular File
> +  Mode: (0644/-rw-r--r--)         Uid: (1)  Gid: (2)
> +  File: "[SCR_MNT]/mmap"
> +  Size: 0            Filetype: Regular File
> +  Mode: (0644/-rw-r--r--)         Uid: (1)  Gid: (2)
> +### some controlled buffered, direct and mmapd IO (type=u)
> +  File: "[SCR_MNT]/buffer"
> +  Size: 53248        Filetype: Regular File
> +  Mode: (0644/-rw-r--r--)         Uid: (1)  Gid: (2)
> +  File: "[SCR_MNT]/direct"
> +  Size: 53248        Filetype: Regular File
> +  Mode: (0644/-rw-r--r--)         Uid: (1)  Gid: (2)
> +  File: "[SCR_MNT]/mmap"
> +  Size: 53248        Filetype: Regular File
> +  Mode: (0644/-rw-r--r--)         Uid: (1)  Gid: (2)
> +*** Report for user quotas on device [SCR_DEV]
> +Block grace time: 7days; Inode grace time: 7days
> +                        Block limits                File limits
> +User            used    soft    hard  grace    used  soft  hard 
> grace
> +----------------------------------------------------------------------
> +#1        --     168       0       0              3     0     0      
> 
> +
> +
> +
> +### test group accounting
> +
> +### create files, setting up ownership (type=g)
> +  File: "[SCR_MNT]/buffer"
> +  Size: 0            Filetype: Regular File
> +  Mode: (0644/-rw-r--r--)         Uid: (1)  Gid: (2)
> +  File: "[SCR_MNT]/direct"
> +  Size: 0            Filetype: Regular File
> +  Mode: (0644/-rw-r--r--)         Uid: (1)  Gid: (2)
> +  File: "[SCR_MNT]/mmap"
> +  Size: 0            Filetype: Regular File
> +  Mode: (0644/-rw-r--r--)         Uid: (1)  Gid: (2)
> +### some controlled buffered, direct and mmapd IO (type=g)
> +  File: "[SCR_MNT]/buffer"
> +  Size: 53248        Filetype: Regular File
> +  Mode: (0644/-rw-r--r--)         Uid: (1)  Gid: (2)
> +  File: "[SCR_MNT]/direct"
> +  Size: 53248        Filetype: Regular File
> +  Mode: (0644/-rw-r--r--)         Uid: (1)  Gid: (2)
> +  File: "[SCR_MNT]/mmap"
> +  Size: 53248        Filetype: Regular File
> +  Mode: (0644/-rw-r--r--)         Uid: (1)  Gid: (2)
> +*** Report for group quotas on device [SCR_DEV]
> +Block grace time: 7days; Inode grace time: 7days
> +                        Block limits                File limits
> +Group           used    soft    hard  grace    used  soft  hard 
> grace
> +----------------------------------------------------------------------
> +#2        --     168       0       0              3     0     0      
> 
> +
> +
> diff --git a/common.quota b/common.quota
> index a9dfb42..e2a7872 100644
> --- a/common.quota
> +++ b/common.quota
> @@ -21,14 +21,27 @@
>  #
>  
>  #
> -# checks that the XFS quota support in the kernel is enabled
> +# checks that the generic quota support in the kernel is enabled
>  # and that we have valid quota user tools installed.
>  #
>  _require_quota()
>  {
> +    [ -x /usr/bin/quota ] || _notrun "Quota user tools not
> installed"
> +    _scratch_mount "-o usrquota,grpquota"
> +    ret=$?
> +    umount $SCRATCH_MNT
> +    [ $ret -ne 0 ] && _notrun "Installed kernel does not support
> quota"
> +}
> +
> +#
> +# checks that the XFS quota support in the kernel is enabled
> +# and that we have valid quota user tools installed.
> +#
> +_require_xfs_quota()
> +{
>      src/feature -q $TEST_DEV
>      [ $? -ne 0 ] && _notrun "Installed kernel does not support XFS
> quota"
> -    [ -x /usr/sbin/xfs_quota ] || _notrun "Quota user tools not
> installed"
> +    [ -x /usr/sbin/xfs_quota ] || _notrun "XFS quota user tools not
> installed"
>  }
>  
>  #
> diff --git a/group b/group
> index e068e92..1fc280f 100644
> --- a/group
> +++ b/group
> @@ -328,3 +328,4 @@ prealloc
>  217 log metadata auto
>  218 auto fsr quick
>  219 auto
> +220 auto quota
> 
> diff --git a/050 b/050
> index abb806a..306a7b5 100755
> --- a/050
> +++ b/050
> @@ -55,7 +55,7 @@ cp /dev/null $seq.full
>  chmod a+rwx $seq.full	# arbitrary users will write here
>  
>  _require_scratch
> -_require_quota
> +_require_xfs_quota
>  
>  bsoft=100
>  bhard=500
> diff --git a/052 b/052
> index 16c78de..3d8bb9e 100755
> --- a/052
> +++ b/052
> @@ -54,7 +54,7 @@ _supported_os IRIX Linux
>  rm -f $seq.full
>  
>  _require_scratch
> -_require_quota
> +_require_xfs_quota
>  _require_nobody
>  
>  # setup a default run
> diff --git a/054 b/054
> index b495e51..b38efab 100755
> --- a/054
> +++ b/054
> @@ -52,7 +52,7 @@ cp /dev/null $seq.full
>  chmod ugo+rwx $seq.full
>  
>  _require_scratch
> -_require_quota
> +_require_xfs_quota
>  
>  _filter_stat()
>  {
> diff --git a/081 b/081
> index 3036484..c8eba80 100755
> --- a/081
> +++ b/081
> @@ -54,7 +54,7 @@ trap "_cleanup; exit \$status" 0 1 2 3 15
>  # prelim
>  rm -f $seq.full $tmp.*
>  _require_scratch
> -_require_quota
> +_require_xfs_quota
>  _require_v2log
>   
>  echo "*** init FS"
> diff --git a/106 b/106
> index 7154979..30f740b 100755
> --- a/106
> +++ b/106
> @@ -42,7 +42,7 @@ trap "rm -f $tmp.*; exit \$status" 0 1 2 3 15
>  _supported_fs xfs
>  _supported_os Linux #IRIX
>  _require_scratch
> -_require_quota
> +_require_xfs_quota
>  _require_prjquota
>  
>  # real QA test starts here
> diff --git a/107 b/107
> index cfa8213..f36dc21 100755
> --- a/107
> +++ b/107
> @@ -54,7 +54,7 @@ s/Inode: \#\d+ \(\d+ blocks, \d+ extents\)/Inode:
> #[INO] (X blocks, Y extents)/;
>  _supported_fs xfs
>  _supported_os Linux #IRIX
>  _require_scratch
> -_require_quota
> +_require_xfs_quota
>  _require_prjquota
>  
>  # real QA test starts here
> diff --git a/108 b/108
> index 3f3e1fb..3a1fee9 100755
> --- a/108
> +++ b/108
> @@ -49,7 +49,7 @@ s,$SCRATCH_DEV,[SCR_DEV],;
>  _supported_fs xfs
>  _supported_os Linux #IRIX
>  _require_scratch
> -_require_quota
> +_require_xfs_quota
>  _require_prjquota
>  
>  test_files()
> diff --git a/116 b/116
> index 8394054..e902ce9 100755
> --- a/116
> +++ b/116
> @@ -51,7 +51,7 @@ _supported_fs xfs
>  _supported_os IRIX Linux
>  
>  _require_scratch
> -_require_quota
> +_require_xfs_quota
>  
>  mkfs.xfs -f $SCRATCH_DEV >/dev/null 2>&1
>  mount -o uquota $SCRATCH_DEV $SCRATCH_MNT
> diff --git a/118 b/118
> index 6b28055..cb0e5ee 100755
> --- a/118
> +++ b/118
> @@ -52,7 +52,7 @@ _supported_fs xfs
>  _supported_os IRIX Linux
>  
>  _require_scratch
> -_require_quota
> +_require_xfs_quota
>  
>  _chowning_file()
>  {
> diff --git a/134 b/134
> index fc2ab74..f00e1f0 100755
> --- a/134
> +++ b/134
> @@ -50,7 +50,7 @@ _cleanup()
>  _supported_fs xfs
>  _supported_os Linux IRIX
>  
> -_require_quota
> +_require_xfs_quota
>  
>  dir=$SCRATCH_MNT/project
>  
> diff --git a/196 b/196
> index 7768618..5da3659 100755
> --- a/196
> +++ b/196
> @@ -51,7 +51,7 @@ _supported_fs xfs
>  _supported_os Linux
>  
>  _require_scratch
> -_require_quota
> +_require_xfs_quota
>  
>  #
>  # Setup temporary replacements for /etc/projects and /etc/projid
> 
> 
> _______________________________________________
> xfs mailing list
> xfs@oss.sgi.com
> http://oss.sgi.com/mailman/listinfo/xfs

^ permalink raw reply	[flat|nested] 5+ messages in thread

* Re: [PATCH] xfstests: 220 - generic quota sanity
  2009-08-10  5:13 ` Lachlan McIlroy
@ 2009-08-10 14:05   ` Eric Sandeen
  2009-08-10 16:09     ` Christoph Hellwig
  0 siblings, 1 reply; 5+ messages in thread
From: Eric Sandeen @ 2009-08-10 14:05 UTC (permalink / raw)
  To: Lachlan McIlroy; +Cc: Eric Sandeen, ext4 development, xfs-oss

Lachlan McIlroy wrote:
> This looks good Eric.
> 
> Is this test just for quota accounting or should it be testing quota
> enforcement too?

I guess 108 just did accounting; I was going to keep it parallel, and do
a different one for accounting, but it could be added to this as well.

-Eric

> Lachlan
> 
> ----- "Eric Sandeen" <sandeen@redhat.com> wrote:
> 
>> Add some very basic quota sanity tests for generic filesystems.
>>
>> This is based on test 108, but uses the generic quota tools,
>> not xfs_quota, and therefore cannot test project quota.
>>
>> Also, the IOs are much smaller (48k) so that ext3 won't get into
>> indirect blocks and throw off the accounting.  This does
>> assume 4k blocks though.
>>
>> Signed-off-by: Eric Sandeen <sandeen@redhat.com>
>> ---

...

^ permalink raw reply	[flat|nested] 5+ messages in thread

* Re: [PATCH] xfstests: 220 - generic quota sanity
  2009-08-10 14:05   ` Eric Sandeen
@ 2009-08-10 16:09     ` Christoph Hellwig
  2009-08-11  1:59       ` Lachlan McIlroy
  0 siblings, 1 reply; 5+ messages in thread
From: Christoph Hellwig @ 2009-08-10 16:09 UTC (permalink / raw)
  To: Eric Sandeen; +Cc: Lachlan McIlroy, Eric Sandeen, ext4 development, xfs-oss

On Mon, Aug 10, 2009 at 09:05:17AM -0500, Eric Sandeen wrote:
> Lachlan McIlroy wrote:
> > This looks good Eric.
> > 
> > Is this test just for quota accounting or should it be testing quota
> > enforcement too?
> 
> I guess 108 just did accounting; I was going to keep it parallel, and do
> a different one for accounting, but it could be added to this as well.

Yeah, let's use a different one for enforement testing.


^ permalink raw reply	[flat|nested] 5+ messages in thread

* Re: [PATCH] xfstests: 220 - generic quota sanity
  2009-08-10 16:09     ` Christoph Hellwig
@ 2009-08-11  1:59       ` Lachlan McIlroy
  0 siblings, 0 replies; 5+ messages in thread
From: Lachlan McIlroy @ 2009-08-11  1:59 UTC (permalink / raw)
  To: Christoph Hellwig; +Cc: Eric Sandeen, ext4 development, xfs-oss, Eric Sandeen

----- "Christoph Hellwig" <hch@infradead.org> wrote:

> On Mon, Aug 10, 2009 at 09:05:17AM -0500, Eric Sandeen wrote:
> > Lachlan McIlroy wrote:
> > > This looks good Eric.
> > > 
> > > Is this test just for quota accounting or should it be testing
> quota
> > > enforcement too?
> > 
> > I guess 108 just did accounting; I was going to keep it parallel,
> and do
> > a different one for accounting, but it could be added to this as
> well.
> 
> Yeah, let's use a different one for enforement testing.

Agree, if quota enforcement isn't working correctly then the accounting
is the first thing to check so having seperate tests is a good idea.

^ permalink raw reply	[flat|nested] 5+ messages in thread

end of thread, other threads:[~2009-08-11  2:00 UTC | newest]

Thread overview: 5+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2009-08-07 19:10 [PATCH] xfstests: 220 - generic quota sanity Eric Sandeen
2009-08-10  5:13 ` Lachlan McIlroy
2009-08-10 14:05   ` Eric Sandeen
2009-08-10 16:09     ` Christoph Hellwig
2009-08-11  1:59       ` Lachlan McIlroy

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).