Blame SOURCES/parted-3.1-tests-cleanup-losetup-usage.patch

fc4a62
From a1aa9eb26f357bb1a5111eb332594dfb7b39ace0 Mon Sep 17 00:00:00 2001
fc4a62
From: "Brian C. Lane" <bcl@redhat.com>
fc4a62
Date: Mon, 15 Oct 2012 17:27:18 -0700
fc4a62
Subject: [PATCH 1/2] tests: cleanup losetup usage
fc4a62
fc4a62
The unsafe_losetup_ function was failing because losetup didn't
fc4a62
recognize that the 'private' /dev/loopX devices were the same as
fc4a62
/dev/loopX, it would fail even if one was in use. Switch to using
fc4a62
losetup --show which is a cleaner solution.
fc4a62
Also use sparse file for loop_setup to save space.
fc4a62
---
fc4a62
 tests/lvm-utils.sh     | 24 ++----------------------
fc4a62
 tests/t-lvm.sh         | 24 ++----------------------
fc4a62
 tests/t6001-psep.sh    |  8 ++------
fc4a62
 tests/t6003-dm-uuid.sh |  3 +--
fc4a62
 4 files changed, 7 insertions(+), 52 deletions(-)
fc4a62
fc4a62
diff --git a/tests/lvm-utils.sh b/tests/lvm-utils.sh
fc4a62
index 456d265..a204b08 100644
fc4a62
--- a/tests/lvm-utils.sh
fc4a62
+++ b/tests/lvm-utils.sh
fc4a62
@@ -16,34 +16,14 @@ export LVM_SUPPRESS_FD_WARNINGS=1
fc4a62
 ME=$(basename "$0")
fc4a62
 warn() { echo >&2 "$ME: $@"; }
fc4a62
 
fc4a62
-unsafe_losetup_()
fc4a62
-{
fc4a62
-  f=$1
fc4a62
-
fc4a62
-  test -n "$G_dev_" \
fc4a62
-    || fail_ "Internal error: unsafe_losetup_ called before init_root_dir_"
fc4a62
-
fc4a62
-  # Iterate through $G_dev_/loop{,/}{0,1,2,3,4,5,6,7,8,9}
fc4a62
-  for slash in '' /; do
fc4a62
-    for i in 0 1 2 3 4 5 6 7 8 9; do
fc4a62
-      dev=$G_dev_/loop$slash$i
fc4a62
-      losetup $dev > /dev/null 2>&1 && continue;
fc4a62
-      losetup "$dev" "$f" > /dev/null && { echo "$dev"; return 0; }
fc4a62
-      break
fc4a62
-    done
fc4a62
-  done
fc4a62
-
fc4a62
-  return 1
fc4a62
-}
fc4a62
-
fc4a62
 loop_setup_()
