Test 050 modified to test all quota mount options in single run
authorAllan Randall <allanr@sgi.com>
Thu, 18 May 2006 15:48:26 +0000 (15:48 +0000)
committerAllan Randall <allanr@sgi.com>
Thu, 18 May 2006 15:48:26 +0000 (15:48 +0000)
Merge of master-melb:xfs-cmds:25962a by kenmcd.

  Modified to test all quota mount options in single run

050
050.out [new file with mode: 0644]
common.quota

diff --git a/050 b/050
index 0fe466a45f3bba036395c9f2f831029fd8112c67..6b1cfa32a727e831f2a94fec69da9d02e459d2fe 100755 (executable)
--- a/050
+++ b/050
@@ -2,8 +2,7 @@
 # FS QA Test No. 050
 #
 # Exercises basic XFS quota functionality
 # FS QA Test No. 050
 #
 # Exercises basic XFS quota functionality
-#      MOUNT_OPTIONS env var switches the test type (uid/gid/acct/enfd)
-#      options are:  (-o) uquota, gquota, uqnoenforce, gqnoenforce
+#       uquota, gquota, uqnoenforce, gqnoenforce, pquota, pqnoenforce
 #
 #-----------------------------------------------------------------------
 # Copyright (c) 2000-2002 Silicon Graphics, Inc.  All Rights Reserved.
 #
 #-----------------------------------------------------------------------
 # Copyright (c) 2000-2002 Silicon Graphics, Inc.  All Rights Reserved.
@@ -27,7 +26,6 @@ status=1      # failure is the default!
 _cleanup()
 {
        cd /
 _cleanup()
 {
        cd /
-       echo; echo "*** unmount"
        umount $SCRATCH_MNT 2>/dev/null
        rm -f $tmp.*
 }
        umount $SCRATCH_MNT 2>/dev/null
        rm -f $tmp.*
 }
@@ -38,21 +36,19 @@ trap "_cleanup; exit \$status" 0 1 2 3 15
 _supported_fs xfs
 _supported_os Linux IRIX
 
 _supported_fs xfs
 _supported_os Linux IRIX
 
-rm -f $seq.out
+
 cp /dev/null $seq.full
 chmod a+rwx $seq.full  # arbitrary users will write here
 
 _require_scratch
 _require_quota
 
 cp /dev/null $seq.full
 chmod a+rwx $seq.full  # arbitrary users will write here
 
 _require_scratch
 _require_quota
 
-# setup a default run
-[ -z "$MOUNT_OPTIONS" ] && export MOUNT_OPTIONS="-o uquota"
-
 bsoft=100
 bhard=500
 isoft=4
 ihard=10
 
 bsoft=100
 bhard=500
 isoft=4
 ihard=10
 
+
 _filter_report()
 {
        tr -s '[:space:]' | sed -e "s/^\#$id /[NAME] /g" -e "s/^#0 /[ROOT] /g"
 _filter_report()
 {
        tr -s '[:space:]' | sed -e "s/^\#$id /[NAME] /g" -e "s/^#0 /[ROOT] /g"
@@ -79,73 +75,149 @@ _filter_and_check_blks()
        ' | _filter_report
 }
 
        ' | _filter_report
 }
 
