mirror of
https://github.com/linux-apfs/apfstests.git
synced 2026-05-01 15:01:44 -07:00
fc48dfb966
And into tests/xfs. Tests found and moved via: $ grep "supported_fs xfs$" [0-2]* | cut -d : -f 1 > xfs.tests $ for i in `cat xfs.tests`; do > git mv $i* tests/xfs/ > grep ^$i group >> tests/xfs/group > sed -i -e "/^$i/d" group > done Output now looks like: sudo ./check -g quick -r FSTYP -- xfs (debug) PLATFORM -- Linux/x86_64 test-1 3.5.0-rc5-dgc+ MKFS_OPTIONS -- -f -bsize=4096 /dev/vdb MOUNT_OPTIONS -- /dev/vdb /mnt/scratch xfs/170 4s generic/120 16s generic/248 0s generic/213 0s generic/256 39s xfs/121 6s xfs/026 11s generic/131 1s xfs/187 1s generic/135 0s .... Signed-off-by: Dave Chinner <dchinner@redhat.com> Reviewed-by: Phil White <pwhite@sgi.com> [rjohnston@sgi.com did not move test 032, belongs in shared] Signed-off-by: Rich Johnston <rjohnston@sgi.com>
117 lines
3.6 KiB
Bash
Executable File
117 lines
3.6 KiB
Bash
Executable File
#! /bin/bash
|
|
# FS QA Test No. 008
|
|
#
|
|
# randholes test
|
|
#
|
|
#-----------------------------------------------------------------------
|
|
# Copyright (c) 2000-2002 Silicon Graphics, Inc. All Rights Reserved.
|
|
#
|
|
# This program is free software; you can redistribute it and/or
|
|
# modify it under the terms of the GNU General Public License as
|
|
# published by the Free Software Foundation.
|
|
#
|
|
# This program is distributed in the hope that it would be useful,
|
|
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
# GNU General Public License for more details.
|
|
#
|
|
# You should have received a copy of the GNU General Public License
|
|
# along with this program; if not, write the Free Software Foundation,
|
|
# Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
|
|
#
|
|
#-----------------------------------------------------------------------
|
|
#
|
|
|
|
seq=`basename $0`
|
|
echo "QA output created by $seq"
|
|
|
|
here=`pwd`
|
|
tmp=/tmp/$$
|
|
status=0 # success is the default!
|
|
pgsize=`$here/src/feature -s`
|
|
trap "_cleanup; exit \$status" 0 1 2 3 15
|
|
|
|
_cleanup()
|
|
{
|
|
rm -f $tmp.*
|
|
rm -rf $testdir/randholes.$$.*
|
|
_cleanup_testdir
|
|
}
|
|
|
|
_filter()
|
|
{
|
|
sed -e "s/-b $pgsize/-b PGSIZE/g" \
|
|
-e "s/-l .* -c/-l FSIZE -c/g"
|
|
}
|
|
|
|
# get standard environment, filters and checks
|
|
. ./common.rc
|
|
. ./common.filter
|
|
|
|
_do_test()
|
|
{
|
|
_n="$1"
|
|
_holes="$2"
|
|
_param="$3"
|
|
|
|
out=$testdir/randholes.$$.$_n
|
|
echo ""
|
|
echo "randholes.$_n : $_param" | _filter
|
|
echo "------------------------------------------"
|
|
if $here/src/randholes $_param $out >$tmp.out
|
|
then
|
|
# only check if we're not allocating in huge chunks (extsz flag)
|
|
if _test_inode_flag extsize $out || _test_inode_flag realtime $out
|
|
then
|
|
echo "holes is in range"
|
|
else
|
|
# quick check - how many holes did we get?
|
|
count=`xfs_bmap $out | egrep -c ': hole'`
|
|
# blocks can end up adjacent, therefore number of holes varies
|
|
_within_tolerance "holes" $count $_holes 10% -v
|
|
fi
|
|
else
|
|
echo " randholes returned $? - see $seq.out.full"
|
|
echo "--------------------------------------" >>$here/$seq.out.full
|
|
echo "$_n - output from randholes:" >>$here/$seq.out.full
|
|
echo "--------------------------------------" >>$here/$seq.out.full
|
|
cat $tmp.out >>$here/$seq.out.full
|
|
echo "--------------------------------------" >>$here/$seq.out.full
|
|
echo "$_n - output from bmap:" >>$here/$seq.out.full
|
|
echo "--------------------------------------" >>$here/$seq.out.full
|
|
xfs_bmap -vvv $out >>$here/$seq.out.full
|
|
status=1
|
|
fi
|
|
}
|
|
|
|
# real QA test starts here
|
|
_supported_fs xfs
|
|
_supported_os IRIX Linux
|
|
|
|
_setup_testdir
|
|
|
|
rm -f $here/$seq.out.full
|
|
|
|
# Note on special numbers here.
|
|
#
|
|
# We are trying to create roughly 50 or 100 holes in a file
|
|
# using random writes. Assuming a good distribution of 50 writes
|
|
# in a file, the file only needs to be 3-4x the size of the write
|
|
# size muliplied by the number of writes. Hence we use 200 * pgsize
|
|
# for files we want 50 holes in and 400 * pgsize for files we want
|
|
# 100 holes in. This keeps the runtime down as low as possible.
|
|
#
|
|
_do_test 1 50 "-l `expr 200 \* $pgsize` -c 50 -b $pgsize"
|
|
_do_test 2 100 "-l `expr 400 \* $pgsize` -c 100 -b $pgsize"
|
|
_do_test 3 100 "-l `expr 400 \* $pgsize` -c 100 -b 512" # test partial pages
|
|
|
|
# rinse, lather, repeat for direct IO
|
|
_do_test 4 50 "-d -l `expr 200 \* $pgsize` -c 50 -b $pgsize"
|
|
_do_test 5 100 "-d -l `expr 400 \* $pgsize` -c 100 -b $pgsize"
|
|
# note: direct IO requires page aligned IO
|
|
|
|
# todo: realtime.
|
|
|
|
# success, all done
|
|
exit
|