Files
apfstests/tests/xfs/096
T
Dave Chinner c5223b9294 filter: inode size output of mkfs.xfs can change
With the change to CRCs by default, the mkfs inode size is defaults
to 512 bytes and the minimum block size changes to 1024 bytes. This
causes mismatches with golden output that expects the inode size to
be 256 bytes, and some tests are tailored around the amount of space
inside a 256 byte inode. Fix them with appropriate filtering or mkfs
parameters to allow 256 byte inodes to be used.

Signed-off-by: Dave Chinner <dchinner@redhat.com>
Signed-off-by: Dave Chinner <david@fromorbit.com>
2015-05-14 12:20:11 +10:00

160 lines
4.4 KiB
Bash
Executable File

#! /bin/bash
# FS QA Test No. 096
#
# test out mkfs_xfs output on IRIX/Linux and some of its error handling
# ensure pv#920679 is addressed
#
#-----------------------------------------------------------------------
# Copyright (c) 2000-2004 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
#
#-----------------------------------------------------------------------
#
seqfull=$0
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/log
#
# filter out counts which will vary
# - extsz, blocks, agsize, agcount, device name, rtextents
# - log version varies for crc enabled fs
# - lsunit varies for 512/4k sector devices
# filter out differences between linux and irix:
# - sectsz on Linux
# - mmr, mixed-case on IRIX
# - lazy-count on IRIX
# - inode-paths on IRIX
# - trailing spaces on Linux but not on IRIX
#
# Example output:
# meta-data=DEV isize=256 agcount=N, agsize=N blks
# data = bsize=4096 blocks=N, imaxpct=25
# = sunit=65 swidth=65 blks, unwritten=1
# naming =version 2 bsize=4096
# log =internal log bsize=4096 blocks=N, version=1
# = sunit=0 blks
# realtime =none extsz=65536 blocks=N, rtextents=N
#
mkfs_filter()
{
tee -a $seqres.full | \
sed \
-e 's/extsz=[0-9][0-9]*[ ]*/extsz=N, /' \
-e 's/blocks=[0-9][0-9]*/blocks=N/' \
-e 's/imaxpct=[0-9][0-9]*/imaxpct=N/' \
-e 's/agsize=[0-9][0-9]*/agsize=N/' \
-e 's/agcount=[0-9][0-9]*/agcount=N/' \
-e 's/swidth=[0-9][0-9]* blks$/&, unwritten=1/' \
-e 's/rtextents=[0-9][0-9]*/rtextents=N/' \
-e 's/meta-data=[^ ]*/meta-data=DEV/' \
-e 's/ *isize=[0-9]* / isize=N /' \
-e '/ *= *sectsz=[0-9][0-9]* *attr=[0-9][0-9]*.*$/d' \
-e '/ *= *mmr=[0-9][0-9]* *$/d' \
-e 's/ *mixed-case=[YN]//' \
-e 's/ *ascii-ci=[01]//' \
-e 's/\(version=\)\([12]\)/\1N/' \
-e 's/\(sunit=\)\([018] blks\)/\1N blks/' \
-e 's/sectsz=[0-9][0-9]* *//' \
-e 's/, lazy-count.*//' \
-e '/inode-paths/d' \
-e 's/\(log[ ]*=\).*bsize/\1LOG bsize/' \
-e 's/\(realtime[ ]*=\).*extsz/\1REALTIME extsz/' \
-e '/.*crc=/d' \
-e 's/ *$//' \
-e 's/ ftype=[01]//' \
-e '/^log stripe unit.*too large/d' \
-e '/^log stripe unit adjusted/d' \
| grep -v parent
}
# real QA test starts here
rm -f $seqres.full
# Modify as appropriate.
_supported_fs xfs
_supported_os IRIX Linux
_require_scratch
_require_v2log
# choose .out file based on internal/external log
rm -f $seqfull.out
if [ "$USE_EXTERNAL" = yes ]; then
ln -s $seq.external $seqfull.out
else
ln -s $seq.internal $seqfull.out
fi
# maximum log record size
max_lr_size=`expr 256 \* 1024`
big_su=`expr $max_lr_size + 4096`
#
# Test out various mkfs param combinations
#
cat >$tmp.seq.params <<EOF
# su too big but must be a multiple of fs block size too
-l version=2,su=`expr $max_lr_size + 512`
# test log stripe greater than LR size
-l version=2,su=$big_su
# same test but get log stripe from data stripe
-l version=2 -d su=$big_su,sw=1
# test out data stripe
-m crc=0 -l version=1 -d su=$big_su,sw=1
# test out data stripe the same but using sunit & swidth
-m crc=0 -l version=1 -d sunit=`expr $big_su / 512`,swidth=`expr $big_su / 512`
EOF
#
# call mkfs in a loop for various params
#
echo ""
cat $tmp.seq.params \
| while read mkfs
do
if echo $mkfs | grep -q '^#'; then
# print out header & ignore comment
echo $mkfs
continue
fi
echo "--- mkfs=$mkfs ---"
export MKFS_OPTIONS="$mkfs"
_scratch_mkfs_xfs 2>&1 | mkfs_filter
echo ""
echo ""
done
# success, all done
status=0
exit