[parted-devel] [PATCH 04/10] Add test to verify that the "md" devices are not getting listed.
Joel Granados Moreno
jgranado at redhat.com
Tue Jun 9 11:35:01 UTC 2009
* tests/t6001-dm-ignored.sh : New test file.
* tests/Makefile.am : add test to the test list.
---
tests/Makefile.am | 1 +
tests/t6001-dm-ignoremd.sh | 85 ++++++++++++++++++++++++++++++++++++++++++++
2 files changed, 86 insertions(+), 0 deletions(-)
create mode 100755 tests/t6001-dm-ignoremd.sh
diff --git a/tests/Makefile.am b/tests/Makefile.am
index 2931e98..de09d38 100644
--- a/tests/Makefile.am
+++ b/tests/Makefile.am
@@ -19,6 +19,7 @@ TESTS = \
t4200-partprobe.sh \
t5000-tags.sh \
t6000-dm.sh \
+ t6001-dm-ignoremd.sh \
t7000-scripting.sh \
t8000-loop.sh
diff --git a/tests/t6001-dm-ignoremd.sh b/tests/t6001-dm-ignoremd.sh
new file mode 100755
index 0000000..4fd9763
--- /dev/null
+++ b/tests/t6001-dm-ignoremd.sh
@@ -0,0 +1,85 @@
+#!/bin/sh
+
+# Copyright (C) 2008 Free Software Foundation, Inc.
+
+# This program is free software; you can redistribute it and/or modify
+# it under the terms of the GNU General Public License as published by
+# the Free Software Foundation; either version 3 of the License, or
+# (at your option) any later version.
+
+# This program is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+# GNU General Public License for more details.
+
+# You should have received a copy of the GNU General Public License
+# along with this program. If not, see <http://www.gnu.org/licenses/>.
+
+test_description='Ignore devices that start with md from /sys/block.'
+
+privileges_required_=1
+# This will setup private /dev and /etc
+device_mapper_required_=1
+
+: ${srcdir=.}
+. $srcdir/test-lib.sh
+
+test "x$ENABLE_DEVICE_MAPPER" = xyes ||
+ {
+ say "skipping $0: no device-mapper support"
+ test_done
+ exit
+ }
+
+test -d /sys/block ||
+ {
+ say "skipping $0: system does not have /sys/block"
+ test_done
+ exit
+ }
+
+which mdadm > /dev/null 2>&1 ||
+ {
+ say "skipping $0: could not find mdadm executable"
+ test_done
+ exit
+ }
+
+# The md device.
+mddev_=
+
+cleanup_() {
+ mdadm --stop $mddev_ > /dev/null 2>&1
+ test -n "$d1" && losetup -d "$d1"
+ rm -f "$f1";
+}
+
+md_dev_create_()
+{
+ lo_dev=$1
+ mdd=$G_dev_/md0
+ for i in 0 1 2 3 4 5 6 7 8 9 ; do
+ mdd=$G_dev_/md$i
+ mdadm --create --force $mdd --level=linear --raid-devices=1 $lo_dev > /dev/null 2>&1 \
+ && break
+
+ if [ $i -eq 9 ]; then echo $mdd ; return 1 ; fi
+ done
+
+ echo $mdd
+ return 0
+}
+
+test_expect_success \
+ 'setup: create loop devices' \
+ 'f1=$(pwd)/1 && d1=$(loop_setup_ "$f1")'
+
+test_expect_success \
+ 'setup: create md# device' \
+ 'mddev_=$(md_dev_create_ "$d1")'
+
+test_expect_failure \
+ 'grep for the created md device' \
+ 'parted -s -m -l | grep "Error:.*: unrecognised disk label"'
+
+test_done
--
1.6.0.6
More information about the parted-devel
mailing list