Re: [PATCH] xfstests: support post-udev device mapper nodes

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



On Mon, 2011-05-02 at 12:02 -0400, Christoph Hellwig wrote:
> Because of udevs complaining device mapper now creates /dev/dm-N as the real
> device nodes, and just symlinks the /dev/mapper/ names to it.  This would be
> easy if everything used the /dev/mapper clear names, but most system utilities
> translate them back to the /dev/mapper/ names and thus confuse various test
> cases.  Add support to _is_block_dev to read symlinks, and add documentation
> on how to run xfstests on device mapper volumes.

I'm not 100% sure I'm parsing the above right.  What
I read is that, although we want to use the "real"
device (not the link), the utilities tend to report
the /dev/mapper names.  Therefore we want to use
/dev/mapper names and internally translate them to
their real devices.

Based on that understanding I think what you're trying
to do is fine, but there a few problems with what you sent.
Note that I'm not even looking at the specifics of
/dev/mapper links at the moment.

> Signed-off-by: Christoph Hellwig <hch@xxxxxx>
> 
> Index: xfstests-dev/common.rc
> ===================================================================
> --- xfstests-dev.orig/common.rc	2011-05-02 12:45:25.000000000 +0000
> +++ xfstests-dev/common.rc	2011-05-02 12:45:28.000000000 +0000
> @@ -587,7 +587,14 @@ _is_block_dev()
>  	exit 1
>      fi
>  
> -    [ -b $1 ] && src/lstat64 $1 | $AWK_PROG '/Device type:/ { print $9 }'
> +    _dev=$1
> +    if [ -L ${_dev} ]; then
> +        _dev=`readlink -f ${_dev}`

Although it typically shouldn't, if the "readlink -f" fails,
it will make _dev have an empty value...

> +    fi
> +
> +    if [ -b ${_dev} ]; then

...which will lead to some sort of shell "syntax error"
message here, which is rather unhelpful.

At a minimum, I think putting quotes around it here
would avoid that (but you should test), i.e.,
    if [ -b "${_dev}" ]; then

> +        src/lstat64 ${_dev} | $AWK_PROG '/Device type:/ { print $9 }'
> +    fi
>  }
>  
>  # Do a command, log it to $seq.full, optionally test return status
> @@ -700,10 +707,12 @@ _require_scratch()
>  	*)
>  		 if [ -z "$SCRATCH_DEV" -o "`_is_block_dev $SCRATCH_DEV`" = "" ]
>  		 then
> +		     echo "no a block device";

This and the next one appear to be junk that should
be removed.

>  		     _notrun "this test requires a valid \$SCRATCH_DEV"
>  		 fi
>  		 if [ "`_is_block_dev $SCRATCH_DEV`" = "`_is_block_dev $TEST_DEV`" ]
>  		 then
> +		    echo "foo"
>  		     _notrun "this test requires a valid \$SCRATCH_DEV"
>  		 fi
>  		if [ ! -d "$SCRATCH_MNT" ]
> Index: xfstests-dev/README.device-mapper
> ===================================================================
> --- /dev/null	1970-01-01 00:00:00.000000000 +0000
> +++ xfstests-dev/README.device-mapper	2011-05-02 15:51:24.000000000 +0000
> @@ -0,0 +1,8 @@
> +
> +To use xfstests on device mapper always use the /dev/mapper/<name> symlinks,
> +not the /dev/dm-* devices, or the symlinks created by LVM.
> +
> +For example:
> +
> +TEST_DEV=/dev/mapper/test
> +SCRATCH_DEV=/dev/mapper/scratch
> 
> _______________________________________________
> xfs mailing list
> xfs@xxxxxxxxxxx
> http://oss.sgi.com/mailman/listinfo/xfs



_______________________________________________
xfs mailing list
xfs@xxxxxxxxxxx
http://oss.sgi.com/mailman/listinfo/xfs


[Index of Archives]     [Linux XFS Devel]     [Linux Filesystem Development]     [Filesystem Testing]     [Linux USB Devel]     [Linux Audio Users]     [Yosemite News]     [Linux Kernel]     [Linux SCSI]

  Powered by Linux