mirror of
https://github.com/linux-apfs/apfstests.git
synced 2026-05-01 15:01:44 -07:00
Create test 178 as described by bnaujok.
Merge of master-melb:xfs-cmds:29273a by kenmcd. New Test
This commit is contained in:
@@ -0,0 +1,84 @@
|
|||||||
|
#! /bin/sh
|
||||||
|
# FS QA Test No. 178
|
||||||
|
#
|
||||||
|
# Reproduce PV#:967665
|
||||||
|
# Test if mkfs.xfs wipes old AG headers when using -f option
|
||||||
|
#
|
||||||
|
#-----------------------------------------------------------------------
|
||||||
|
# Copyright (c) 2007 Silicon Graphics, Inc. All Rights Reserved.
|
||||||
|
#-----------------------------------------------------------------------
|
||||||
|
#
|
||||||
|
# creator
|
||||||
|
owner=mohamedb@sgi.com
|
||||||
|
|
||||||
|
seq=`basename $0`
|
||||||
|
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.*
|
||||||
|
}
|
||||||
|
# dd the 1st sector then repair
|
||||||
|
_dd_repair_check()
|
||||||
|
{
|
||||||
|
#dd first sector
|
||||||
|
dd if=/dev/zero of=$1 bs=$2 count=1 2>&1 | _filter_dd
|
||||||
|
#xfs_repair
|
||||||
|
_scratch_xfs_repair 2>&1 | _filter_repair
|
||||||
|
#check repair
|
||||||
|
if _check_scratch_fs; then
|
||||||
|
echo "repair passed"
|
||||||
|
else
|
||||||
|
echo "repair failed!"
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
# get standard environment, filters and checks
|
||||||
|
. ./common.rc
|
||||||
|
. ./common.filter
|
||||||
|
. ./common.repair
|
||||||
|
|
||||||
|
# real QA test starts here
|
||||||
|
|
||||||
|
# Modify as appropriate.
|
||||||
|
_supported_fs xfs
|
||||||
|
_supported_os Linux
|
||||||
|
|
||||||
|
# From the PV
|
||||||
|
# o Summary of testing:
|
||||||
|
# 1. mkfs.xfs a default filesystem, note agcount value.
|
||||||
|
# 2. dd zero first sector and repair and verify.
|
||||||
|
# 3. mkfs.xfs overriding agcount to a smaller value
|
||||||
|
# (ie. each AG is bigger)
|
||||||
|
# 4. dd zero first sector, repair and verify.
|
||||||
|
# -> old mkfs.xfs will cause repair to incorrectly
|
||||||
|
# fix filesystem, new mkfs.xfs will be fine.
|
||||||
|
|
||||||
|
_require_scratch
|
||||||
|
_scratch_mkfs_xfs | _filter_mkfs 2>$tmp.mkfs \
|
||||||
|
|| _fail "mkfs failed!"
|
||||||
|
|
||||||
|
# By executing the followint tmp file, will get on the mkfs options stored in
|
||||||
|
# variables
|
||||||
|
. $tmp.mkfs
|
||||||
|
|
||||||
|
[ $agcount -le 2 ] && _notrun "Test requires more than 2 AGs."
|
||||||
|
|
||||||
|
_dd_repair_check $SCRATCH_DEV $sectsz
|
||||||
|
|
||||||
|
# smaller AGCOUNT
|
||||||
|
let "agcount=$agcount-2"
|
||||||
|
_scratch_mkfs_xfs -dagcount=$agcount >/dev/null 2>&1 \
|
||||||
|
|| _fail "mkfs failed!"
|
||||||
|
|
||||||
|
_dd_repair_check $SCRATCH_DEV $sectsz
|
||||||
|
|
||||||
|
# success, all done
|
||||||
|
status=0
|
||||||
|
exit
|
||||||
@@ -0,0 +1,79 @@
|
|||||||
|
QA output created by 178
|
||||||
|
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
|
||||||
|
Phase 1 - find and verify superblock...
|
||||||
|
bad primary superblock - bad magic number !!!
|
||||||
|
|
||||||
|
attempting to find secondary superblock...
|
||||||
|
found candidate secondary superblock...
|
||||||
|
verified secondary superblock...
|
||||||
|
writing modified primary superblock
|
||||||
|
sb root inode value INO inconsistent with calculated value INO
|
||||||
|
resetting superblock root inode pointer to INO
|
||||||
|
sb realtime bitmap inode INO inconsistent with calculated value INO
|
||||||
|
resetting superblock realtime bitmap ino pointer to INO
|
||||||
|
sb realtime summary inode INO inconsistent with calculated value INO
|
||||||
|
resetting superblock realtime summary ino pointer to INO
|
||||||
|
Phase 2 - using <TYPEOF> log
|
||||||
|
- zero log...
|
||||||
|
- scan filesystem freespace and inode maps...
|
||||||
|
- found root inode chunk
|
||||||
|
Phase 3 - for each AG...
|
||||||
|
- scan and clear agi unlinked lists...
|
||||||
|
- process known inodes and perform inode discovery...
|
||||||
|
- process newly discovered inodes...
|
||||||
|
Phase 4 - check for duplicate blocks...
|
||||||
|
- setting up duplicate extent list...
|
||||||
|
- check for inodes claiming duplicate blocks...
|
||||||
|
Phase 5 - rebuild AG headers and trees...
|
||||||
|
- reset superblock...
|
||||||
|
Phase 6 - check inode connectivity...
|
||||||
|
- resetting contents of realtime bitmap and summary inodes
|
||||||
|
- traversing filesystem ...
|
||||||
|
- traversal finished ...
|
||||||
|
- moving disconnected inodes to lost+found ...
|
||||||
|
Phase 7 - verify and correct link counts...
|
||||||
|
Note - stripe unit (0) and width (0) fields have been reset.
|
||||||
|
Please set with mount -o sunit=<value>,swidth=<value>
|
||||||
|
done
|
||||||
|
repair passed
|
||||||
|
Phase 1 - find and verify superblock...
|
||||||
|
bad primary superblock - bad magic number !!!
|
||||||
|
|
||||||
|
attempting to find secondary superblock...
|
||||||
|
found candidate secondary superblock...
|
||||||
|
verified secondary superblock...
|
||||||
|
writing modified primary superblock
|
||||||
|
sb root inode value INO inconsistent with calculated value INO
|
||||||
|
resetting superblock root inode pointer to INO
|
||||||
|
sb realtime bitmap inode INO inconsistent with calculated value INO
|
||||||
|
resetting superblock realtime bitmap ino pointer to INO
|
||||||
|
sb realtime summary inode INO inconsistent with calculated value INO
|
||||||
|
resetting superblock realtime summary ino pointer to INO
|
||||||
|
Phase 2 - using <TYPEOF> log
|
||||||
|
- zero log...
|
||||||
|
- scan filesystem freespace and inode maps...
|
||||||
|
- found root inode chunk
|
||||||
|
Phase 3 - for each AG...
|
||||||
|
- scan and clear agi unlinked lists...
|
||||||
|
- process known inodes and perform inode discovery...
|
||||||
|
- process newly discovered inodes...
|
||||||
|
Phase 4 - check for duplicate blocks...
|
||||||
|
- setting up duplicate extent list...
|
||||||
|
- check for inodes claiming duplicate blocks...
|
||||||
|
Phase 5 - rebuild AG headers and trees...
|
||||||
|
- reset superblock...
|
||||||
|
Phase 6 - check inode connectivity...
|
||||||
|
- resetting contents of realtime bitmap and summary inodes
|
||||||
|
- traversing filesystem ...
|
||||||
|
- traversal finished ...
|
||||||
|
- moving disconnected inodes to lost+found ...
|
||||||
|
Phase 7 - verify and correct link counts...
|
||||||
|
Note - stripe unit (0) and width (0) fields have been reset.
|
||||||
|
Please set with mount -o sunit=<value>,swidth=<value>
|
||||||
|
done
|
||||||
|
repair passed
|
||||||
@@ -124,6 +124,9 @@ _filter_mkfs()
|
|||||||
print STDERR "ddev=$1\nisize=$2\nagcount=$3\nagsize=$4\n";
|
print STDERR "ddev=$1\nisize=$2\nagcount=$3\nagsize=$4\n";
|
||||||
print STDOUT "meta-data=DDEV isize=XXX agcount=N, agsize=XXX blks\n";
|
print STDOUT "meta-data=DDEV isize=XXX agcount=N, agsize=XXX blks\n";
|
||||||
}
|
}
|
||||||
|
if (/^\s+=\s+sectsz=(\d+)\s+attr=(\d+)/) {
|
||||||
|
print STDERR "sectsz=$1\nattr=$2\n";
|
||||||
|
}
|
||||||
if (/^data\s+=\s+bsize=(\d+)\s+blocks=(\d+), imaxpct=(\d+)/) {
|
if (/^data\s+=\s+bsize=(\d+)\s+blocks=(\d+), imaxpct=(\d+)/) {
|
||||||
print STDERR "dbsize=$1\ndblocks=$2\nimaxpct=$3\n";
|
print STDERR "dbsize=$1\ndblocks=$2\nimaxpct=$3\n";
|
||||||
print STDOUT "data = bsize=XXX blocks=XXX, imaxpct=PCT\n";
|
print STDOUT "data = bsize=XXX blocks=XXX, imaxpct=PCT\n";
|
||||||
|
|||||||
Reference in New Issue
Block a user