dcavalca / rpms / mdadm

Forked from rpms/mdadm 3 years ago
Clone

Blame SOURCES/mdadm-test-Add-disks-to-support-testing-phsical-devi.patch

b7f731
From 25357919d227fd907e4da167d0e07f33f9c94bca Mon Sep 17 00:00:00 2001
b7f731
From: Zhilong Liu <zlliu@suse.com>
b7f731
Date: Wed, 14 Jun 2017 21:02:53 +0800
b7f731
Subject: [RHEL7.5 PATCH 157/169] mdadm/test: Add '--disks=' to support
b7f731
 testing phsical devices
b7f731
b7f731
If test mode has set as '--dev=disk', then users can specify
b7f731
the argument of "--disks" to test a bunch of physical devices.
b7f731
For example: ./test --dev=disk --disks=/dev/sda{2..15}
b7f731
could execute all test cases on physical devices.
b7f731
b7f731
Currently, the --dev=disk mode would confilct with testdev()
b7f731
in current test cases, thus ignore testing testdev() if has
b7f731
set --dev=disk mode.
b7f731
b7f731
Signed-off-by: Zhilong Liu <zlliu@suse.com>
b7f731
Signed-off-by: Jes Sorensen <jsorensen@fb.com>
b7f731
---
b7f731
 test | 37 ++++++++++++++++++++++++++++++++-----
b7f731
 1 file changed, 32 insertions(+), 5 deletions(-)
b7f731
b7f731
diff --git a/test b/test
b7f731
index df2eeab..87e2df2 100755
b7f731
--- a/test
b7f731
+++ b/test
b7f731
@@ -73,11 +73,11 @@ save_log() {
b7f731
 	then
b7f731
 		# not supported lvm type yet
b7f731
 		echo
b7f731
-	elif [ $DEVTYPE == 'loop' ]
b7f731
+	elif [ "$DEVTYPE" == 'loop' -o "$DEVTYPE" == 'disk' ]
b7f731
 	then
b7f731
 		if [ ! -z ${array[@]} -a ${#array[@]} -ge 1 ]
b7f731
 		then
b7f731
-			md_disks=($($mdadm -D -Y ${array[@]} | grep "/dev/$DEVTYPE" | cut -d'=' -f2))
b7f731
+			md_disks=($($mdadm -D -Y ${array[@]} | grep "/dev/" | cut -d'=' -f2))
b7f731
 			cat /proc/mdstat | grep -q "bitmap"
b7f731
 			if [ $? -eq 0 ]
b7f731
 			then
b7f731
@@ -114,6 +114,9 @@ cleanup() {
b7f731
 			eval "lvremove --quiet -f \$dev$d"
b7f731
 		done
b7f731
 		;;
b7f731
+	disk )
b7f731
+		$mdadm --zero ${disks[@]} &> /dev/null
b7f731
+		;;
b7f731
 	esac
b7f731
 }
b7f731
 
b7f731
@@ -128,6 +131,7 @@ do_setup() {
b7f731
 	[ -d $logdir ] || mkdir -p $logdir
b7f731
 	dmesg -c > /dev/null
b7f731
 
b7f731
+	devlist=
b7f731
 	if [ "$DEVTYPE" == "loop" ]
b7f731
 	then
b7f731
 		# make sure there are no loop devices remaining.
b7f731
@@ -139,8 +143,22 @@ do_setup() {
b7f731
 			losetup -d /dev/loop[0-9]* 2> /dev/null
b7f731
 			sleep 0.2
b7f731
 		done
b7f731
+	elif [ "$DEVTYPE" == "disk" ]
b7f731
+	then
b7f731
+		if [ ! -z "$disks" ]
b7f731
+		then
b7f731
+			for d in $(seq 0 ${#disks[@]})
b7f731
+			do
b7f731
+				eval "dev$d=${disks[$d]}"
b7f731
+				eval devlist=\"\$devlist \$dev$d\"
b7f731
+				eval devlist$d=\"\$devlist\"
b7f731
+			done
b7f731
+			$mdadm --zero ${disks[@]} &> /dev/null
b7f731
+		else
b7f731
+			echo "Forget to provide physical devices for disk mode."
b7f731
+			exit 1
b7f731
+		fi
b7f731
 	fi
b7f731
-	devlist=
b7f731
 	for d in 0 1 2 3 4 5 6 7 8 9 10 11 12 13
b7f731
 	do
b7f731
 		sz=$size
b7f731
@@ -320,6 +338,7 @@ no_errors() {
b7f731
 # basic device test
b7f731
 testdev() {
b7f731
 	[ -b $1 ] || die "$1 isn't a block device."
b7f731
+	[ "$DEVTYPE" == "disk" ] && return 0
b7f731
 	udevadm settle
b7f731
 	dev=$1
b7f731
 	cnt=$2
b7f731
@@ -383,6 +402,7 @@ do_test() {
b7f731
 do_help() {
b7f731
 	cat <<-EOF
b7f731
 	Usage: $0 [options]
b7f731
+	Example for disk mode: ./test --dev=disk --disks=/dev/sda{2..15}
b7f731
 	Options:
b7f731
 		--tests=test1,test2,...     Comma separated list of tests to run
b7f731
 		--raidtype=                 raid0|linear|raid1|raid456|raid10|ddf|imsm
b7f731
@@ -391,7 +411,8 @@ do_help() {
b7f731
 		--logdir=directory          Directory to save all logfiles in
b7f731
 		--save-logs                 Usually use with --logdir together
b7f731
 		--keep-going | --no-error   Don't stop on error, ie. run all tests
b7f731
-		--dev=loop|lvm|ram          Use loop devices (default), LVM, or RAM disk
b7f731
+		--dev=loop|lvm|ram|disk     Use loop devices (default), LVM, RAM or disk
b7f731
+		--disks=                    Provide a bunch of physical devices for test
b7f731
 		--volgroup=name             LVM volume group for LVM test
b7f731
 		setup                       Setup test environment and exit
b7f731
 		cleanup                     Cleanup test environment
b7f731
@@ -476,6 +497,9 @@ parse_args() {
b7f731
 			ram )
b7f731
 				DEVTYPE=ram
b7f731
 				;;
b7f731
+			disk )
b7f731
+				DEVTYPE=disk
b7f731
+				;;
b7f731
 			* )
b7f731
 				echo "Unknown argument: $i"
b7f731
 				do_help
b7f731
@@ -483,6 +507,9 @@ parse_args() {
b7f731
 				;;
b7f731
 			esac
b7f731
 			;;
b7f731
+		--disks=* )
b7f731
+			disks=(${disks[*]} ${i##*=})
b7f731
+			;;
b7f731
 		--volgroup=* )
b7f731
 			LVM_VOLGROUP=`expr "x$i" : 'x[^=]*=\(.*\)'`
b7f731
 			;;
b7f731
@@ -509,7 +536,7 @@ check_env() {
b7f731
 		echo "test: please run 'make everything' before perform testing."
b7f731
 		exit 1
b7f731
 	}
b7f731
-	cmds=(mdadm lsblk df udevadm losetup mkfs.ext3 fsck)
b7f731
+	cmds=(mdadm lsblk df udevadm losetup mkfs.ext3 fsck seq)
b7f731
 	for cmd in ${cmds[@]}
b7f731
 	do
b7f731
 		which $cmd > /dev/null || {
b7f731
-- 
b7f731
2.7.4
b7f731