mirror of
				https://git.proxmox.com/git/mirror_zfs.git
				synced 2025-10-25 17:35:00 +03:00 
			
		
		
		
	ZTS: Eliminate partitioning from zpool_add
Use file vdevs if we are short on $DISKS. Also fixed vol recursion for FreeBSD in 004. Reviewed-by: John Kennedy <john.kennedy@delphix.com> Reviewed-by: Brian Behlendorf <behlendorf1@llnl.gov> Signed-off-by: Ryan Moeller <ryan@iXsystems.com> Closes #10060
This commit is contained in:
		
							parent
							
								
									3f99a3abc7
								
							
						
					
					
						commit
						f0410e9806
					
				| @ -32,11 +32,4 @@ | |||||||
| . $STF_SUITE/include/libtest.shlib | . $STF_SUITE/include/libtest.shlib | ||||||
| . $STF_SUITE/tests/functional/cli_root/zpool_add/zpool_add.kshlib | . $STF_SUITE/tests/functional/cli_root/zpool_add/zpool_add.kshlib | ||||||
| 
 | 
 | ||||||
| DISK=${DISKS%% *} |  | ||||||
| if is_mpath_device $DISK; then |  | ||||||
|         delete_partitions |  | ||||||
| fi |  | ||||||
| 
 |  | ||||||
| cleanup_devices $DISKS |  | ||||||
| 
 |  | ||||||
| log_pass | log_pass | ||||||
|  | |||||||
| @ -34,28 +34,4 @@ | |||||||
| 
 | 
 | ||||||
| verify_runnable "global" | verify_runnable "global" | ||||||
| 
 | 
 | ||||||
| if ! is_physical_device $DISKS; then |  | ||||||
| 	log_unsupported "This directory cannot be run on raw files." |  | ||||||
| fi |  | ||||||
| 
 |  | ||||||
| disk1=${DISKS%% *} |  | ||||||
| if is_mpath_device $disk1; then |  | ||||||
|         delete_partitions |  | ||||||
| fi |  | ||||||
| 
 |  | ||||||
| if [[ -n $DISK ]]; then |  | ||||||
| 	# |  | ||||||
|         # Use 'zpool create' to clean up the information in |  | ||||||
|         # in the given disk to avoid slice overlapping. |  | ||||||
|         # |  | ||||||
| 	cleanup_devices $DISK |  | ||||||
| 
 |  | ||||||
|         partition_disk $SIZE $DISK 7 |  | ||||||
| else |  | ||||||
| 	for disk in `echo $DISKSARRAY`; do |  | ||||||
| 		cleanup_devices $disk |  | ||||||
| 		partition_disk $SIZE $disk 7 |  | ||||||
| 	done |  | ||||||
| fi |  | ||||||
| 
 |  | ||||||
| log_pass | log_pass | ||||||
|  | |||||||
| @ -28,57 +28,12 @@ | |||||||
| # Copyright (c) 2012, 2015 by Delphix. All rights reserved. | # Copyright (c) 2012, 2015 by Delphix. All rights reserved. | ||||||
| # | # | ||||||
| 
 | 
 | ||||||
| export DISK_ARRAY_NUM=0 |  | ||||||
| export DISK_ARRAY_LIMIT=4 |  | ||||||
| export DISKSARRAY="" |  | ||||||
| 
 |  | ||||||