-_scratch_mkfs_xfs | _filter_mkfs 2>$tmp.mkfs
-cat $tmp.mkfs >>$seq.full
-
-# keep the blocksize and data size for dd later
-. $tmp.mkfs
-
-_qmount
-
-# Figure out whether we're doing large allocations
-# (bail out if they're so large they stuff the test up)
-_test_inode_flag extsz-inherit $SCRATCH_MNT
-noextsz=$?
-extsize=`_test_inode_extsz $SCRATCH_MNT`
-[ $extsize -ge 512000 ] && \
-       _notrun "Extent size hint is too large ($extsize bytes)"
-
-_qsetup
-
-echo "Using output from '" `ls -l $seq.out` "'" >>$seq.full
-echo "and using type=$type id=$id" >>$seq.full
-
-echo
-echo "*** report no quota settings" | tee -a $seq.full
-xfs_quota -x -c "repquota -birnN -$type" $SCRATCH_DEV | _filter_report
-
-echo
-echo "*** report initial settings" | tee -a $seq.full
-_file_as_id $SCRATCH_MNT/initme $id $type 1024 0
-echo "ls -l $SCRATCH_MNT" >>$seq.full
-ls -l $SCRATCH_MNT >>$seq.full
-xfs_quota -x \
-       -c "limit -$type bsoft=${bsoft}k bhard=${bhard}k $id" \
-       -c "limit -$type isoft=$isoft ihard=$ihard $id" \
-       $SCRATCH_DEV
-xfs_quota -x -c "repquota -birnN -$type" $SCRATCH_DEV | _filter_report
-
-echo
-echo "*** push past the soft inode limit" | tee -a $seq.full
-_file_as_id $SCRATCH_MNT/softie1 $id $type 1024 0
-_file_as_id $SCRATCH_MNT/softie2 $id $type 1024 0
-_qmount
-xfs_quota -x -c "repquota -birnN -$type" $SCRATCH_DEV | _filter_report
-
-echo
-echo "*** push past the soft block limit" | tee -a $seq.full
-_file_as_id $SCRATCH_MNT/softie $id $type 1024 140
-_qmount
-xfs_quota -x -c "repquota -birnN -$type" $SCRATCH_DEV | _filter_report
-
-echo
-# Note: for quota accounting (not enforcement), EDQUOT is not expected
-echo "*** push past the hard inode limit (expect EDQUOT)" | tee -a $seq.full
-for i in 1 2 3 4 5 6 7 8 9 10 11 12
-do
-       _file_as_id $SCRATCH_MNT/hard$i $id $type 1024 0
-done
-_qmount
-xfs_quota -x -c "repquota -birnN -$type" $SCRATCH_DEV | _filter_report
-
-echo
-# Note: for quota accounting (not enforcement), EDQUOT is not expected
-echo "*** push past the hard block limit (expect EDQUOT)" | tee -a $seq.full
-_file_as_id $SCRATCH_MNT/softie $id $type 1024 540
-echo "ls -l $SCRATCH_MNT" >>$seq.full
-ls -l $SCRATCH_MNT >>$seq.full
-_qmount
-xfs_quota -x -c "repquota -birnN -$type" $SCRATCH_DEV | _filter_and_check_blks
+_exercise()
+{
+       _scratch_mkfs_xfs | _filter_mkfs 2>$tmp.mkfs
+       cat $tmp.mkfs >>$seq.full
+
+       # keep the blocksize and data size for dd later
+       . $tmp.mkfs
+
+       
+       _qmount
+
+
+       # Figure out whether we're doing large allocations
+       # (bail out if they're so large they stuff the test up)
+       _test_inode_flag extsz-inherit $SCRATCH_MNT
+       noextsz=$?
+       extsize=`_test_inode_extsz $SCRATCH_MNT`
+       [ $extsize -ge 512000 ] && \
+               _notrun "Extent size hint is too large ($extsize bytes)"
+
+       _qsetup
+
+       echo "Using output from '" `ls -l $seq.out` "'" >>$seq.full
+       echo "and using type=$type id=$id" >>$seq.full
+
+       echo
+       echo "*** report no quota settings" | tee -a $seq.full
+       xfs_quota -D $tmp.projects -P $tmp.projid -x -c "repquota -birnN -$type" $SCRATCH_DEV | _filter_report
+
+       echo
+       echo "*** report initial settings" | tee -a $seq.full
+       _file_as_id $SCRATCH_MNT/initme $id $type 1024 0
+       echo "ls -l $SCRATCH_MNT" >>$seq.full
+       ls -l $SCRATCH_MNT >>$seq.full
+       xfs_quota -D $tmp.projects -P $temp.projid -x \
+               -c "limit -$type bsoft=${bsoft}k bhard=${bhard}k $id" \
+               -c "limit -$type isoft=$isoft ihard=$ihard $id" \
+               $SCRATCH_DEV
+       xfs_quota -D $tmp.projects -P $tmp.projid -x -c "repquota -birnN -$type" $SCRATCH_DEV | _filter_report
+
+       echo
+       echo "*** push past the soft inode limit" | tee -a $seq.full
+       _file_as_id $SCRATCH_MNT/softie1 $id $type 1024 0
+       _file_as_id $SCRATCH_MNT/softie2 $id $type 1024 0
+       _qmount
+       xfs_quota -D $tmp.projects -P $tmp.projid -x -c "repquota -birnN -$type" $SCRATCH_DEV | _filter_report
+       
+       echo
+       echo "*** push past the soft block limit" | tee -a $seq.full
+       _file_as_id $SCRATCH_MNT/softie $id $type 1024 140
+       _qmount
+       xfs_quota -D $tmp.projects -P $tmp.projid -x -c "repquota -birnN -$type" $SCRATCH_DEV | _filter_report
+       
+       echo
+       # Note: for quota accounting (not enforcement), EDQUOT is not expected
+       echo "*** push past the hard inode limit (expect EDQUOT)" | tee -a $seq.full
+       for i in 1 2 3 4 5 6 7 8 9 10 11 12
+       do
+               _file_as_id $SCRATCH_MNT/hard$i $id $type 1024 0
+       done
+       _qmount
+       xfs_quota -D $tmp.projects -P $tmp.projid -x -c "repquota -birnN -$type" $SCRATCH_DEV | _filter_report
+
+       echo
+       # Note: for quota accounting (not enforcement), EDQUOT is not expected
+       echo "*** push past the hard block limit (expect EDQUOT)" | tee -a $seq.full
+       _file_as_id $SCRATCH_MNT/softie $id $type 1024 540
+       echo "ls -l $SCRATCH_MNT" >>$seq.full
+       ls -l $SCRATCH_MNT >>$seq.full
+       _qmount
+       xfs_quota -D $tmp.projects -P $tmp.projid -x -c "repquota -birnN -$type" $SCRATCH_DEV | _filter_and_check_blks
+
+       echo
+       echo "*** unmount"
+       umount $SCRATCH_MNT
+
+}
+
+
+#ensures only one quota mount option is specified
+_qmount_option()
+{
+       #replace any user defined quota options
+       export MOUNT_OPTIONS=`echo $MOUNT_OPTIONS \
+       | sed -e 's/uquota/$q_opt/g' \
+               -e 's/gquota/$q_opt/g' \
+               -e 's/pquota/$q_opt/g' \
+               -e 's/quota/$q_opt/g' \
+               -e 's/uqnoenforce/$q_opt/g' \
+               -e 's/gqnoenforce/$q_opt/g' \
+               -e 's/pqnoenforce/$q_opt/g' \
+               -e 's/qnoenforce/$q_opt/g' \
+       | sed 's/$q_opt/'$1'/g'`
+
+       #check $q_opt is in new mount options
+       echo $MOUNT_OPTIONS | grep "$1" > /dev/null 2>&1
+       [ "$?" -eq 0 ] || export MOUNT_OPTIONS="$MOUNT_OPTIONS -o $1"
+}
+
+cat >$tmp.projects <<EOF 
+1:/mnt/scratch
+EOF
+
+cat >$tmp.projid <<EOF
+root:0
+scrach:1
+EOF
+
+projid_file="$tmp.projid"
+
+echo "*** user"
+if [ "$HOSTOS" == "IRIX" ]
+then
+       _qmount_option "quota"
+else
+       _qmount_option "uquota"
+fi
+_exercise
+
+echo "*** group"
+_qmount_option "gquota"
+_exercise
+
+echo "*** uqnoenforce" 
+if [ "$HOSTOS" == "IRIX" ]
+then
+       _qmount_option "qnoenforce"
+else
+       _qmount_option "uqnoenforce"
+fi
+_exercise
+
+echo "*** gqnoenforce" 
+_qmount_option "gqnoenforce"
+_exercise
+
+echo "*** pquota" 
+_qmount_option "pquota"
+_exercise
+
+echo "*** pqnoenforce" 
+_qmount_option "pqnoenforce"
+_exercise
 
 # success, all done
 status=0
 
 # success, all done
 status=0
