blob: c4af4058040a548d9bcdcf7925aa379dfa50c3e0 [file] [log] [blame]
#! /bin/bash
# SPDX-License-Identifier: GPL-2.0
# Copyright (c) 2020 Red Hat, Inc. All Rights Reserved.
#
# FS QA Test No. 600
#
# Test individual user ID quota grace period extension
# This is the linux quota-tools version of the test
#
# This test only exercises user quota because it's not known whether the
# filesystem can set individual grace timers for each quota type
#
seq=`basename $0`
seqres=$RESULT_DIR/$seq
echo "QA output created by $seq"
here=`pwd`
tmp=/tmp/$$
status=1 # failure is the default!
trap "_cleanup; exit \$status" 0 1 2 3 15
_cleanup()
{
cd /
rm -f $tmp.*
}
# get standard environment, filters and checks
. ./common/rc
. ./common/filter
. ./common/quota
# remove previous $seqres.full before test
rm -f $seqres.full
# real QA test starts here
_supported_fs generic
_require_scratch
_require_quota
_require_user
_require_setquota_project
_scratch_mkfs >$seqres.full 2>&1
_qmount_option "usrquota"
_qmount
echo "Silence is golden"
# Set a default user inode grace period of 1 second
setquota -t -u 0 1 $SCRATCH_MNT
# Soft inode limit 1, hard limit 5
setquota -u $qa_user 0 0 1 5 $SCRATCH_MNT
# Run qa user over soft limit and go over grace period
su $qa_user -c "touch $SCRATCH_MNT/file1 $SCRATCH_MNT/file2"
sleep 3
# Extend grace to now + 100s
now=`date +%s`
let set=now+100
setquota -T -u $qa_user 0 100 $SCRATCH_MNT 2>&1 | grep -v "^setquota"
get=`repquota -up $SCRATCH_MNT | grep "^$qa_user" | awk '{print $NF}'`
# Either the new expiry must match; or be one second after the set time, to
# deal with the seconds counter incrementing.
if [ "$get" != "$set" ] && [ "$get" -ne "$((set + 1))" ]; then
echo "set grace to $set but got grace $get"
fi
# success, all done
status=0
exit