Files
apfstests/tests/xfs/108
T

109 lines
2.6 KiB
Bash
Raw Normal View History

#! /bin/bash
2018-06-09 11:35:45 +10:00
# SPDX-License-Identifier: GPL-2.0
# Copyright (c) 2005 Silicon Graphics, Inc. All Rights Reserved.
#
# FS QA Test No. 108
#
# Simple quota accounting test for direct/buffered/mmap IO.
#
seq=`basename $0`
seqres=$RESULT_DIR/$seq
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
2013-03-15 12:28:04 +00:00
. ./common/rc
. ./common/filter
. ./common/quota
# real QA test starts here
_supported_fs xfs
_require_scratch
_require_xfs_quota
test_files()
{
echo; echo "### create files, setting up ownership (type=$type)"
rm -f $SCRATCH_MNT/{buffer,direct,mmap}
2005-06-02 15:09:19 +00:00
$XFS_IO_PROG -fc "chproj $prid" $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
2005-06-02 15:09:19 +00:00
$XFS_IO_PROG -c lsproj $file
done
}
test_accounting()
{
echo "### some controlled buffered, direct and mmapd IO (type=$type)"
echo "--- initiating parallel IO..." >>$seqres.full
2005-06-02 15:09:19 +00:00
$XFS_IO_PROG -c 'pwrite -b 1m 0 16m' -c 'fsync' \
$SCRATCH_MNT/buffer >>$seqres.full 2>&1 &
2005-06-02 15:09:19 +00:00
$XFS_IO_PROG -c 'pwrite -b 1m 0 16m' -d \
$SCRATCH_MNT/direct >>$seqres.full 2>&1 &
2005-06-02 15:09:19 +00:00
$XFS_IO_PROG -c 't 16m' -c 'mm -rw 0 16m' -c 'mw 0 16m' -c 'ms -s' \
$SCRATCH_MNT/mmap >>$seqres.full 2>&1 &
wait
echo "--- completed parallel IO ($type)" >>$seqres.full
for file in $SCRATCH_MNT/{buffer,direct,mmap}; do
$here/src/lstat64 $file | head -3 | _filter_scratch
done
xfs_quota -c "quota -hnb -$type $id" $QARGS | _filter_quota
xfs_quota -c "quota -hni -$type $id" $QARGS | _filter_quota
xfs_quota -c "quota -hnr -$type $id" $QARGS | _filter_quota
}
2010-09-09 19:47:35 +02:00
export MOUNT_OPTIONS="-opquota"
2019-03-19 17:46:01 -07:00
_scratch_mkfs_xfs >> $seqres.full
2010-09-09 19:47:35 +02:00
_qmount
2010-10-01 06:04:33 +02:00
_require_prjquota $SCRATCH_DEV
2010-09-09 19:47:35 +02:00
# real QA test starts here
rm -f $tmp.projects $seqres.full
2015-12-21 18:07:43 +11:00
_scratch_unmount 2>/dev/null
_scratch_mkfs_xfs | _filter_mkfs 2>$tmp.mkfs
cat $tmp.mkfs >>$seqres.full
_scratch_mount
uid=1
gid=2
prid=3
export QARGS="-x -D /dev/null -P /dev/null $SCRATCH_MNT"
2015-12-21 18:07:43 +11:00
_scratch_unmount
echo; echo "### test user accounting"
export MOUNT_OPTIONS="-ouquota"
_qmount
type=u
id=$uid
test_files
test_accounting
2015-12-21 18:07:43 +11:00
_scratch_unmount 2>/dev/null
echo; echo "### test group accounting"
export MOUNT_OPTIONS="-ogquota"
_qmount
type=g
id=$gid
test_files
test_accounting
2015-12-21 18:07:43 +11:00
_scratch_unmount 2>/dev/null
#echo; echo "### test project accounting"
export MOUNT_OPTIONS="-opquota"
_qmount
type=p
id=$prid
test_files
test_accounting
2015-12-21 18:07:43 +11:00
_scratch_unmount 2>/dev/null
status=0
exit