diff --git a/050.out b/050.out
new file mode 100644 (file)
index 0000000..8acde7b
--- /dev/null
+++ b/050.out
@@ -0,0 +1,193 @@
+QA output created by 050
+*** user
+meta-data=DDEV isize=XXX agcount=N, agsize=XXX blks
+data     = bsize=XXX blocks=XXX, imaxpct=PCT
+         = sunit=XXX swidth=XXX, unwritten=X
+naming   =VERN bsize=XXX
+log      =LDEV bsize=XXX blocks=XXX
+realtime =RDEV extsz=XXX blocks=XXX, rtextents=XXX
+
+*** report no quota settings
+[ROOT] 0 0 0 00 [--------] 3 0 0 00 [--------] 0 0 0 00 [--------]
+
+*** report initial settings
+[ROOT] 0 0 0 00 [--------] 3 0 0 00 [--------] 0 0 0 00 [--------]
+[NAME] 0 100 500 00 [--------] 1 4 10 00 [--------] 0 0 0 00 [--------]
+
+*** push past the soft inode limit
+[ROOT] 0 0 0 00 [--------] 3 0 0 00 [--------] 0 0 0 00 [--------]
+[NAME] 0 100 500 00 [--------] 3 4 10 00 [--------] 0 0 0 00 [--------]
+
+*** push past the soft block limit
+[ROOT] 0 0 0 00 [--------] 3 0 0 00 [--------] 0 0 0 00 [--------]
+[NAME] 140 100 500 00 [7 days] 4 4 10 00 [7 days] 0 0 0 00 [--------]
+
+*** push past the hard inode limit (expect EDQUOT)
+[ROOT] 0 0 0 00 [--------] 3 0 0 00 [--------] 0 0 0 00 [--------]
+[NAME] 140 100 500 00 [7 days] 10 4 10 00 [7 days] 0 0 0 00 [--------]
+
+*** push past the hard block limit (expect EDQUOT)
+[ROOT] 0 0 0 00 [--------] 3 0 0 00 [--------] 0 0 0 00 [--------]
+[NAME] =OK= 100 500 00 [7 days] 10 4 10 00 [7 days] 0 0 0 00 [--------]
+
+*** unmount
+*** group
+meta-data=DDEV isize=XXX agcount=N, agsize=XXX blks
+data     = bsize=XXX blocks=XXX, imaxpct=PCT
+         = sunit=XXX swidth=XXX, unwritten=X
+naming   =VERN bsize=XXX
+log      =LDEV bsize=XXX blocks=XXX
+realtime =RDEV extsz=XXX blocks=XXX, rtextents=XXX
+
+*** report no quota settings
+[ROOT] 0 0 0 00 [--------] 3 0 0 00 [--------] 0 0 0 00 [--------]
+
+*** report initial settings
+[ROOT] 0 0 0 00 [--------] 3 0 0 00 [--------] 0 0 0 00 [--------]
+[NAME] 0 100 500 00 [--------] 1 4 10 00 [--------] 0 0 0 00 [--------]
+
+*** push past the soft inode limit
+[ROOT] 0 0 0 00 [--------] 3 0 0 00 [--------] 0 0 0 00 [--------]
+[NAME] 0 100 500 00 [--------] 3 4 10 00 [--------] 0 0 0 00 [--------]
+
+*** push past the soft block limit
+[ROOT] 0 0 0 00 [--------] 3 0 0 00 [--------] 0 0 0 00 [--------]
+[NAME] 140 100 500 00 [7 days] 4 4 10 00 [7 days] 0 0 0 00 [--------]
+
+*** push past the hard inode limit (expect EDQUOT)
+[ROOT] 0 0 0 00 [--------] 3 0 0 00 [--------] 0 0 0 00 [--------]
+[NAME] 140 100 500 00 [7 days] 10 4 10 00 [7 days] 0 0 0 00 [--------]
+
+*** push past the hard block limit (expect EDQUOT)
+[ROOT] 0 0 0 00 [--------] 3 0 0 00 [--------] 0 0 0 00 [--------]
+[NAME] =OK= 100 500 00 [7 days] 10 4 10 00 [7 days] 0 0 0 00 [--------]
+
+*** unmount
+*** uqnoenforce
+meta-data=DDEV isize=XXX agcount=N, agsize=XXX blks
+data     = bsize=XXX blocks=XXX, imaxpct=PCT
+         = sunit=XXX swidth=XXX, unwritten=X
+naming   =VERN bsize=XXX
+log      =LDEV bsize=XXX blocks=XXX
+realtime =RDEV extsz=XXX blocks=XXX, rtextents=XXX
+
+*** report no quota settings
+[ROOT] 0 0 0 00 [--------] 3 0 0 00 [--------] 0 0 0 00 [--------]
+
+*** report initial settings
+[ROOT] 0 0 0 00 [--------] 3 0 0 00 [--------] 0 0 0 00 [--------]
+[NAME] 0 100 500 00 [--------] 1 4 10 00 [--------] 0 0 0 00 [--------]
+
+*** push past the soft inode limit
+[ROOT] 0 0 0 00 [--------] 3 0 0 00 [--------] 0 0 0 00 [--------]
+[NAME] 0 100 500 00 [--------] 3 4 10 00 [--------] 0 0 0 00 [--------]
+
+*** push past the soft block limit
+[ROOT] 0 0 0 00 [--------] 3 0 0 00 [--------] 0 0 0 00 [--------]
+[NAME] 140 100 500 00 [--------] 4 4 10 00 [--------] 0 0 0 00 [--------]
+
+*** push past the hard inode limit (expect EDQUOT)
+[ROOT] 4 0 0 00 [--------] 3 0 0 00 [--------] 0 0 0 00 [--------]
+[NAME] 140 100 500 00 [--------] 16 4 10 00 [--none--] 0 0 0 00 [--------]
+
+*** push past the hard block limit (expect EDQUOT)
+[ROOT] 4 0 0 00 [--------] 3 0 0 00 [--------] 0 0 0 00 [--------]
+[NAME] 540 100 500 00 [--none--] 16 4 10 00 [--none--] 0 0 0 00 [--------]
+
+*** unmount
+*** gqnoenforce
+meta-data=DDEV isize=XXX agcount=N, agsize=XXX blks
+data     = bsize=XXX blocks=XXX, imaxpct=PCT
+         = sunit=XXX swidth=XXX, unwritten=X
+naming   =VERN bsize=XXX
+log      =LDEV bsize=XXX blocks=XXX
+realtime =RDEV extsz=XXX blocks=XXX, rtextents=XXX
+
+*** report no quota settings
+[ROOT] 0 0 0 00 [--------] 3 0 0 00 [--------] 0 0 0 00 [--------]
+
+*** report initial settings
+[ROOT] 0 0 0 00 [--------] 3 0 0 00 [--------] 0 0 0 00 [--------]
+[NAME] 0 100 500 00 [--------] 1 4 10 00 [--------] 0 0 0 00 [--------]
+
+*** push past the soft inode limit
+[ROOT] 0 0 0 00 [--------] 3 0 0 00 [--------] 0 0 0 00 [--------]
+[NAME] 0 100 500 00 [--------] 3 4 10 00 [--------] 0 0 0 00 [--------]
+
+*** push past the soft block limit
+[ROOT] 0 0 0 00 [--------] 3 0 0 00 [--------] 0 0 0 00 [--------]
+[NAME] 140 100 500 00 [--------] 4 4 10 00 [--------] 0 0 0 00 [--------]
+
+*** push past the hard inode limit (expect EDQUOT)
+[ROOT] 4 0 0 00 [--------] 3 0 0 00 [--------] 0 0 0 00 [--------]
+[NAME] 140 100 500 00 [--------] 16 4 10 00 [--none--] 0 0 0 00 [--------]
+
+*** push past the hard block limit (expect EDQUOT)
+[ROOT] 4 0 0 00 [--------] 3 0 0 00 [--------] 0 0 0 00 [--------]
+[NAME] 540 100 500 00 [--none--] 16 4 10 00 [--none--] 0 0 0 00 [--------]
+
+*** unmount
+*** pquota
+meta-data=DDEV isize=XXX agcount=N, agsize=XXX blks
+data     = bsize=XXX blocks=XXX, imaxpct=PCT
+         = sunit=XXX swidth=XXX, unwritten=X
+naming   =VERN bsize=XXX
+log      =LDEV bsize=XXX blocks=XXX
+realtime =RDEV extsz=XXX blocks=XXX, rtextents=XXX
+
+*** report no quota settings
+[ROOT] 0 0 0 00 [--------] 3 0 0 00 [--------] 0 0 0 00 [--------]
+
+*** report initial settings
+[ROOT] 0 0 0 00 [--------] 3 0 0 00 [--------] 0 0 0 00 [--------]
+[NAME] 0 100 500 00 [--------] 1 4 10 00 [--------] 0 0 0 00 [--------]
+
+*** push past the soft inode limit
+[ROOT] 0 0 0 00 [--------] 3 0 0 00 [--------] 0 0 0 00 [--------]
+[NAME] 0 100 500 00 [--------] 3 4 10 00 [--------] 0 0 0 00 [--------]
+
+*** push past the soft block limit
+[ROOT] 0 0 0 00 [--------] 3 0 0 00 [--------] 0 0 0 00 [--------]
+[NAME] 140 100 500 00 [7 days] 4 4 10 00 [7 days] 0 0 0 00 [--------]
+
+*** push past the hard inode limit (expect EDQUOT)
+[ROOT] 0 0 0 00 [--------] 3 0 0 00 [--------] 0 0 0 00 [--------]
+[NAME] 140 100 500 00 [7 days] 10 4 10 00 [7 days] 0 0 0 00 [--------]
+
+*** push past the hard block limit (expect EDQUOT)
+[ROOT] 0 0 0 00 [--------] 3 0 0 00 [--------] 0 0 0 00 [--------]
+[NAME] =OK= 100 500 00 [7 days] 10 4 10 00 [7 days] 0 0 0 00 [--------]
+
+*** unmount
+*** pqnoenforce
+meta-data=DDEV isize=XXX agcount=N, agsize=XXX blks
+data     = bsize=XXX blocks=XXX, imaxpct=PCT
+         = sunit=XXX swidth=XXX, unwritten=X
+naming   =VERN bsize=XXX
+log      =LDEV bsize=XXX blocks=XXX
+realtime =RDEV extsz=XXX blocks=XXX, rtextents=XXX
+
+*** report no quota settings
+[ROOT] 0 0 0 00 [--------] 3 0 0 00 [--------] 0 0 0 00 [--------]
+
+*** report initial settings
+[ROOT] 0 0 0 00 [--------] 3 0 0 00 [--------] 0 0 0 00 [--------]
+[NAME] 0 100 500 00 [--------] 1 4 10 00 [--------] 0 0 0 00 [--------]
+
+*** push past the soft inode limit
+[ROOT] 0 0 0 00 [--------] 3 0 0 00 [--------] 0 0 0 00 [--------]
+[NAME] 0 100 500 00 [--------] 3 4 10 00 [--------] 0 0 0 00 [--------]
+
+*** push past the soft block limit
+[ROOT] 0 0 0 00 [--------] 3 0 0 00 [--------] 0 0 0 00 [--------]
+[NAME] 140 100 500 00 [--------] 4 4 10 00 [--------] 0 0 0 00 [--------]
+
+*** push past the hard inode limit (expect EDQUOT)
+[ROOT] 4 0 0 00 [--------] 3 0 0 00 [--------] 0 0 0 00 [--------]
+[NAME] 140 100 500 00 [--------] 16 4 10 00 [--none--] 0 0 0 00 [--------]
+
+*** push past the hard block limit (expect EDQUOT)
+[ROOT] 4 0 0 00 [--------] 3 0 0 00 [--------] 0 0 0 00 [--------]
+[NAME] 540 100 500 00 [--none--] 16 4 10 00 [--none--] 0 0 0 00 [--------]
+
+*** unmount
index b15be86f2f439e813e70d1ee08d7bac816df6691..7fb10c2a1dbc26fd0b21d8b80bf27536715d5982 100644 (file)
@@ -86,12 +86,15 @@ _choose_gid()
 
 _choose_prid()
 {
 
 _choose_prid()
 {
-    if [ ! -f /etc/projid ]; then
+    if [ $projid_file == "" ]; then
+       projid_file=/etc/projid
+    fi
+    if [ ! -f $projid_file ]; then
        echo 0
        return
     fi
     perl -ne '@a = split(/:/); END { printf "id=%d name=%s\n", $a[1],$a[0] }' \
        echo 0
        return
     fi
     perl -ne '@a = split(/:/); END { printf "id=%d name=%s\n", $a[1],$a[0] }' \
-       /etc/projid
+       $projid_file
 }
 
 _qmount()
 }
 
 _qmount()
