Add extra test cases for growfs

Merge of master-melb:xfs-cmds:29854a by kenmcd.

  Modify the loop back grow function to include a flag for checking the fs after growin and added few more growfs test cases that are less 16TB
This commit is contained in:
Mohamed Barwani
2007-10-09 06:11:20 +00:00
parent 1aaaa8eef2
commit 9c1fdb6404
3 changed files with 212 additions and 35 deletions
+51 -12
View File
@@ -19,11 +19,6 @@ status=1
trap "_cleanup; rm -f $tmp.*; exit \$status" 0 1 2 3 15
# get standard environment, filters and checks
. ./common.rc
. ./common.filter
_cleanup()
{
cd /
@@ -37,6 +32,11 @@ _cleanup()
. ./common.rc
. ./common.filter
# loop devices are available in Linux only
_supported_fs xfs
_supported_os Linux
# Must have loop device
_require_loop
LOOP_DEV=$TEST_DIR/$seq.fs
@@ -48,7 +48,7 @@ _filter_io()
}
# real QA test starts here
_supported_fs xfs
echo "*** create loop mount point"
rm -f $LOOP_MNT 2>/dev/null
mkdir $LOOP_MNT || _fail "cannot create loopback mount point"
@@ -58,6 +58,7 @@ _grow_loop()
original=$1
new_size=$2
bsize=$3
check=$4
echo
echo "=== GROWFS (from $original to $new_size, $bsize blocksize)"
@@ -73,21 +74,59 @@ _grow_loop()
mount -t xfs -o loop $LOOP_DEV $LOOP_MNT
echo "*** grow loop filesystem"
xfs_growfs $LOOP_MNT | _filter_mkfs 2>/dev/null
#xfs_growfs $LOOP_MNT 2>&1 | grep -e "^data" #| _filter_growfs 2>/dev/null
xfs_growfs $LOOP_MNT 2>&1 | _filter_growfs 2>&1
echo "*** unmount and check"
echo "*** unmount"
umount $LOOP_MNT
# Large grows takes forever to check..
if [ "$check" -gt "0" ]
then
echo "*** check"
_check_xfs_filesystem $LOOP_DEV none none
fi
rm -f $LOOP_DEV
}
# Wes' problem sizes...
_grow_loop 168024b 1376452608 4096
_grow_loop 168024b 1376452608 4096 1
# Some other blocksize cases...
_grow_loop 168024b 1376452608 2048
_grow_loop 168024b 1376452608 512
_grow_loop 168024b 688230400 1024
_grow_loop 168024b 1376452608 2048 1
_grow_loop 168024b 1376452608 512 1
_grow_loop 168024b 688230400 1024 1
# Other corner cases suggested by dgc
# also the following doesn't check if the filesystem is consistent.
# - grow 1TB by 1.5TB (control)
_grow_loop 1t 2500g 4096 0
# - grow 1TB by 2.5TB (grow by > 2TB)
_grow_loop 1t 3500g 4096 0
# - grow 1TB by 3.5TB (grow past 4TB)
_grow_loop 1t 4500g 4096 0
# - grow 1TB by 4.5TB (grow by > 4TB)
_grow_loop 1t 5500g 4096 0
# - grow 1TB by 7.5TB (grow past 8TB)
_grow_loop 1t 8500g 4096 0
# - grow 1TB by 8.5TB (grow by > 8TB)
_grow_loop 1t 9500g 4096 0
# - grow 1TB by 14.5TB (grow by > 8TB)
_grow_loop 1t 15500g 4096 0
# - grow 1TB by 15TB (grow to 16TB)
_grow_loop 1t 16000g 4096 0
# It would be nice to go on, but this would require a totally new test in order
# to take care of 64-bit machines.
echo "*** all done"
status=0
+146 -22
View File
@@ -14,13 +14,10 @@ realtime =RDEV extsz=XXX blocks=XXX, rtextents=XXX
wrote 4096/4096 bytes at offset 1376452608
*** mount loop filesystem
*** grow loop filesystem
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
*** unmount and check
xfs_growfs --BlockSize=4096 --Blocks=168024
data blocks changed from 168024 to 336048
*** unmount
*** check
=== GROWFS (from 168024b to 1376452608, 2048 blocksize)
@@ -35,13 +32,10 @@ realtime =RDEV extsz=XXX blocks=XXX, rtextents=XXX
wrote 2048/2048 bytes at offset 1376452608
*** mount loop filesystem
*** grow loop filesystem
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
*** unmount and check
xfs_growfs --BlockSize=2048 --Blocks=168024
data blocks changed from 168024 to 672096
*** unmount
*** check
=== GROWFS (from 168024b to 1376452608, 512 blocksize)
@@ -56,13 +50,10 @@ realtime =RDEV extsz=XXX blocks=XXX, rtextents=XXX
wrote 512/512 bytes at offset 1376452608
*** mount loop filesystem
*** grow loop filesystem
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
*** unmount and check
xfs_growfs --BlockSize=512 --Blocks=163840
data blocks changed from 163840 to 2688384
*** unmount
*** check
=== GROWFS (from 168024b to 688230400, 1024 blocksize)
@@ -77,11 +68,144 @@ realtime =RDEV extsz=XXX blocks=XXX, rtextents=XXX
wrote 1024/1024 bytes at offset 688230400
*** mount loop filesystem
*** grow loop filesystem
xfs_growfs --BlockSize=1024 --Blocks=168024
data blocks changed from 168024 to 672096
*** unmount
*** check
=== GROWFS (from 1t to 2500g, 4096 blocksize)
*** mkfs loop file (size=1t)
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
*** unmount and check
*** extend loop file
wrote 4096/4096 bytes at offset 2684354560000
*** mount loop filesystem
*** grow loop filesystem
xfs_growfs --BlockSize=4096 --Blocks=268435456
data blocks changed from 268435456 to 655360001
*** unmount
=== GROWFS (from 1t to 3500g, 4096 blocksize)
*** mkfs loop file (size=1t)
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
*** extend loop file
wrote 4096/4096 bytes at offset 3758096384000
*** mount loop filesystem
*** grow loop filesystem
xfs_growfs --BlockSize=4096 --Blocks=268435456
data blocks changed from 268435456 to 917504001
*** unmount
=== GROWFS (from 1t to 4500g, 4096 blocksize)
*** mkfs loop file (size=1t)
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
*** extend loop file
wrote 4096/4096 bytes at offset 4831838208000
*** mount loop filesystem
*** grow loop filesystem
xfs_growfs --BlockSize=4096 --Blocks=268435456
data blocks changed from 268435456 to 1179648001
*** unmount
=== GROWFS (from 1t to 5500g, 4096 blocksize)
*** mkfs loop file (size=1t)
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
*** extend loop file
wrote 4096/4096 bytes at offset 5905580032000
*** mount loop filesystem
*** grow loop filesystem
xfs_growfs --BlockSize=4096 --Blocks=268435456
data blocks changed from 268435456 to 1441792001
*** unmount
=== GROWFS (from 1t to 8500g, 4096 blocksize)
*** mkfs loop file (size=1t)
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
*** extend loop file
wrote 4096/4096 bytes at offset 9126805504000
*** mount loop filesystem
*** grow loop filesystem
xfs_growfs --BlockSize=4096 --Blocks=268435456
data blocks changed from 268435456 to 2228224001
*** unmount
=== GROWFS (from 1t to 9500g, 4096 blocksize)
*** mkfs loop file (size=1t)
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
*** extend loop file
wrote 4096/4096 bytes at offset 10200547328000
*** mount loop filesystem
*** grow loop filesystem
xfs_growfs --BlockSize=4096 --Blocks=268435456
data blocks changed from 268435456 to 2490368001
*** unmount
=== GROWFS (from 1t to 15500g, 4096 blocksize)
*** mkfs loop file (size=1t)
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
*** extend loop file
wrote 4096/4096 bytes at offset 16642998272000
*** mount loop filesystem
*** grow loop filesystem
xfs_growfs --BlockSize=4096 --Blocks=268435456
data blocks changed from 268435456 to 4063232001
*** unmount
=== GROWFS (from 1t to 16000g, 4096 blocksize)
*** mkfs loop file (size=1t)
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
*** extend loop file
wrote 4096/4096 bytes at offset 17179869184000
*** mount loop filesystem
*** grow loop filesystem
xfs_growfs --BlockSize=4096 --Blocks=268435456
data blocks changed from 268435456 to 4194304000
*** unmount
*** all done
+14
View File
@@ -153,5 +153,19 @@ _filter_mkfs()
}'
}
# prints the bits we care about in growfs
#
_filter_growfs()
{
perl -ne '
if (/^data\s+=\s+bsize=(\d+)\s+blocks=(\d+), imaxpct=(\d+)/) {
print "xfs_growfs --BlockSize=$1 --Blocks=$2\n";
}
elsif (/^data/) {
print;
}'
}
# make sure this script returns success
/bin/true