Source-Changes-HG archive

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]

[src/bouyer-quota2]: src/tests/fs/ffs Test clearing of quota entries



details:   https://anonhg.NetBSD.org/src/rev/0fb5bc21c1cd
branches:  bouyer-quota2
changeset: 761115:0fb5bc21c1cd
user:      bouyer <bouyer%NetBSD.org@localhost>
date:      Mon Feb 07 20:31:46 2011 +0000

description:
Test clearing of quota entries

diffstat:

 tests/fs/ffs/Makefile        |   4 +-
 tests/fs/ffs/t_clearquota.sh |  91 ++++++++++++++++++++++++++++++++++++++++++++
 2 files changed, 93 insertions(+), 2 deletions(-)

diffs (113 lines):

diff -r ee6ed446fa91 -r 0fb5bc21c1cd tests/fs/ffs/Makefile
--- a/tests/fs/ffs/Makefile     Mon Feb 07 20:31:20 2011 +0000
+++ b/tests/fs/ffs/Makefile     Mon Feb 07 20:31:46 2011 +0000
@@ -1,4 +1,4 @@
-#      $NetBSD: Makefile,v 1.14.2.4 2011/02/02 19:17:08 bouyer Exp $
+#      $NetBSD: Makefile,v 1.14.2.5 2011/02/07 20:31:46 bouyer Exp $
 #
 
 .include <bsd.own.mk>
@@ -17,7 +17,7 @@
 MAN.h_quota2_tests=    # empty
 BINDIR.h_quota2_tests= ${TESTSDIR}
 
-.for name in t_getquota t_setquota t_quotalimit
+.for name in t_getquota t_setquota t_quotalimit t_clearquota
 TESTS_SH+=     ${name}
 TESTS_SH_SRC_${name}=  quotas_common.sh ${name}.sh
 .endfor
diff -r ee6ed446fa91 -r 0fb5bc21c1cd tests/fs/ffs/t_clearquota.sh
--- /dev/null   Thu Jan 01 00:00:00 1970 +0000
+++ b/tests/fs/ffs/t_clearquota.sh      Mon Feb 07 20:31:46 2011 +0000
@@ -0,0 +1,91 @@
+# $NetBSD: t_clearquota.sh,v 1.1.2.1 2011/02/07 20:31:46 bouyer Exp $ 
+#
+#  Copyright (c) 2011 Manuel Bouyer
+#  All rights reserved.
+# 
+#  Redistribution and use in source and binary forms, with or without
+#  modification, are permitted provided that the following conditions
+#  are met:
+#  1. Redistributions of source code must retain the above copyright
+#     notice, this list of conditions and the following disclaimer.
+#  2. Redistributions in binary form must reproduce the above copyright
+#     notice, this list of conditions and the following disclaimer in the
+#     documentation and/or other materials provided with the distribution.
+# 
+#  THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS
+#  ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
+#  TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
+#  PURPOSE ARE DISCLAIMED.  IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS
+#  BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
+#  CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
+#  SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
+#  INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
+#  CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
+#  ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
+#  POSSIBILITY OF SUCH DAMAGE.
+#
+
+for e in le be; do
+  for v in 1 2; do
+    for q in "user" "group"; do
+      test_case_root clear_${e}_${v}_${q} clear_quota \
+        "clear quota with ${q} enabled" -b ${e} ${v} ${q}
+    done
+    test_case_root clear_${e}_${v}_"both" clear_quota \
+        "clear quota with both enabled" -b ${e} ${v} "both"
+    test_case_root clear_${e}_${v}_"both_log" clear_quota \
+        "clear quota for new id with both enabled, WAPBL" -bl ${e} ${v} "both"
+  done
+done
+
+clear_quota()
+{
+       create_with_quotas_server $*
+       local q=$4
+       local expect
+       local fail
+       local id=1
+
+       case ${q} in
+       user)
+               expect=u
+               fail=g
+               ;;
+       group)
+               expect=g
+               fail=u
+               ;;
+       both)
+               expect="u g"
+               fail=""
+               ;;
+       *)
+               atf_fail "wrong quota type"
+               ;;
+       esac
+
+#set and check the expected quota
+       for q in ${expect} ; do
+               atf_check -s exit:0 \
+                  $(atf_get_srcdir)/rump_edquota -$q -s10k/20 -h40M/50k \
+                  -t 2W/3D ${id}
+               atf_check -s exit:0 \
+-o "match:/mnt        0       10    40960  2weeks       0      20   51200   3days" \
+-o "match:Disk quotas for .*: $" \
+                   $(atf_get_srcdir)/rump_quota -${q} -v ${id}
+       done
+#now clear the quotas
+       for q in ${expect} ; do
+               atf_check -s exit:0 \
+                  $(atf_get_srcdir)/rump_edquota -$q -c ${id}
+       done;
+
+#check that we do not get positive reply for any quota type
+       for q in u g ; do
+               atf_check -s exit:0 -o "not-match:/mnt" \
+                   -o "not-match:Disk quotas for .*: $" \
+                   -o "match:Disk quotas for .*: none$" \
+                   $(atf_get_srcdir)/rump_quota -${q} -v ${id}
+       done
+       rump_shutdown
+}



Home | Main Index | Thread Index | Old Index