@@ -107,24 +110,36 @@ _qsetup()
     enforce=1
     if src/feature -u $SCRATCH_DEV
     then
     enforce=1
     if src/feature -u $SCRATCH_DEV
     then
-       type=u ; eval `_choose_uid`; ln -s $seq.usrquota $seq.out
+       type=u ; 
+       eval `_choose_uid`
+       [ ! -f $seq.out ] && ln -s $seq.usrquota $seq.out
     elif src/feature -g $SCRATCH_DEV
     then
     elif src/feature -g $SCRATCH_DEV
     then
-       type=g ; eval `_choose_gid`; ln -s $seq.grpquota $seq.out
+       type=g
+       eval `_choose_gid`
+       [ ! -f $seq.out ] && ln -s $seq.grpquota $seq.out
     elif src/feature -p $SCRATCH_DEV
     then
     elif src/feature -p $SCRATCH_DEV
     then
-       type=p ; eval `_choose_prid`; ln -s $seq.prjquota $seq.out
+       type=p
+       eval `_choose_prid`
+       [ ! -f $seq.out ] && ln -s $seq.prjquota $seq.out
     elif src/feature -U $SCRATCH_DEV
     then
     elif src/feature -U $SCRATCH_DEV
     then
-       type=u ; eval `_choose_uid`; ln -s $seq.uqnoenforce $seq.out
+       type=u
+       eval `_choose_uid`
+       [ ! -f $seq.out ] && ln -s $seq.uqnoenforce $seq.out
        enforce=0
     elif src/feature -G $SCRATCH_DEV
     then
        enforce=0
     elif src/feature -G $SCRATCH_DEV
     then
-       type=g ; eval `_choose_gid`; ln -s $seq.gqnoenforce $seq.out
+       type=g
+       eval `_choose_gid`
+       [ ! -f $seq.out ] && ln -s $seq.gqnoenforce $seq.out
        enforce=0
     elif src/feature -P $SCRATCH_DEV
     then
        enforce=0
     elif src/feature -P $SCRATCH_DEV
     then
-       type=p ; eval `_choose_prid`; ln -s $seq.pqnoenforce $seq.out
+       type=p
+       eval `_choose_prid`
+       [ ! -f $seq.out ] && ln -s $seq.pqnoenforce $seq.out
        enforce=0
     else
        _notrun "No quota support at mount time"
        enforce=0
     else
        _notrun "No quota support at mount time"