Blame SOURCES/0035-tests-Add-udevadm-settle-to-wait_for_-loop-1260664.patch

fc4a62
From 0d00bd73ba85c18082cbe47dd76e2adeba7e8620 Mon Sep 17 00:00:00 2001
fc4a62
From: "Brian C. Lane" <bcl@redhat.com>
fc4a62
Date: Tue, 1 Mar 2016 10:38:26 -0800
fc4a62
Subject: [PATCH] tests: Add udevadm settle to wait_for_ loop (#1260664)
fc4a62
fc4a62
Sometimes the device will vanish after the wait_for_dev_to_appear exits.
fc4a62
Add udevadm settle in an attempt to make sure the udev system is done
fc4a62
flapping around and the device will stay in place.
fc4a62
fc4a62
Related: rhbz#1260664
fc4a62
---
fc4a62
 tests/t-lib-helpers.sh            | 2 ++
fc4a62
 tests/t-local.sh                  | 2 ++
fc4a62
 tests/t6001-psep.sh               | 2 ++
fc4a62
 tests/t6002-dm-many-partitions.sh | 1 +
fc4a62
 tests/t6003-dm-uuid.sh            | 2 ++
fc4a62
 tests/t6100-mdraid-partitions.sh  | 1 +
fc4a62
 6 files changed, 10 insertions(+)
fc4a62
fc4a62
diff --git a/tests/t-lib-helpers.sh b/tests/t-lib-helpers.sh
fc4a62
index 4b3c122..b65d675 100644
fc4a62
--- a/tests/t-lib-helpers.sh
fc4a62
+++ b/tests/t-lib-helpers.sh
fc4a62
@@ -371,6 +371,7 @@ wait_for_dev_to_appear_()
fc4a62
   local i=0
fc4a62
   local incr=1
fc4a62
   while :; do
fc4a62
+    udevadm settle
fc4a62
     ls "$file" > /dev/null 2>&1 && return 0
fc4a62
     sleep .1 2>/dev/null || { sleep 1; incr=10; }
fc4a62
     i=$(expr $i + $incr); test $i = 20 && break
fc4a62
@@ -386,6 +387,7 @@ wait_for_dev_to_disappear_()
fc4a62
   local i=0
fc4a62
   local incr=1
fc4a62
   while :; do
fc4a62
+    udevadm settle
fc4a62
     ls "$file" > /dev/null 2>&1 || return 0
fc4a62
     sleep .1 2>/dev/null || { sleep 1; incr=10; }
fc4a62
     i=$(expr $i + $incr); test $i -ge $(expr $n_sec \* 10) && break
fc4a62
diff --git a/tests/t-local.sh b/tests/t-local.sh
fc4a62
index dde1b8d..5305865 100644
fc4a62
--- a/tests/t-local.sh
fc4a62
+++ b/tests/t-local.sh
fc4a62
@@ -47,6 +47,7 @@ wait_for_dev_to_appear_()
fc4a62
   local i=0
fc4a62
   local incr=1
fc4a62
   while :; do
fc4a62
+    udevadm settle
fc4a62
     ls "$file" > /dev/null 2>&1 && return 0
fc4a62
     sleep .1 2>/dev/null || { sleep 1; incr=10; }
fc4a62
     i=$(expr $i + $incr); test $i = 20 && break
fc4a62
@@ -110,6 +111,7 @@ scsi_debug_setup_()
fc4a62
   local i=0
fc4a62
   local new_dev
fc4a62
   while :; do
fc4a62
+    udevadm settle
fc4a62
     new_dev=$(new_sdX_) && break
fc4a62
     sleep .1 2>/dev/null || { sleep 1; incr=10; }
fc4a62
     i=$(expr $i + $incr); test $i = 20 && break
fc4a62
diff --git a/tests/t6001-psep.sh b/tests/t6001-psep.sh
fc4a62
index b747732..f22c877 100644
fc4a62
--- a/tests/t6001-psep.sh
fc4a62
+++ b/tests/t6001-psep.sh
fc4a62
@@ -20,6 +20,8 @@
fc4a62
 . "${srcdir=.}/init.sh"; path_prepend_ ../parted
fc4a62
 
fc4a62
 require_root_
fc4a62
+require_udevadm_settle_
fc4a62
+
fc4a62
 (dmsetup --help) > /dev/null 2>&1 || skip_test_ "No dmsetup installed"
fc4a62
 
fc4a62
 # Device maps names - should be random to not conflict with existing ones on
fc4a62
diff --git a/tests/t6002-dm-many-partitions.sh b/tests/t6002-dm-many-partitions.sh
fc4a62
index 247c9ee..13894f5 100755
fc4a62
--- a/tests/t6002-dm-many-partitions.sh
fc4a62
+++ b/tests/t6002-dm-many-partitions.sh
fc4a62
@@ -20,6 +20,7 @@
fc4a62
 . "${srcdir=.}/init.sh"; path_prepend_ ../parted
fc4a62
 
fc4a62
 require_root_
fc4a62
+require_udevadm_settle_
fc4a62
 (dmsetup --help) > /dev/null 2>&1 || skip_test_ "No dmsetup installed"
fc4a62
 
fc4a62
 ss=$sector_size_
fc4a62
diff --git a/tests/t6003-dm-uuid.sh b/tests/t6003-dm-uuid.sh
fc4a62
index f58cb06..f51e45f 100755
fc4a62
--- a/tests/t6003-dm-uuid.sh
fc4a62
+++ b/tests/t6003-dm-uuid.sh
fc4a62
@@ -20,6 +20,7 @@
fc4a62
 . "${srcdir=.}/init.sh"; path_prepend_ ../parted
fc4a62
 
fc4a62
 require_root_
fc4a62
+require_udevadm_settle_
fc4a62
 (dmsetup --help) > /dev/null 2>&1 || skip_test_ "No dmsetup installed"
fc4a62
 
fc4a62
 ss=$sector_size_
fc4a62
@@ -46,6 +47,7 @@ for ((i=1; i<=$n_partitions; i+=1)); do
fc4a62
   cmd="$cmd mkpart p$i ${s}s ${s}s"
fc4a62
 done
fc4a62
 parted -m -a min -s /dev/mapper/$dm_name mklabel gpt $cmd > /dev/null 2>&1 || fail=1
fc4a62
+wait_for_dev_to_appear_ /dev/mapper/${dm_name}p${n_partitions} || fail=1
fc4a62
 
fc4a62
 # Make sure all the partitions have UUIDs
fc4a62
 for ((i=1; i<=$n_partitions; i+=1)); do
fc4a62
diff --git a/tests/t6100-mdraid-partitions.sh b/tests/t6100-mdraid-partitions.sh
fc4a62
index d7e7d6a..a74afe0 100755
fc4a62
--- a/tests/t6100-mdraid-partitions.sh
fc4a62
+++ b/tests/t6100-mdraid-partitions.sh
fc4a62
@@ -38,6 +38,7 @@ parted -s "$scsi_dev" mklabel gpt \
fc4a62
     mkpart p1 ext2 1M 4M \
fc4a62
     mkpart p2 ext2 5M 8M > out 2>&1 || fail=1
fc4a62
 compare /dev/null out || fail=1
fc4a62
+wait_for_dev_to_appear_ ${scsi_dev}2 || { fail=1; cat /proc/partitions; }
fc4a62
 
fc4a62
 cleanup_fn_() {
fc4a62
   # stop mdraid array
fc4a62
-- 
fc4a62
2.5.0
fc4a62