From 8f8c5580fda8f406483c7b44902a6e0202980463 Mon Sep 17 00:00:00 2001 From: Zdenek Kabelac Date: Mon, 19 Sep 2011 19:36:52 +0000 Subject: [PATCH] Add support for DM_DEV_DIR Follow other commands support this directory setting. Useful for test suite. --- WHATS_NEW | 2 +- man/fsadm.8.in | 4 ++++ scripts/fsadm.sh | 23 +++++++++++++---------- 3 files changed, 18 insertions(+), 11 deletions(-) mode change 100644 => 100755 scripts/fsadm.sh diff --git a/WHATS_NEW b/WHATS_NEW index 8d20f569a..420756f8c 100644 --- a/WHATS_NEW +++ b/WHATS_NEW @@ -1,6 +1,6 @@ Version 2.02.89 - ================================== - Add support for non /dev device paths into fsadm script. + Add support for DM_DEV_DIR device path into fsadm script. Support different PATH setting for fsadm script testing. Surround all executed commands with quotes in fsadm script. Fix missing '$' in test for content of "$LVM" in fsadm script. diff --git a/man/fsadm.8.in b/man/fsadm.8.in index 9f4756144..b7bd0a078 100644 --- a/man/fsadm.8.in +++ b/man/fsadm.8.in @@ -63,6 +63,10 @@ All [y|n] questions will be answered 'y'. .TP .B TMPDIR The temporary directory name for mount points. Defaults to "/tmp". +.TP +.B DM_DEV_DIR +The device directory name. +Defaults to "/dev" and must be an absolute path. .SH SEE ALSO .BR lvm (8), diff --git a/scripts/fsadm.sh b/scripts/fsadm.sh old mode 100644 new mode 100755 index 486d5541f..c8cc5e01c --- a/scripts/fsadm.sh +++ b/scripts/fsadm.sh @@ -67,12 +67,14 @@ DO_LVRESIZE=0 FSTYPE=unknown VOLUME=unknown TEMPDIR="${TMPDIR:-/tmp}/${TOOL}_${RANDOM}$$/m" +DM_DEV_DIR="${DM_DEV_DIR:-/dev}" BLOCKSIZE= BLOCKCOUNT= MOUNTPOINT= MOUNTED= REMOUNT= PROCMOUNTS="/proc/mounts" +NULL="$DM_DEV_DIR/null" IFS_OLD=$IFS # without bash $'\n' @@ -176,17 +178,18 @@ decode_size() { # dereference device name if it is symbolic link detect_fs() { VOLUME_ORIG=$1 - VOLUME=${1#/dev/} - VOLUME=$("$READLINK" $READLINK_E "/dev/$VOLUME") || VOLUME=$("$READLINK" $READLINK_E "$VOLUME_ORIG") || error "Cannot get readlink \"$1\"" + VOLUME=${1/#"${DM_DEV_DIR}/"/} + VOLUME=$("$READLINK" $READLINK_E "$DM_DEV_DIR/$VOLUME") || error "Cannot get readlink \"$1\"" RVOLUME=$VOLUME case "$RVOLUME" in + # hardcoded /dev since udev does not create these entries elsewhere /dev/dm-[0-9]*) - read &1 && VOLUME="/dev/mapper/$SYSVOLUME" + read &1 && VOLUME="$DM_DEV_DIR/mapper/$SYSVOLUME" ;; esac - # use /dev/null as cache file to be sure about the result + # use null device as cache file to be sure about the result # not using option '-o value' to be compatible with older version of blkid - FSTYPE=$("$BLKID" -c /dev/null -s TYPE "$VOLUME") || error "Cannot get FSTYPE of \"$VOLUME\"" + FSTYPE=$("$BLKID" -c "$NULL" -s TYPE "$VOLUME") || error "Cannot get FSTYPE of \"$VOLUME\"" FSTYPE=${FSTYPE##*TYPE=\"} # cut quotation marks FSTYPE=${FSTYPE%%\"*} verbose "\"$FSTYPE\" filesystem found on \"$VOLUME\"" @@ -221,7 +224,7 @@ detect_mounted() { # get the full size of device in bytes detect_device_size() { # check if blockdev supports getsize64 - "$BLOCKDEV" 2>&1 | "$GREP" getsize64 >/dev/null + "$BLOCKDEV" 2>&1 | "$GREP" getsize64 >"$NULL" if test $? -eq 0; then DEVSIZE=$("$BLOCKDEV" --getsize64 "$VOLUME") || error "Cannot read size of device \"$VOLUME\"" else @@ -389,7 +392,7 @@ resize() { # only one supported #################################### diff_dates() { - echo $(( $("$DATE" -u -d"$1" +%s 2>/dev/null) - $("$DATE" -u -d"$2" +%s 2>/dev/null) )) + echo $(( $("$DATE" -u -d"$1" +%s 2>"$NULL") - $("$DATE" -u -d"$2" +%s 2>"$NULL") )) } ################### @@ -451,11 +454,11 @@ test -n "$TUNE_EXT" -a -n "$RESIZE_EXT" -a -n "$TUNE_REISER" -a -n "$RESIZE_REIS -a -n "$DATE" -a -n "$FSCK" -a -n "$XFS_CHECK" -a -n "$LVM" \ || error "Required command definitions in the script are missing!" -"$LVM" version >/dev/null 2>&1 || error "Could not run lvm binary \"$LVM\"" -$("$READLINK" -e / >/dev/null 2>&1) || READLINK_E="-f" +"$LVM" version >"$NULL" 2>&1 || error "Could not run lvm binary \"$LVM\"" +$("$READLINK" -e / >"$NULL" 2>&1) || READLINK_E="-f" TEST64BIT=$(( 1000 * 1000000000000 )) test "$TEST64BIT" -eq 1000000000000000 || error "Shell does not handle 64bit arithmetic" -$(echo Y | "$GREP" Y >/dev/null) || error "Grep does not work properly" +$(echo Y | "$GREP" Y >"$NULL") || error "Grep does not work properly" test $("$DATE" -u -d"Jan 01 00:00:01 1970" +%s) -eq 1 || error "Date translation does not work" -- 2.43.5