fc4a62
 {
fc4a62
   file=$1
fc4a62
-  dd if=/dev/zero of="$file" bs=1M count=1 seek=1000 > /dev/null 2>&1 \
fc4a62
+  dd if=/dev/null of="$file" bs=1M count=1 seek=1000 > /dev/null 2>&1 \
fc4a62
     || { warn "loop_setup_ failed: Unable to create tmp file $file"; return 1; }
fc4a62
 
fc4a62
   # NOTE: this requires a new enough version of losetup
fc4a62
-  dev=$(unsafe_losetup_ "$file") \
fc4a62
+  dev=$(losetup --show -f "$file") 2>/dev/null \
fc4a62
     || { warn "loop_setup_ failed: Unable to create loopback device"; return 1; }
fc4a62
 
fc4a62
   echo "$dev"
fc4a62
diff --git a/tests/t-lvm.sh b/tests/t-lvm.sh
fc4a62
index b08f934..3c7657b 100644
fc4a62
--- a/tests/t-lvm.sh
fc4a62
+++ b/tests/t-lvm.sh
fc4a62
@@ -16,34 +16,14 @@ export LVM_SUPPRESS_FD_WARNINGS=1
fc4a62
 ME=$(basename "$0")
fc4a62
 warn() { echo >&2 "$ME: $@"; }
fc4a62
 
fc4a62
-unsafe_losetup_()
fc4a62
-{
fc4a62
-  f=$1
fc4a62
-
fc4a62
-  test -n "$G_dev_" \
fc4a62
-    || error "Internal error: unsafe_losetup_ called before init_root_dir_"
fc4a62
-
fc4a62
-  # Iterate through $G_dev_/loop{,/}{0,1,2,3,4,5,6,7,8,9}
fc4a62
-  for slash in '' /; do
fc4a62
-    for i in 0 1 2 3 4 5 6 7 8 9; do
fc4a62
-      dev=$G_dev_/loop$slash$i
fc4a62
-      losetup $dev > /dev/null 2>&1 && continue;
fc4a62
-      losetup "$dev" "$f" > /dev/null && { echo "$dev"; return 0; }
fc4a62
-      break
fc4a62
-    done
fc4a62
-  done
fc4a62
-
fc4a62
-  return 1
fc4a62
-}
fc4a62
-
fc4a62
 loop_setup_()
fc4a62
 {
fc4a62
   file=$1
fc4a62
-  dd if=/dev/zero of="$file" bs=1M count=1 seek=1000 > /dev/null 2>&1 \
fc4a62
+  dd if=/dev/null of="$file" bs=1M count=1 seek=1000 > /dev/null 2>&1 \
fc4a62
     || { warn "loop_setup_ failed: Unable to create tmp file $file"; return 1; }
fc4a62
 
fc4a62
   # NOTE: this requires a new enough version of losetup
fc4a62
-  dev=$(unsafe_losetup_ "$file" 2>/dev/null) \
fc4a62
+  dev=$(losetup --show -f "$file") 2>/dev/null \
fc4a62
     || { warn "loop_setup_ failed: Unable to create loopback device"; return 1; }
fc4a62
 
fc4a62
   echo "$dev"
fc4a62
diff --git a/tests/t6001-psep.sh b/tests/t6001-psep.sh
fc4a62
index 490c6d2..1859ac9 100644
fc4a62
--- a/tests/t6001-psep.sh
fc4a62
+++ b/tests/t6001-psep.sh
fc4a62
@@ -44,14 +44,10 @@ cleanup_fn_() {
fc4a62
 # create a file of size N bytes
fc4a62
 N=10M
fc4a62
 
fc4a62
-# create the test file
fc4a62
-f1=$(pwd)/1; dd if=/dev/null of=$f1 bs=1 seek=$N 2> /dev/null || fail=1
fc4a62
-f2=$(pwd)/2; dd if=/dev/null of=$f2 bs=1 seek=$N 2> /dev/null || fail=1
fc4a62
-
fc4a62
-d1=$(loop_setup_ "$f1") \
fc4a62
+f1=$(pwd)/1; d1=$(loop_setup_ "$f1") \
fc4a62
   || skip_ "is this partition mounted with 'nodev'?"
fc4a62
 
fc4a62
-d2=$(loop_setup_ "$f2") \
fc4a62
+f2=$(pwd)/2 ;d2=$(loop_setup_ "$f2") \
fc4a62
   || skip_ "is this partition mounted with 'nodev'?"
fc4a62
 
fc4a62
 dmsetup_cmd="0 `blockdev --getsz $d1` linear $d1 0"
fc4a62
diff --git a/tests/t6003-dm-uuid.sh b/tests/t6003-dm-uuid.sh
fc4a62
index 1751cb4..f58cb06 100755
fc4a62
--- a/tests/t6003-dm-uuid.sh
fc4a62
+++ b/tests/t6003-dm-uuid.sh
fc4a62
@@ -36,8 +36,7 @@ cleanup_() {
fc4a62
 }
fc4a62
 
fc4a62
 # create a file large enough to hold a GPT partition table
fc4a62
-dd if=/dev/null of=$loop_file bs=$ss seek=$ns || framework_failure
fc4a62
-dev=$(losetup --show -f $loop_file) || framework_failure
fc4a62
+dev=$(loop_setup_ $loop_file) || framework_failure
fc4a62
 dmsetup create $dm_name --table "0 $ns linear $dev 0" || framework_failure
fc4a62
 dmsetup rename $dm_name --setuuid f139317b-f98a-45d7-ab3b-9b4e0a336872 || framework_failure
fc4a62
 
fc4a62
-- 
fc4a62
1.7.11.4
fc4a62