[Top] [All Lists]

[PATCH] xfstests: unmount scratch mnt in test 307

To: <xfs@xxxxxxxxxxx>, <linux-btrfs@xxxxxxxxxxxxxxx>
Subject: [PATCH] xfstests: unmount scratch mnt in test 307
From: Josef Bacik <jbacik@xxxxxxxxxxxx>
Date: Fri, 3 May 2013 16:11:35 -0400
Delivered-to: xfs@xxxxxxxxxxx
Dkim-signature: v=1; a=rsa-sha256; c=relaxed/simple; d=fusionio.com; s=default; t=1367611898; bh=IBMrD/CaxlxFqq5kMjx11mtUk+tZFdES9u8yft7hcWA=; h=From:To:Subject:Date; b=MoHXyspDHU4uWFCLb2J5ZX92XhSUaJYO4NzalA4LnUSY73g4tJhuicGse668tSuP5 AryBARnfyTGh9xRqJq9X4gwZrsiNa3hJNWo6myecuckcO2lcEesMgdY9I3FxPA49Uf sWUcnG7D/LQ/uA1NP0xCXgP4vmYmxECZgcqc8WBw=
So if you have a mount command that doesn't use /etc/mtab then it will spit out
a different device for the mounted device.  So say we have

SCRATCH_DEV_POOL="/dev/sda /dev/sdb /dev/sdc"

we will turn this into

SCRATCH_DEV_POOL="/dev/sdb /dev/sdc"

and then when you mkfs this you do _scratch_mkfs $SCRATCH_DEV_POOL which turns
into this

mkfs.btrfs /dev/sdb /dev/sdc /dev/sda

becuase we do

mkfs $* $SCRATCH_DEV

Then btrfs will always show the lowest devid in /proc/mounts to maintain
consistency, so even though we do mount /dev/sda $SCRATCH_MNT, you will see
/dev/sdb as the mounted device in /proc/mounts.  So then say the next test wants
to just use $SCRATCH_DEV, it will do _require_scratchdev which will check to see
if $SCRATCH_DEV is mounted, which it will look like it is not because
/proc/mounts shows /dev/sdb instead of /dev/sda, and so it won't umount
$SCRATCH_MNT, and then that test will fail because we can't mkfs the device
because it is busy.  I reproduced this on a box that doesn't use /etc/mtab by

./check btrfs/307 generic/015

and 015 would fail.  With this patch it passes now.  Thanks,

Signed-off-by: Josef Bacik <jbacik@xxxxxxxxxxxx>
 tests/btrfs/307 |    1 +
 1 files changed, 1 insertions(+), 0 deletions(-)

diff --git a/tests/btrfs/307 b/tests/btrfs/307
index 87314c6..15157b3 100644
--- a/tests/btrfs/307
+++ b/tests/btrfs/307
@@ -35,6 +35,7 @@ _cleanup()
     cd /
     rm -f $tmp.*
+    umount $SCRATCH_MNT
 # get standard environment, filters and checks

<Prev in Thread] Current Thread [Next in Thread>