# Run test by setting NOSETUP=true when ltest has setup env for us
set -e
-#kernel 2.4.x doesn't support quota
-K_VER=`uname --kernel-release | cut -b 1-3`
-if [ $K_VER = "2.4" ]; then
- echo "Kernel 2.4 doesn't support quota"
- exit 0
-fi
-
SRCDIR=`dirname $0`
export PATH=$PWD/$SRCDIR:$SRCDIR:$PWD/$SRCDIR/../utils:$PATH:/sbin
+if [ "$USE_OFD" = "yes" -a -z "$ONLY" ]; then
+ # only accounting tests are supported with OFD for the time being
+ ONLY="33 34 35"
+fi
+
ONLY=${ONLY:-"$*"}
# test_11 has been used to protect a kernel bug(bz10912), now it isn't
# useful any more. Then add it to ALWAYS_EXCEPT. b=19835
ALWAYS_EXCEPT="10 12 $SANITY_QUOTA_EXCEPT"
# UPDATE THE COMMENT ABOVE WITH BUG NUMBERS WHEN CHANGING ALWAYS_EXCEPT!
-case `uname -r` in
-2.6*) FSTYPE=${FSTYPE:-ldiskfs};;
-*) error "unsupported kernel" ;;
-esac
-
[ "$ALWAYS_EXCEPT$EXCEPT" ] && \
echo "Skipping tests: `echo $ALWAYS_EXCEPT $EXCEPT`"
quota15_19 quota15_20 quota15_21 quota15_22 quota15_23 quota15_24 \
quota15_25 quota15_26 quota15_27 quota15_28 quota15_29 quota15_30"
+export MULTIOP=${MULTIOP:-multiop}
TRACE=${TRACE:-""}
LUSTRE=${LUSTRE:-`dirname $0`/..}
. $LUSTRE/tests/test-framework.sh
build_test_filter
+if [ "$USE_OFD" = "yes" ]; then
+ for num in `seq $OSTCOUNT`; do
+ if [ $(facet_fstype ost$num) = ldiskfs ]; then
+ # not the most efficient way to enable the quota feature
+ # on ost, but it still allows us to test ofd accounting
+ # for now
+ device=$(ostdevname $num)
+ stop ost$num
+ do_facet ost$num "$TUNE2FS -O quota $device"
+ [ ${PIPESTATUS[0]} -ne 0] && \
+ error "failed to enable quota feature for ost$num"
+ start ost$num $device $OST_MOUNT_OPTS
+ fi
+ done
+fi
+
# set_blk_tunables(btune_sz)
set_blk_tunesz() {
local btune=$(($1 * BLK_SZ))
# set quota
quota_init() {
- $LFS quotacheck -ug $DIR
+ do_nodes $(comma_list $(nodes_list)) "lctl set_param debug=+quota"
- resetquota -u $TSTUSR
- resetquota -g $TSTUSR
+ log "do the quotacheck ..."
+ $LFS quotacheck -ug $DIR
- do_nodes $(comma_list $(nodes_list)) "lctl set_param debug=+quota"
+ resetquota -u $TSTUSR
+ resetquota -g $TSTUSR
}
quota_init
# inode->i_blkbits = min(PTLRPC_MAX_BRW_BITS+1, LL_MAX_BLKSIZE_BITS);
blksize=$((1 << 21)) # 2Mb
size_file=$((GB * 9 / 2))
-# this check is just for test9 and test10
+# this check is just for test_9
OST0_MIN=4900000 #4.67G
check_whether_skip () {
OST0_SIZE=`$LFS df $DIR | awk '/\[OST:0\]/ {print $4}'`
quota_show_check a g $TSTUSR
echo " Set stripe"
- $LFS setstripe $TESTFILE -c 1
+ $LFS setstripe $TESTFILE -c 1 -i 0
touch $TESTFILE
chown $TSTUSR.$TSTUSR $TESTFILE
$LFS setquota -u root -b 10 -B 10 -i 10 -I 10 $DIR
createmany -m ${TESTFILE} 20 || \
quota_error u root "unexpected: user(root) create files failly!"
- dd if=/dev/zero of=$TESTFILE bs=4k count=4096 || \
+ $MULTIOP ${TESTFILE} oO_CREAT:O_WRONLY:O_DIRECT:w$((4096 * 4096))c || \
quota_error u root "unexpected: user(root) write files failly!"
chmod 666 $TESTFILE
- $RUNAS dd if=/dev/zero of=${TESTFILE} seek=4096 bs=4k count=4096 && \
+ $RUNAS $MULTIOP ${TESTFILE} oO_WRONLY:O_APPEND:O_DIRECT:w$((4096 * 4096))c && \
quota_error u root "unexpected: user(quota_usr) write a file successfully!"
# trigger the llog
sleep 3
quota_show_check b u $TSTUSR
- $LFS setstripe $TESTFILE -c 1
+ $LFS setstripe $TESTFILE -c 1 -i 0
chown $TSTUSR.$TSTUSR $TESTFILE
log " Step1: trigger quota with 0_DIRECT"
}
test_23() {
- log "run for $((OSTCOUNT * 4))MB test file"
- test_23_sub $((OSTCOUNT * 4 * 1024))
+ local slave_cnt=$((OSTCOUNT + 1)) # 1 mds, n osts
- OST0_MIN=120000
+ OST0_MIN=$((6 * $slave_cnt * 1024)) # extra space for meta blocks.
check_whether_skip && return 0
- log "run for $((OSTCOUNT * 40))MB test file"
- test_23_sub $((OSTCOUNT * 40 * 1024))
+ log "run for $((4 * $slave_cnt))MB test file"
+ test_23_sub $((4 * $slave_cnt * 1024))
+
+ OST0_MIN=$((60 * $slave_cnt * 1024)) # extra space for meta blocks.
+ check_whether_skip && return 0
+ log "run for $((40 * $slave_cnt))MB test file"
+ test_23_sub $((40 * $slave_cnt * 1024))
}
run_test_with_stat 23 "run for fixing bug16125 ==========="
timeout=$(lctl get_param -n timeout)
lctl set_param timeout=10
fi
+ # actually send a RPC to make service at_current confined within at_max
+ $LFS setquota -u $TSTUSR -b 0 -B $BLK_LIMIT -i 0 -I 0 $DIR || error "should succeed"
#define OBD_FAIL_MDS_QUOTACTL_NET 0x12e
lustre_fail mds 0x12e
$LFS setquota -u $TSTUSR -b 0 -B $BLK_LIMIT -i 0 -I 0 $DIR & pid=$!
- echo "sleeping for $((10 * 2)) seconds"
- sleep $((10 * 2))
+ echo "sleeping for 10 * 1.25 + 5 + 10 seconds"
+ sleep 28
ps -p $pid && error "lfs hadn't finished by timeout"
wait $pid && error "succeeded, but should have failed"
}
run_test 32 "check lqs hash(bug 21846) =========================================="
+cleanup_quota_test() {
+ trap 0
+ echo "Delete files..."
+ rm -rf $DIR/$tdir
+}
+
+# basic usage tracking for user & group
+test_33() {
+ mkdir -p $DIR/$tdir
+ chmod 0777 $DIR/$tdir
+ INODES=10
+ BLK_CNT=1024
+ TOTAL_BLKS=$(($INODES * $BLK_CNT))
+
+ trap cleanup_quota_test EXIT
+
+ # make sure the system is clean
+ USED=`getquota -u $TSTID global curspace`
+ [ $USED -ne 0 ] && \
+ error "Used space ($USED) for user $TSTID isn't 0."
+ USED=`getquota -g $TSTID global curspace`
+ [ $USED -ne 0 ] && \
+ error "Used space ($USED) for group $TSTID isn't 0."
+
+ for i in `seq 0 $INODES`; do
+ $RUNAS dd if=/dev/zero of=$DIR/$tdir/$tfile-$i conv=fsync \
+ bs=$((BLK_SZ * BLK_CNT)) count=1 2>/dev/null ||
+ error "write failed"
+ echo "Iteration $i/$INODES completed"
+ done
+ sync; sync_all_data;
+
+ echo "Verify disk usage after write"
+ USED=`getquota -u $TSTID global curspace`
+ [ $USED -lt $TOTAL_BLKS ] && \
+ error "Used space for user $TSTID is $USED, expected $TOTAL_BLKS"
+ USED=`getquota -u $TSTID global curinodes`
+ [ $USED -lt $INODES ] && \
+ error "Used inode for user $TSTID is $USED, expected $INODES"
+
+ USED=`getquota -g $TSTID global curspace`
+ [ $USED -lt $TOTAL_BLKS ] && \
+ error "Used space for group $TSTID is $USED, expected $TOTAL_BLKS"
+ USED=`getquota -g $TSTID global curinodes`
+ [ $USED -lt $INODES ] && \
+ error "Used inode for group $TSTID is $USED, expected $INODES"
+
+ cleanup_quota_test
+
+ echo "Verify disk usage after delete"
+ wait_delete_completed
+ USED=`getquota -u $TSTID global curspace`
+ [ $USED -eq 0 ] || error "Used space for user $TSTID isn't 0. $USED"
+ USED=`getquota -u $TSTID global curinodes`
+ [ $USED -eq 0 ] || error "Used inodes for user $TSTID isn't 0. $USED"
+ USED=`getquota -g $TSTID global curspace`
+ [ $USED -eq 0 ] || error "Used space for group $TSTID isn't 0. $USED"
+ USED=`getquota -g $TSTID global curinodes`
+ [ $USED -eq 0 ] || error "Used inodes for group $TSTID isn't 0. $USED"
+}
+run_test 33 "basic usage tracking for user & group =============================="
+
+# usage transfer test for user & group
+test_34() {
+ BLK_CNT=1024
+ mkdir -p $DIR/$tdir
+ chmod 0777 $DIR/$tdir
+
+ trap cleanup_quota_test EXIT
+
+ # make sure the system is clean
+ USED=`getquota -u $TSTID global curspace`
+ [ $USED -ne 0 ] && error "Used space ($USED) for user $TSTID isn't 0."
+ USED=`getquota -g $TSTID global curspace`
+ [ $USED -ne 0 ] && error "Used space ($USED) for group $TSTID isn't 0."
+
+ echo "Write file..."
+ dd if=/dev/zero of=$DIR/$tdir/$tfile bs=$((BLK_SZ * BLK_CNT)) count=1 \
+ conv=fsync 2>/dev/null || error "write failed"
+ sync; sync_all_data;
+
+ echo "chown the file to user $TSTID"
+ chown $TSTID $DIR/$tdir/$tfile || error "chown failed"
+
+ echo "Wait for setattr on objects finished..."
+ wait_delete_completed
+
+ echo "Verify disk usage for user $TSTID"
+ USED=`getquota -u $TSTID global curspace`
+ [ $USED -lt $BLK_CNT ] && \
+ error "Used space for user $TSTID is $USED, expected $BLK_CNT"
+ USED=`getquota -u $TSTID global curinodes`
+ [ $USED -ne 1 ] && \
+ error "Used inodes for user $TSTID is $USED, expected 1"
+
+ echo "chgrp the file to group $TSTID"
+ chgrp $TSTID $DIR/$tdir/$tfile || error "chgrp failed"
+
+ echo "Wait for setattr on objects finished..."
+ wait_delete_completed
+
+ echo "Verify disk usage for group $TSTID"
+ USED=`getquota -g $TSTID global curspace`
+ [ $USED -ge $BLK_CNT ] || \
+ error "Used space for group $TSTID is $USED, expected $BLK_CNT"
+ USED=`getquota -g $TSTID global curinodes`
+ [ $USED -eq 1 ] || \
+ error "Used inodes for group $TSTID is $USED, expected 1"
+
+ cleanup_quota_test
+}
+run_test 34 "usage transfer for user & group ===================================="
+
+# usage is still accessible across restart
+test_35() {
+ mkdir -p $DIR/$tdir
+ chmod 0777 $DIR/$tdir
+ BLK_CNT=1024
+
+ trap cleanup_quota_test EXIT
+
+ echo "Write file..."
+ $RUNAS dd if=/dev/zero of=$DIR/$tdir/$tfile bs=$((BLK_SZ * BLK_CNT)) \
+ count=1 conv=fsync 2>/dev/null || error "write failed"
+ sync; sync_all_data;
+
+ echo "Save disk usage before restart"
+ ORIG_USR_SPACE=`getquota -u $TSTID global curspace`
+ [ $ORIG_USR_SPACE -eq 0 ] && \
+ error "Used space for user $TSTID is 0, expected $BLK_CNT"
+ ORIG_USR_INODES=`getquota -u $TSTID global curinodes`
+ [ $ORIG_USR_INODES -eq 0 ] && \
+ error "Used inodes for user $TSTID is 0, expected 1"
+ ORIG_GRP_SPACE=`getquota -g $TSTID global curspace`
+ [ $ORIG_GRP_SPACE -eq 0 ] && \
+ error "Used space for group $TSTID is 0, expected $BLK_CNT"
+ ORIG_GRP_INODES=`getquota -g $TSTID global curinodes`
+ [ $ORIG_GRP_INODES -eq 0 ] && \
+ error "Used inodes for group $TSTID is 0, expected 1"
+
+ log "Restart..."
+ local ORIG_REFORMAT=$REFORMAT
+ REFORMAT=""
+ cleanup_and_setup_lustre
+ REFORMAT=$ORIG_REFORMAT
+ quota_init
+
+ echo "Verify disk usage after restart"
+ USED=`getquota -u $TSTID global curspace`
+ [ $USED -eq $ORIG_USR_SPACE ] || \
+ error "Used space for user $TSTID changed from " \
+ "$ORIG_USR_SPACE to $USED"
+ USED=`getquota -u $TSTID global curinodes`
+ [ $USED -eq $ORIG_USR_INODES ] || \
+ error "Used inodes for user $TSTID changed from " \
+ "$ORIG_USR_INODES to $USED"
+ USED=`getquota -g $TSTID global curspace`
+ [ $USED -eq $ORIG_GRP_SPACE ] || \
+ error "Used space for group $TSTID changed from " \
+ "$ORIG_GRP_SPACE to $USED"
+ USED=`getquota -g $TSTID global curinodes`
+ [ $USED -eq $ORIG_GRP_INODES ] || \
+ error "Used inodes for group $TSTID changed from " \
+ "$ORIG_GRP_INODES to $USED"
+
+ cleanup_quota_test
+}
+run_test 35 "usage is still accessible across reboot ============================"
+
# turn off quota
quota_fini()
{
}
quota_fini
-log "cleanup: ======================================================"
cd $ORIG_PWD
+complete $(basename $0) $SECONDS
check_and_cleanup_lustre
-echo '=========================== finished ==============================='
export QUOTA_AUTO=$QUOTA_AUTO_OLD
-[ -f "$QUOTALOG" ] && cat $QUOTALOG && grep -q FAIL $QUOTALOG && exit 1 || true
-echo "$0: completed"
+exit_status