| function set_disks |  | ||||||
| { |  | ||||||
|         set -A disk_array $(find_disks $DISKS) |  | ||||||
| 
 |  | ||||||
|         if (( ${#disk_array[*]} <= 1 )); then |  | ||||||
|                 export DISK=${DISKS%% *} |  | ||||||
|         else |  | ||||||
|                 export DISK="" |  | ||||||
|                 typeset -i i=0 |  | ||||||
|                 while (( i < ${#disk_array[*]} )); do |  | ||||||
|                         export DISK${i}="${disk_array[$i]}" |  | ||||||
|                         DISKSARRAY="$DISKSARRAY ${disk_array[$i]}" |  | ||||||
|                         (( i = i + 1 )) |  | ||||||
|                         (( i>$DISK_ARRAY_LIMIT )) && break |  | ||||||
|                 done |  | ||||||
|                 export DISK_ARRAY_NUM=$i |  | ||||||
|                 export DISKSARRAY |  | ||||||
|         fi |  | ||||||
| 
 |  | ||||||
| 	if (( $DISK_ARRAY_NUM == 0 )); then |  | ||||||
| 		export disk=$DISK |  | ||||||
| 	else |  | ||||||
| 		export disk=$DISK0 |  | ||||||
| 	fi |  | ||||||
| 
 |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| set_disks |  | ||||||
| 
 |  | ||||||
| export SIZE="$(((MINVDEVSIZE / (1024 * 1024)) * 2))m" | export SIZE="$(((MINVDEVSIZE / (1024 * 1024)) * 2))m" | ||||||
| 
 |  | ||||||
| if is_linux || is_freebsd; then |  | ||||||
| 	set_device_dir |  | ||||||
| 	set_slice_prefix |  | ||||||
| 	export SLICE0=1 |  | ||||||
| 	export SLICE1=2 |  | ||||||
| 	export SLICE3=4 |  | ||||||
| 	export SLICE4=5 |  | ||||||
| 	export SLICE5=6 |  | ||||||
| 	export SLICE6=7 |  | ||||||
| else |  | ||||||
| 	export SLICE0=0 |  | ||||||
| 	export SLICE1=1 |  | ||||||
| 	export SLICE3=3 |  | ||||||
| 	export SLICE4=4 |  | ||||||
| 	export SLICE5=5 |  | ||||||
| 	export SLICE6=6 |  | ||||||
| fi |  | ||||||
| 
 |  | ||||||
| export VOLSIZE=$MINVDEVSIZE | export VOLSIZE=$MINVDEVSIZE | ||||||
|  | 
 | ||||||
|  | echo $DISKS | read DISK0 DISK1 DISK2 | ||||||
|  | 
 | ||||||
|  | if is_linux; then | ||||||
|  | 	export DISK_ARRAY_NUM=3 | ||||||
|  | 	set_device_dir | ||||||
|  | fi | ||||||
|  | |||||||
| @ -109,20 +109,3 @@ function save_dump_dev | |||||||
| 	fi | 	fi | ||||||
| 	echo $dumpdev | 	echo $dumpdev | ||||||
| } | } | ||||||
| 
 |  | ||||||
| # |  | ||||||
| # Common cleanup routine for partitions used in testing |  | ||||||
| # |  | ||||||
| function partition_cleanup |  | ||||||
| { |  | ||||||
| 
 |  | ||||||
| 	if [[ -n $DISK ]]; then |  | ||||||
| 		partition_disk $SIZE $DISK 7 |  | ||||||
| 	else |  | ||||||
| 		typeset disk="" |  | ||||||
| 		for disk in $DISK0 $DISK1; do |  | ||||||
| 			partition_disk $SIZE $disk 7 |  | ||||||
| 		done |  | ||||||
| 	fi |  | ||||||
| 
 |  | ||||||
| } |  | ||||||
|  | |||||||
| @ -47,10 +47,8 @@ verify_runnable "global" | |||||||
| 
 | 
 | ||||||
| function cleanup | function cleanup | ||||||
| { | { | ||||||
| 	poolexists $TESTPOOL && \ | 	poolexists $TESTPOOL && destroy_pool $TESTPOOL | ||||||
| 		destroy_pool $TESTPOOL | 	rm -f $disk0 $disk1 | ||||||
| 
 |  | ||||||
| 	partition_cleanup |  | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| log_assert "'zpool add <pool> <vdev> ...' can add devices to the pool." | log_assert "'zpool add <pool> <vdev> ...' can add devices to the pool." | ||||||
| @ -59,36 +57,15 @@ log_onexit cleanup | |||||||
| 
 | 
 | ||||||
| set -A keywords "" "mirror" "raidz" "raidz1" "spare" | set -A keywords "" "mirror" "raidz" "raidz1" "spare" | ||||||
| 
 | 
 | ||||||
| case $DISK_ARRAY_NUM in | pooldevs="${DISK0} \ | ||||||
| 0|1) | 	\"${DISK0} ${DISK1}\" \ | ||||||
| 	pooldevs="${disk}${SLICE_PREFIX}${SLICE0} \ | 	\"${DISK0} ${DISK1} ${DISK2}\"" | ||||||
| 		${DEV_DSKDIR}/${disk}${SLICE_PREFIX}${SLICE0} \ | mirrordevs="\"${DISK0} ${DISK1}\"" | ||||||
| 		\"${disk}${SLICE_PREFIX}${SLICE0} \ | raidzdevs="\"${DISK0} ${DISK1}\"" | ||||||
| 		${disk}${SLICE_PREFIX}${SLICE1}\"" |  | ||||||
| 	mirrordevs="\"${DEV_DSKDIR}/${disk}${SLICE_PREFIX}${SLICE0} \ |  | ||||||
| 		${disk}${SLICE_PREFIX}${SLICE1}\"" |  | ||||||
| 	raidzdevs="\"${DEV_DSKDIR}/${disk}${SLICE_PREFIX}${SLICE0} \ |  | ||||||
| 		${disk}${SLICE_PREFIX}${SLICE1}\"" |  | ||||||
| 
 | 
 | ||||||
| 	;; | disk0=$TEST_BASE_DIR/disk0 | ||||||
| 2|*) | disk1=$TEST_BASE_DIR/disk1 | ||||||
| 	pooldevs="${DISK0}${SLICE_PREFIX}${SLICE0} \ | truncate -s $MINVDEVSIZE $disk0 $disk1 | ||||||
| 		\"${DEV_DSKDIR}/${DISK0}${SLICE_PREFIX}${SLICE0} \ |  | ||||||
| 		${DISK1}${SLICE_PREFIX}${SLICE0}\" \ |  | ||||||
| 		\"${DISK0}${SLICE_PREFIX}${SLICE0} \ |  | ||||||
| 		${DISK0}${SLICE_PREFIX}${SLICE1} \ |  | ||||||
| 		${DISK1}${SLICE_PREFIX}${SLICE1}\"\ |  | ||||||
| 		\"${DISK0}${SLICE_PREFIX}${SLICE0} \ |  | ||||||
| 		${DISK1}${SLICE_PREFIX}${SLICE0} \ |  | ||||||
| 		${DISK0}${SLICE_PREFIX}${SLICE1}\ |  | ||||||
| 		${DISK1}${SLICE_PREFIX}${SLICE1}\"" |  | ||||||
| 	mirrordevs="\"${DEV_DSKDIR}/${DISK0}${SLICE_PREFIX}${SLICE0} \ |  | ||||||
| 		${DISK1}${SLICE_PREFIX}${SLICE0}\"" |  | ||||||
| 	raidzdevs="\"${DEV_DSKDIR}/${DISK0}${SLICE_PREFIX}${SLICE0} \ |  | ||||||
| 		${DISK1}${SLICE_PREFIX}${SLICE0}\"" |  | ||||||
| 
 |  | ||||||
| 	;; |  | ||||||
| esac |  | ||||||
| 
 | 
 | ||||||
| typeset -i i=0 | typeset -i i=0 | ||||||
| typeset vdev | typeset vdev | ||||||
| @ -101,7 +78,7 @@ while (( $i < ${#keywords[*]} )); do | |||||||
|         case ${keywords[i]} in |         case ${keywords[i]} in | ||||||
|         ""|spare) |         ""|spare) | ||||||
| 		for vdev in "${poolarray[@]}"; do | 		for vdev in "${poolarray[@]}"; do | ||||||
| 			create_pool "$TESTPOOL" "${disk}${SLICE_PREFIX}${SLICE6}" | 			create_pool "$TESTPOOL" "$disk0" | ||||||
| 			log_must poolexists "$TESTPOOL" | 			log_must poolexists "$TESTPOOL" | ||||||
| 			log_must zpool add -f "$TESTPOOL" ${keywords[i]} $vdev | 			log_must zpool add -f "$TESTPOOL" ${keywords[i]} $vdev | ||||||
| 			log_must vdevs_in_pool "$TESTPOOL" "$vdev" | 			log_must vdevs_in_pool "$TESTPOOL" "$vdev" | ||||||
| @ -112,8 +89,7 @@ while (( $i < ${#keywords[*]} )); do | |||||||
|         mirror) |         mirror) | ||||||
| 		for vdev in "${mirrorarray[@]}"; do | 		for vdev in "${mirrorarray[@]}"; do | ||||||
| 			create_pool "$TESTPOOL" "${keywords[i]}" \ | 			create_pool "$TESTPOOL" "${keywords[i]}" \ | ||||||
| 				"${disk}${SLICE_PREFIX}${SLICE4}" \ | 				"$disk0" "$disk1" | ||||||
| 				"${disk}${SLICE_PREFIX}${SLICE5}" |  | ||||||
| 			log_must poolexists "$TESTPOOL" | 			log_must poolexists "$TESTPOOL" | ||||||
| 			log_must zpool add "$TESTPOOL" ${keywords[i]} $vdev | 			log_must zpool add "$TESTPOOL" ${keywords[i]} $vdev | ||||||
| 			log_must vdevs_in_pool "$TESTPOOL" "$vdev" | 			log_must vdevs_in_pool "$TESTPOOL" "$vdev" | ||||||
| @ -124,8 +100,7 @@ while (( $i < ${#keywords[*]} )); do | |||||||
|         raidz|raidz1) |         raidz|raidz1) | ||||||
| 		for vdev in "${raidzarray[@]}"; do | 		for vdev in "${raidzarray[@]}"; do | ||||||
| 			create_pool "$TESTPOOL" "${keywords[i]}" \ | 			create_pool "$TESTPOOL" "${keywords[i]}" \ | ||||||
| 				"${disk}${SLICE_PREFIX}${SLICE4}" \ | 				"$disk0" "$disk1" | ||||||
| 				"${disk}${SLICE_PREFIX}${SLICE5}" |  | ||||||
| 			log_must poolexists "$TESTPOOL" | 			log_must poolexists "$TESTPOOL" | ||||||
| 			log_must zpool add "$TESTPOOL" ${keywords[i]} $vdev | 			log_must zpool add "$TESTPOOL" ${keywords[i]} $vdev | ||||||
| 			log_must vdevs_in_pool "$TESTPOOL" "$vdev" | 			log_must vdevs_in_pool "$TESTPOOL" "$vdev" | ||||||
|  | |||||||
| @ -48,10 +48,7 @@ verify_runnable "global" | |||||||
| 
 | 
 | ||||||
| function cleanup | function cleanup | ||||||
| { | { | ||||||
|         poolexists $TESTPOOL && \ |         poolexists $TESTPOOL && destroy_pool $TESTPOOL | ||||||
|                 destroy_pool $TESTPOOL |  | ||||||
| 
 |  | ||||||
| 	partition_cleanup |  | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| log_assert "'zpool add -f <pool> <vdev> ...' can successfully add" \ | log_assert "'zpool add -f <pool> <vdev> ...' can successfully add" \ | ||||||
| @ -59,14 +56,13 @@ log_assert "'zpool add -f <pool> <vdev> ...' can successfully add" \ | |||||||
| 
 | 
 | ||||||
| log_onexit cleanup | log_onexit cleanup | ||||||
| 
 | 
 | ||||||
| create_pool "$TESTPOOL" mirror "${disk}${SLICE_PREFIX}${SLICE0}" \ | create_pool $TESTPOOL mirror $DISK0 $DISK1 | ||||||
| 	"${disk}${SLICE_PREFIX}${SLICE1}" | log_must poolexists $TESTPOOL | ||||||
| log_must poolexists "$TESTPOOL" |  | ||||||
| 
 | 
 | ||||||
| log_mustnot zpool add "$TESTPOOL" ${disk}${SLICE_PREFIX}${SLICE3} | log_mustnot zpool add $TESTPOOL $DISK2 | ||||||
| log_mustnot vdevs_in_pool "$TESTPOOL" "${disk}${SLICE_PREFIX}${SLICE3}" | log_mustnot vdevs_in_pool $TESTPOOL $DISK2 | ||||||
| 
 | 
 | ||||||
| log_must zpool add -f "$TESTPOOL" ${disk}${SLICE_PREFIX}${SLICE3} | log_must zpool add -f $TESTPOOL $DISK2 | ||||||
| log_must vdevs_in_pool "$TESTPOOL" "${disk}${SLICE_PREFIX}${SLICE3}" | log_must vdevs_in_pool $TESTPOOL $DISK2 | ||||||
| 
 | 
 | ||||||
| log_pass "'zpool add -f <pool> <vdev> ...' executes successfully." | log_pass "'zpool add -f <pool> <vdev> ...' executes successfully." | ||||||
|  | |||||||
| @ -47,31 +47,30 @@ verify_runnable "global" | |||||||
| 
 | 
 | ||||||
| function cleanup | function cleanup | ||||||
| { | { | ||||||
| 	poolexists $TESTPOOL && \ | 	poolexists $TESTPOOL && destroy_pool $TESTPOOL | ||||||
| 		destroy_pool "$TESTPOOL" | 	poolexists $TESTPOOL1 && destroy_pool $TESTPOOL1 | ||||||
| 
 | 	if [ -n "$recursive" ]; then | ||||||
| 	datasetexists $TESTPOOL1/$TESTVOL && \ | 		set_tunable64 VOL_RECURSIVE $recursive | ||||||
| 		log_must zfs destroy -f $TESTPOOL1/$TESTVOL | 	fi | ||||||
| 	poolexists $TESTPOOL1 && \ |  | ||||||
| 		destroy_pool "$TESTPOOL1" |  | ||||||
| 
 |  | ||||||
| 	partition_cleanup |  | ||||||
| 
 |  | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| log_assert "'zpool add <pool> <vdev> ...' can add zfs volume to the pool." | log_assert "'zpool add <pool> <vdev> ...' can add zfs volume to the pool." | ||||||
| 
 | 
 | ||||||
| log_onexit cleanup | log_onexit cleanup | ||||||
| 
 | 
 | ||||||
| create_pool "$TESTPOOL" "${disk}${SLICE_PREFIX}${SLICE0}" | create_pool $TESTPOOL $DISK0 | ||||||
| log_must poolexists "$TESTPOOL" | log_must poolexists $TESTPOOL | ||||||
| 
 | 
 | ||||||
| create_pool "$TESTPOOL1" "${disk}${SLICE_PREFIX}${SLICE1}" | create_pool $TESTPOOL1 $DISK1 | ||||||
| log_must poolexists "$TESTPOOL1" | log_must poolexists $TESTPOOL1 | ||||||
| log_must zfs create -V $VOLSIZE $TESTPOOL1/$TESTVOL | log_must zfs create -V $VOLSIZE $TESTPOOL1/$TESTVOL | ||||||
| block_device_wait | block_device_wait | ||||||
| 
 | 
 | ||||||
| log_must zpool add "$TESTPOOL" $ZVOL_DEVDIR/$TESTPOOL1/$TESTVOL | if is_freebsd; then | ||||||
|  | 	recursive=$(get_tunable VOL_RECURSIVE) | ||||||
|  | 	log_must set_tunable64 VOL_RECURSIVE 1 | ||||||
|  | fi | ||||||
|  | log_must zpool add $TESTPOOL $ZVOL_DEVDIR/$TESTPOOL1/$TESTVOL | ||||||
| 
 | 
 | ||||||
| log_must vdevs_in_pool "$TESTPOOL" "$ZVOL_DEVDIR/$TESTPOOL1/$TESTVOL" | log_must vdevs_in_pool "$TESTPOOL" "$ZVOL_DEVDIR/$TESTPOOL1/$TESTVOL" | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -50,16 +50,12 @@ verify_runnable "global" | |||||||
| 
 | 
 | ||||||
| function cleanup | function cleanup | ||||||
| { | { | ||||||
| 	poolexists "$TESTPOOL" && \ | 	poolexists $TESTPOOL && destroy_pool $TESTPOOL | ||||||
| 		destroy_pool "$TESTPOOL" | 	poolexists $TESTPOOL1 && destroy_pool $TESTPOOL1 | ||||||
| 	poolexists "$TESTPOOL1" && \ |  | ||||||
| 		destroy_pool "$TESTPOOL1" |  | ||||||
| 
 | 
 | ||||||
| 	if [[ -n $saved_dump_dev ]]; then | 	if [[ -n $saved_dump_dev ]]; then | ||||||
| 		log_must eval "dumpadm -u -d $saved_dump_dev > /dev/null" | 		log_must eval "dumpadm -u -d $saved_dump_dev > /dev/null" | ||||||
| 	fi | 	fi | ||||||
| 
 |  | ||||||
| 	partition_cleanup |  | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| log_assert "'zpool add' should fail with inapplicable scenarios." | log_assert "'zpool add' should fail with inapplicable scenarios." | ||||||
| @ -69,27 +65,27 @@ log_onexit cleanup | |||||||
| mnttab_dev=$(find_mnttab_dev) | mnttab_dev=$(find_mnttab_dev) | ||||||
| vfstab_dev=$(find_vfstab_dev) | vfstab_dev=$(find_vfstab_dev) | ||||||
| saved_dump_dev=$(save_dump_dev) | saved_dump_dev=$(save_dump_dev) | ||||||
| dump_dev=${disk}${SLICE_PREFIX}${SLICE3} | dump_dev=$DISK2 | ||||||
| 
 | 
 | ||||||
| create_pool "$TESTPOOL" "${disk}${SLICE_PREFIX}${SLICE0}" | create_pool $TESTPOOL $DISK0 | ||||||
| log_must poolexists "$TESTPOOL" | log_must poolexists $TESTPOOL | ||||||
| 
 | 
 | ||||||
| create_pool "$TESTPOOL1" "${disk}${SLICE_PREFIX}${SLICE1}" | create_pool $TESTPOOL1 $DISK1 | ||||||
| log_must poolexists "$TESTPOOL1" | log_must poolexists $TESTPOOL1 | ||||||
| 
 | 
 | ||||||
| unset NOINUSE_CHECK | unset NOINUSE_CHECK | ||||||
| log_mustnot zpool add -f "$TESTPOOL" ${disk}${SLICE_PREFIX}${SLICE1} | log_mustnot zpool add -f $TESTPOOL $DISK1 | ||||||
| log_mustnot zpool add -f "$TESTPOOL" $mnttab_dev | log_mustnot zpool add -f $TESTPOOL $mnttab_dev | ||||||
| if is_linux; then | if is_linux; then | ||||||
|        log_mustnot zpool add "$TESTPOOL" $vfstab_dev |        log_mustnot zpool add $TESTPOOL $vfstab_dev | ||||||
| else | else | ||||||
|        log_mustnot zpool add -f "$TESTPOOL" $vfstab_dev |        log_mustnot zpool add -f $TESTPOOL $vfstab_dev | ||||||
| fi | fi | ||||||
| 
 | 
 | ||||||
| if is_illumos; then | if is_illumos; then | ||||||
| 	log_must eval "new_fs ${DEV_DSKDIR}/$dump_dev > /dev/null 2>&1" | 	log_must eval "new_fs ${DEV_DSKDIR}/$dump_dev > /dev/null 2>&1" | ||||||
| 	log_must eval "dumpadm -u -d ${DEV_DSKDIR}/$dump_dev > /dev/null" | 	log_must eval "dumpadm -u -d ${DEV_DSKDIR}/$dump_dev > /dev/null" | ||||||
| 	log_mustnot zpool add -f "$TESTPOOL" $dump_dev | 	log_mustnot zpool add -f $TESTPOOL $dump_dev | ||||||
| fi | fi | ||||||
| 
 | 
 | ||||||
| log_pass "'zpool add' should fail with inapplicable scenarios." | log_pass "'zpool add' should fail with inapplicable scenarios." | ||||||
|  | |||||||
| @ -46,14 +46,8 @@ verify_runnable "global" | |||||||
| 
 | 
 | ||||||
| function cleanup | function cleanup | ||||||
| { | { | ||||||
| 	poolexists $TESTPOOL1 && \ | 	poolexists $TESTPOOL1 && destroy_pool $TESTPOOL1 | ||||||
| 		destroy_pool $TESTPOOL1 | 	rm -rf $TESTDIR | ||||||
| 
 |  | ||||||
| 	poolexists $TESTPOOL && \ |  | ||||||
| 		destroy_pool $TESTPOOL |  | ||||||
| 
 |  | ||||||
| 	[[ -d $TESTDIR ]] && log_must rm -rf $TESTDIR |  | ||||||
| 	partition_cleanup |  | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| log_assert "Adding a large number of file based vdevs to a zpool works." | log_assert "Adding a large number of file based vdevs to a zpool works." | ||||||
| @ -66,12 +60,12 @@ create_pool "$TESTPOOL1" "$TESTDIR/file.00" | |||||||
| vdevs_list=$(echo $TESTDIR/file.{01..16}) | vdevs_list=$(echo $TESTDIR/file.{01..16}) | ||||||
| log_must truncate -s $MINVDEVSIZE $vdevs_list | log_must truncate -s $MINVDEVSIZE $vdevs_list | ||||||
| 
 | 
 | ||||||
| log_must zpool add -f "$TESTPOOL1" $vdevs_list | log_must zpool add -f $TESTPOOL1 $vdevs_list | ||||||
| log_must vdevs_in_pool "$TESTPOOL1" "$vdevs_list" | log_must vdevs_in_pool $TESTPOOL1 "$vdevs_list" | ||||||
| 
 | 
 | ||||||
| # Attempt to add a file based vdev that's too small. | # Attempt to add a file based vdev that's too small. | ||||||
| log_must truncate -s 32m $TESTDIR/broken_file | log_must truncate -s 32m $TESTDIR/broken_file | ||||||
| log_mustnot zpool add -f "$TESTPOOL1" ${TESTDIR}/broken_file | log_mustnot zpool add -f $TESTPOOL1 ${TESTDIR}/broken_file | ||||||
| log_mustnot vdevs_in_pool "$TESTPOOL1" "${TESTDIR}/broken_file" | log_mustnot vdevs_in_pool $TESTPOOL1 ${TESTDIR}/broken_file | ||||||
| 
 | 
 | ||||||
| log_pass "Adding a large number of file based vdevs to a zpool works." | log_pass "Adding a large number of file based vdevs to a zpool works." | ||||||
|  | |||||||
| @ -46,10 +46,7 @@ verify_runnable "global" | |||||||
| 
 | 
 | ||||||
| function cleanup | function cleanup | ||||||
| { | { | ||||||
| 	poolexists "$TESTPOOL" && \ | 	poolexists $TESTPOOL && destroy_pool $TESTPOOL | ||||||
| 		destroy_pool "$TESTPOOL" |  | ||||||
| 
 |  | ||||||
| 	partition_cleanup |  | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| log_assert "'zpool add' should return an error with badly-formed parameters." | log_assert "'zpool add' should return an error with badly-formed parameters." | ||||||
| @ -57,10 +54,10 @@ log_assert "'zpool add' should return an error with badly-formed parameters." | |||||||
| log_onexit cleanup | log_onexit cleanup | ||||||
| 
 | 
 | ||||||
| set -A args "" "-f" "-n" "-?" "-nf" "-fn" "-f -n" "--f" "-blah" \ | set -A args "" "-f" "-n" "-?" "-nf" "-fn" "-f -n" "--f" "-blah" \ | ||||||
| 	"-? $TESTPOOL ${disk}${SLICE_PREFIX}${SLICE1}" | 	"-? $TESTPOOL $DISK1" | ||||||
| 
 | 
 | ||||||
| create_pool "$TESTPOOL" "${disk}${SLICE_PREFIX}${SLICE0}" | create_pool $TESTPOOL $DISK0 | ||||||
| log_must poolexists "$TESTPOOL" | log_must poolexists $TESTPOOL | ||||||
| 
 | 
 | ||||||
| typeset -i i=0 | typeset -i i=0 | ||||||
| while (( $i < ${#args[*]} )); do | while (( $i < ${#args[*]} )); do | ||||||
|  | |||||||
| @ -46,22 +46,18 @@ verify_runnable "global" | |||||||
| 
 | 
 | ||||||
| function cleanup | function cleanup | ||||||
| { | { | ||||||
| 
 |         poolexists $TESTPOOL && destroy_pool $TESTPOOL | ||||||
|         poolexists "$TESTPOOL" && \ |  | ||||||
|                 destroy_pool "$TESTPOOL" |  | ||||||
| 
 |  | ||||||
| 	partition_cleanup |  | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| log_assert "'zpool add' should return an error with nonexistent pools and vdevs" | log_assert "'zpool add' should return an error with nonexistent pools and vdevs" | ||||||
| 
 | 
 | ||||||
| log_onexit cleanup | log_onexit cleanup | ||||||
| 
 | 
 | ||||||
| set -A args "" "-f nonexistent_pool ${disk}${SLICE_PREFIX}${SLICE1}" \ | set -A args "" "-f nonexistent_pool $DISK1" \ | ||||||
| 	"-f $TESTPOOL nonexistent_vdev" | 	"-f $TESTPOOL nonexistent_vdev" | ||||||
| 
 | 
 | ||||||
| create_pool "$TESTPOOL" "${disk}${SLICE_PREFIX}${SLICE0}" | create_pool $TESTPOOL $DISK0 | ||||||
| log_must poolexists "$TESTPOOL" | log_must poolexists $TESTPOOL | ||||||
| 
 | 
 | ||||||
| typeset -i i=0 | typeset -i i=0 | ||||||
| while (( $i < ${#args[*]} )); do | while (( $i < ${#args[*]} )); do | ||||||
|  | |||||||
| @ -47,12 +47,7 @@ verify_runnable "global" | |||||||
| 
 | 
 | ||||||
| function cleanup | function cleanup | ||||||
| { | { | ||||||
| 
 |         poolexists $TESTPOOL && destroy_pool $TESTPOOL | ||||||
|         poolexists "$TESTPOOL" && \ |  | ||||||
|                 destroy_pool "$TESTPOOL" |  | ||||||
| 
 |  | ||||||
| 	partition_cleanup |  | ||||||
| 
 |  | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| log_assert "'zpool add' should fail if vdevs are the same or vdev is " \ | log_assert "'zpool add' should fail if vdevs are the same or vdev is " \ | ||||||
| @ -60,12 +55,11 @@ log_assert "'zpool add' should fail if vdevs are the same or vdev is " \ | |||||||
| 
 | 
 | ||||||
| log_onexit cleanup | log_onexit cleanup | ||||||
| 
 | 
 | ||||||
| create_pool "$TESTPOOL" "${disk}${SLICE_PREFIX}${SLICE0}" | create_pool $TESTPOOL $DISK0 | ||||||
| log_must poolexists "$TESTPOOL" | log_must poolexists $TESTPOOL | ||||||
| 
 | 
 | ||||||
| log_mustnot zpool add -f "$TESTPOOL" ${disk}${SLICE_PREFIX}${SLICE1} \ | log_mustnot zpool add -f $TESTPOOL $DISK1 $DISK1 | ||||||
| 	${disk}${SLICE_PREFIX}${SLICE1} | log_mustnot zpool add -f $TESTPOOL $DISK0 | ||||||
| log_mustnot zpool add -f "$TESTPOOL" ${disk}${SLICE_PREFIX}${SLICE0} |  | ||||||
| 
 | 
 | ||||||
| log_pass "'zpool add' get fail as expected if vdevs are the same or vdev is " \ | log_pass "'zpool add' get fail as expected if vdevs are the same or vdev is " \ | ||||||
| 	"contained in the given pool." | 	"contained in the given pool." | ||||||
|  | |||||||
| @ -51,7 +51,7 @@ function cleanup | |||||||
| 
 | 
 | ||||||
| 	typeset -i i=0 | 	typeset -i i=0 | ||||||
| 	while ((i < 10)); do | 	while ((i < 10)); do | ||||||
| 		log_must rm -f $TEST_BASE_DIR/vdev$i | 		rm -f $TEST_BASE_DIR/vdev$i | ||||||
| 		((i += 1)) | 		((i += 1)) | ||||||
| 	done | 	done | ||||||
| } | } | ||||||
|  | |||||||
		Loading…
	
		Reference in New Issue
	
	Block a user
	 Ryan Moeller
						Ryan Moeller