X-Spam-Checker-Version: SpamAssassin 3.4.0-r929098 (2010-03-30) on oss.sgi.com X-Spam-Level: X-Spam-Status: No, score=-1.8 required=5.0 tests=BAYES_00,J_CHICKENPOX_45 autolearn=no version=3.4.0-r929098 Received: from cuda.sgi.com (cuda1.sgi.com [192.48.157.11]) by oss.sgi.com (8.14.3/8.14.3/SuSE Linux 0.8) with ESMTP id q0CE6WO8259830 for ; Thu, 12 Jan 2012 08:06:33 -0600 X-ASG-Debug-ID: 1326377189-00a9eb65e41b3230001-NocioJ Received: from hades.usersys.redhat.com (186.215.132.159.static.gvt.net.br [186.215.132.159]) by cuda.sgi.com with ESMTP id HwWzGhlgZEdC9Ad6 for ; Thu, 12 Jan 2012 06:06:30 -0800 (PST) X-Barracuda-Envelope-From: cmaiolino@hades.usersys.redhat.com X-Barracuda-Apparent-Source-IP: 186.215.132.159 Received: by hades.usersys.redhat.com (Postfix, from userid 500) id 87471E0EA2; Thu, 12 Jan 2012 12:06:28 -0200 (BRST) From: Carlos Maiolino To: xfs@oss.sgi.com Cc: Carlos Maiolino Subject: [PATCH] xfstests 278: Ensure lost+found is not created with wrong link count (V4) Date: Thu, 12 Jan 2012 12:06:27 -0200 X-ASG-Orig-Subj: [PATCH] xfstests 278: Ensure lost+found is not created with wrong link count (V4) Message-Id: <1326377187-27344-1-git-send-email-cmaiolino@redhat.com> X-Mailer: git-send-email 1.7.6.4 X-Barracuda-Connect: 186.215.132.159.static.gvt.net.br[186.215.132.159] X-Barracuda-Start-Time: 1326377189 X-Barracuda-URL: http://cuda.sgi.com:80/cgi-mod/mark.cgi X-Virus-Scanned: ClamAV version 0.94.2, clamav-milter version 0.94.2 on oss.sgi.com X-Virus-Scanned: by bsmtpd at sgi.com X-Barracuda-Spam-Score: 0.00 X-Barracuda-Spam-Status: No, SCORE=0.00 using per-user scores of TAG_LEVEL=2.0 QUARANTINE_LEVEL=1000.0 KILL_LEVEL=2.1 tests= X-Barracuda-Spam-Report: Code version 3.2, rules version 3.2.2.85724 Rule breakdown below pts rule name description ---- ---------------------- -------------------------------------------------- X-Virus-Status: Clean xfs_repair was leaving lost+found directory with a wrong link count when a cleaned inode was re-used to create lost+found. This test case confirm that, after xfs_repair is executed, the lost+found inode is left in a consistent state. Signed-off-by: Carlos Maiolino --- 278 | 87 +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ 278.out | 2 + group | 1 + 3 files changed, 90 insertions(+), 0 deletions(-) create mode 100755 278 create mode 100644 278.out diff --git a/278 b/278 new file mode 100755 index 0000000..89cae35 --- /dev/null +++ b/278 @@ -0,0 +1,87 @@ +#! /bin/bash +# FS QA Test No. 278 +# +# Test xfs_repair to ensure it fixes the lost+found link count +# at the first run. See also commit 198b747f255346bca64408875763b6ca0ed3d57d +# from xfsprogs tree. +# +# +#----------------------------------------------------------------------- +# Copyright (c) 2011 Red Hat, 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 +#----------------------------------------------------------------------- +# +# creator +owner=cmaiolino@redhat.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.* +} + +# get standard environment, filters and checks +. ./common.rc +. ./common.filter + +# real QA test starts here +_supported_fs xfs +_supported_os Linux +_require_scratch +_scratch_mkfs >/dev/null 2>&1 +_scratch_mount + +mkdir -p $SCRATCH_MNT/dir/subdir + +#get inodes to be changed +DIR_INO=`ls -i $SCRATCH_MNT |awk '{print $1}'` +SUBDIR_INO=`ls -i $SCRATCH_MNT/dir |awk '{print $1}'` + +_scratch_unmount + +echo "Silence is goodness..." + +# Corrupt DIR +xfs_db -x -c "inode $DIR_INO" -c "write u.sfdir2.list[0].inumber.i4 0" $SCRATCH_DEV >> $seq.full +xfs_db -x -c "inode $DIR_INO" -c "write u.sfdir2.list[0].name 0" $SCRATCH_DEV >> $seq.full +xfs_db -x -c "inode $DIR_INO" -c "write u.sfdir2.list[0].offset 0" $SCRATCH_DEV >> $seq.full +xfs_db -x -c "inode $DIR_INO" -c "write u.sfdir2.list[0].namelen 0" $SCRATCH_DEV >> $seq.full +xfs_db -x -c "inode $DIR_INO" -c "write u.sfdir2.hdr.parent.i4 0" $SCRATCH_DEV >> $seq.full +xfs_db -x -c "inode $DIR_INO" -c "write core.nlinkv2 0" $SCRATCH_DEV >> $seq.full + +# Corrupt SUBDIR +xfs_db -x -c "inode $SUBDIR_INO" -c "write u.sfdir2.hdr.parent.i4 0" $SCRATCH_DEV >> $seq.full +xfs_db -x -c "inode $SUBDIR_INO" -c "write core.nlinkv2 0" $SCRATCH_DEV >> $seq.full + +echo "===== BEGIN of xfs_repair =====" >> $seq.full +echo "" >>$seq.full + +xfs_repair $SCRATCH_DEV >> $seq.full 2>&1 +echo "===== END of xfs_repair =====" >> $seq.full + +if _check_scratch_fs; then + status=0 +else + status=1 +fi +exit diff --git a/278.out b/278.out new file mode 100644 index 0000000..2acd770 --- /dev/null +++ b/278.out @@ -0,0 +1,2 @@ +QA output created by 278 +Silence is goodness... diff --git a/group b/group index 99592d3..6f2d748 100644 --- a/group +++ b/group @@ -391,3 +391,4 @@ deprecated 275 auto rw 276 auto rw metadata 277 auto ioctl quick metadata +278 repair auto -- 1.7.6.4