mirror of
				https://git.proxmox.com/git/mirror_zfs.git
				synced 2025-10-26 01:45:00 +03:00 
			
		
		
		
	ZTS: Misc test fixes for FreeBSD
Add missing logic for FreeBSD to a few test scripts. Reviewed-by: John Kennedy <john.kennedy@delphix.com> Reviewed-by: Brian Behlendorf <behlendorf1@llnl.gov> Signed-off-by: Ryan Moeller <ryan@iXsystems.com> Closes #9994
This commit is contained in:
		
							parent
							
								
									71439163bb
								
							
						
					
					
						commit
						4f4ddf98ee
					
				| @ -116,7 +116,7 @@ function setup_snap_env | |||||||
| 
 | 
 | ||||||
| 			if datasetnonexists $snap; then | 			if datasetnonexists $snap; then | ||||||
| 				log_must cp /etc/passwd $fname | 				log_must cp /etc/passwd $fname | ||||||
| 				if is_linux; then | 				if is_linux || is_freebsd; then | ||||||
| 					log_must sync | 					log_must sync | ||||||
| 				else | 				else | ||||||
| 					# | 					# | ||||||
|  | |||||||
| @ -42,9 +42,17 @@ | |||||||
| # 3. Verify it run successfully. | # 3. Verify it run successfully. | ||||||
| # | # | ||||||
| 
 | 
 | ||||||
|  | function cleanup | ||||||
|  | { | ||||||
|  | 	if is_freebsd && [ -n "$old_corefile" ]; then | ||||||
|  | 		sysctl kern.corefile=$old_corefile | ||||||
|  | 	fi | ||||||
|  | } | ||||||
|  | 
 | ||||||
| verify_runnable "both" | verify_runnable "both" | ||||||
| 
 | 
 | ||||||
| log_assert "Debugging features of zpool should succeed." | log_assert "Debugging features of zpool should succeed." | ||||||
|  | log_onexit cleanup | ||||||
| 
 | 
 | ||||||
| log_must zpool -? > /dev/null 2>&1 | log_must zpool -? > /dev/null 2>&1 | ||||||
| 
 | 
 | ||||||
| @ -67,7 +75,8 @@ if is_linux; then | |||||||
| 	export ASAN_OPTIONS="abort_on_error=1:disable_coredump=0" | 	export ASAN_OPTIONS="abort_on_error=1:disable_coredump=0" | ||||||
| elif is_freebsd; then | elif is_freebsd; then | ||||||
| 	ulimit -c unlimited | 	ulimit -c unlimited | ||||||
| 	log_must sysctl kern.corefile=$corepath/core.zpool | 	old_corefile=$(sysctl -n kern.corefile) | ||||||
|  | 	log_must sysctl kern.corefile=core | ||||||
| 	export ASAN_OPTIONS="abort_on_error=1:disable_coredump=0" | 	export ASAN_OPTIONS="abort_on_error=1:disable_coredump=0" | ||||||
| fi | fi | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -50,7 +50,9 @@ function cleanup | |||||||
| 	poolexists $TESTPOOL && destroy_pool $TESTPOOL | 	poolexists $TESTPOOL && destroy_pool $TESTPOOL | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| if is_linux; then | if is_freebsd; then | ||||||
|  | 	typeset swap_disks=$(swapinfo -l | grep "/dev" | awk '{print $1}') | ||||||
|  | elif is_linux; then | ||||||
| 	typeset swap_disks=`swapon -s | grep "/dev" | awk '{print $1}'` | 	typeset swap_disks=`swapon -s | grep "/dev" | awk '{print $1}'` | ||||||
| else | else | ||||||
| 	typeset swap_disks=`swap -l | grep "c[0-9].*d[0-9].*s[0-9]" | \ | 	typeset swap_disks=`swap -l | grep "c[0-9].*d[0-9].*s[0-9]" | \ | ||||||
|  | |||||||
| @ -81,7 +81,12 @@ log_must zfs create -V 100m $vol_name | |||||||
| block_device_wait | block_device_wait | ||||||
| swap_setup ${ZVOL_DEVDIR}/$vol_name | swap_setup ${ZVOL_DEVDIR}/$vol_name | ||||||
| 
 | 
 | ||||||
| for opt in "-n" "" "-f"; do | if is_freebsd; then | ||||||
|  | 	typeset -a opts=("" "-f") | ||||||
|  | else | ||||||
|  | 	typeset -a opts=("-n" "" "-f") | ||||||
|  | fi | ||||||
|  | for opt in "${opts[@]}"; do | ||||||
| 	log_mustnot zpool create $opt $TESTPOOL1 ${ZVOL_DEVDIR}/${vol_name} | 	log_mustnot zpool create $opt $TESTPOOL1 ${ZVOL_DEVDIR}/${vol_name} | ||||||
| done | done | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -23,15 +23,21 @@ | |||||||
| 
 | 
 | ||||||
| verify_runnable "global" | verify_runnable "global" | ||||||
| 
 | 
 | ||||||
| DISK1=${DISKS%% *} | if is_freebsd; then | ||||||
|  | 	log_unsupported "FreeBSD has no hole punching mechanism for the time being." | ||||||
|  | 	diskinfo -v $DISKS | grep -qE 'No.*# TRIM/UNMAP support' && | ||||||
|  | 	    log_unsupported "DISKS do not support discard (TRIM/UNMAP)" | ||||||
|  | else | ||||||
|  | 	DISK1=${DISKS%% *} | ||||||
| 
 | 
 | ||||||
| typeset -i max_discard=0 | 	typeset -i max_discard=0 | ||||||
| if is_disk_device $DEV_RDSKDIR/$DISK1; then | 	if is_disk_device $DEV_RDSKDIR/$DISK1; then | ||||||
| 	max_discard=$(lsblk -Dbn $DEV_RDSKDIR/$DISK1 | awk '{ print $4; exit }') | 		max_discard=$(lsblk -Dbn $DEV_RDSKDIR/$DISK1 | awk '{ print $4; exit }') | ||||||
| fi | 	fi | ||||||
| 
 | 
 | ||||||
| if test $max_discard -eq 0; then | 	if test $max_discard -eq 0; then | ||||||
| 	log_unsupported "DISKS do not support discard (TRIM/UNMAP)" | 		log_unsupported "DISKS do not support discard (TRIM/UNMAP)" | ||||||
|  | 	fi | ||||||
| fi | fi | ||||||
| 
 | 
 | ||||||
| log_pass | log_pass | ||||||
|  | |||||||
| @ -46,7 +46,7 @@ | |||||||
| function test_cleanup | function test_cleanup | ||||||
| { | { | ||||||
| 	poolexists $NESTEDPOOL && destroy_pool $NESTEDPOOL | 	poolexists $NESTEDPOOL && destroy_pool $NESTEDPOOL | ||||||
| 	log_must set_tunable32 SPA_ASIZE_INFLATION 24 | 	set_tunable32 SPA_ASIZE_INFLATION 24 | ||||||
| 	cleanup_test_pool | 	cleanup_test_pool | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -26,7 +26,6 @@ | |||||||
| # Use is subject to license terms. | # Use is subject to license terms. | ||||||
| # | # | ||||||
| 
 | 
 | ||||||
| # |  | ||||||
| . $STF_SUITE/include/properties.shlib | . $STF_SUITE/include/properties.shlib | ||||||
| . $STF_SUITE/tests/functional/rsend/rsend.kshlib | . $STF_SUITE/tests/functional/rsend/rsend.kshlib | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -16,8 +16,8 @@ | |||||||
| # Use is subject to license terms. | # Use is subject to license terms. | ||||||
| # | # | ||||||
| 
 | 
 | ||||||
| . $STF_SUITE/include/properties.shlib |  | ||||||
| . $STF_SUITE/include/libtest.shlib | . $STF_SUITE/include/libtest.shlib | ||||||
|  | . $STF_SUITE/include/properties.shlib | ||||||
| . $STF_SUITE/tests/functional/rsend/rsend.kshlib | . $STF_SUITE/tests/functional/rsend/rsend.kshlib | ||||||
| 
 | 
 | ||||||
| # | # | ||||||
| @ -67,10 +67,15 @@ log_must eval "zfs recv $POOL/newfs < $BACKDIR/fs@snap${last_snap}" | |||||||
| # Set atime=off to prevent the recursive_cksum from modifying newfs. | # Set atime=off to prevent the recursive_cksum from modifying newfs. | ||||||
| log_must zfs set atime=off $POOL/newfs | log_must zfs set atime=off $POOL/newfs | ||||||
| 
 | 
 | ||||||
| # Due to reduced performance on debug kernels use fewer files by default. |  | ||||||
| if is_kmemleak; then | if is_kmemleak; then | ||||||
|  | 	# Use fewer files and passes on debug kernels | ||||||
|  | 	# to avoid timeout due to reduced performance. | ||||||
| 	nr_files=100 | 	nr_files=100 | ||||||
| 	passes=2 | 	passes=2 | ||||||
|  | elif is_freebsd; then | ||||||
|  | 	# Use fewer files and passes on FreeBSD to avoid timeout. | ||||||
|  | 	nr_files=500 | ||||||
|  | 	passes=2 | ||||||
| else | else | ||||||
| 	nr_files=1000 | 	nr_files=1000 | ||||||
| 	passes=3 | 	passes=3 | ||||||
|  | |||||||
| @ -59,10 +59,15 @@ log_must eval "zfs recv $POOL/newfs < $BACKDIR/fs@snap${last_snap}" | |||||||
| # Set atime=off to prevent the recursive_cksum from modifying newfs. | # Set atime=off to prevent the recursive_cksum from modifying newfs. | ||||||
| log_must zfs set atime=off $POOL/newfs | log_must zfs set atime=off $POOL/newfs | ||||||
| 
 | 
 | ||||||
| # Due to reduced performance on debug kernels use fewer files by default. |  | ||||||
| if is_kmemleak; then | if is_kmemleak; then | ||||||
|  | 	# Use fewer files and passes on debug kernels | ||||||
|  | 	# to avoid timeout due to reduced performance. | ||||||
| 	nr_files=100 | 	nr_files=100 | ||||||
| 	passes=2 | 	passes=2 | ||||||
|  | elif is_freebsd; then | ||||||
|  | 	# Use fewer passes and files on FreeBSD to avoid timeout. | ||||||
|  | 	nr_files=500 | ||||||
|  | 	passes=2 | ||||||
| else | else | ||||||
| 	nr_files=1000 | 	nr_files=1000 | ||||||
| 	passes=3 | 	passes=3 | ||||||
|  | |||||||
| @ -24,6 +24,7 @@ | |||||||
| verify_runnable "global" | verify_runnable "global" | ||||||
| 
 | 
 | ||||||
| if is_freebsd; then | if is_freebsd; then | ||||||
|  | 	log_unsupported "FreeBSD has no hole punching mechanism for the time being." | ||||||
| 	diskinfo -v $DISKS | grep -qE 'No.*# TRIM/UNMAP support' && | 	diskinfo -v $DISKS | grep -qE 'No.*# TRIM/UNMAP support' && | ||||||
| 	    log_unsupported "DISKS do not support discard (TRIM/UNMAP)" | 	    log_unsupported "DISKS do not support discard (TRIM/UNMAP)" | ||||||
| else | else | ||||||
|  | |||||||
| @ -131,7 +131,7 @@ function verify_partition # device | |||||||
| 		log_fail "$device is not a block device" | 		log_fail "$device is not a block device" | ||||||
| 	fi | 	fi | ||||||
| 	# create a small dummy partition | 	# create a small dummy partition | ||||||
| 	set_partition 0 1 1m $device | 	set_partition 0 "" 1m $device | ||||||
| 	# verify we can access the partition on the device | 	# verify we can access the partition on the device | ||||||
| 	devname="$(readlink -f "$device")" | 	devname="$(readlink -f "$device")" | ||||||
| 	if is_linux || is_freebsd; then | 	if is_linux || is_freebsd; then | ||||||
|  | |||||||
| @ -383,14 +383,18 @@ function get_directory | |||||||
| 
 | 
 | ||||||
| function get_min_arc_size | function get_min_arc_size | ||||||
| { | { | ||||||
| 	if is_linux; then | 	typeset -l min_arc_size | ||||||
| 		typeset -l min_arc_size=`awk '$1 == "c_min" { print $3 }' \ | 
 | ||||||
| 		    /proc/spl/kstat/zfs/arcstats` | 	if is_freebsd; then | ||||||
| 	else | 		min_arc_size=$(sysctl -n kstat.zfs.misc.arcstats.c_min) | ||||||
| 		typeset -l min_arc_size=$(dtrace -qn 'BEGIN { | 	elif is_illumos; then | ||||||
|  | 		min_arc_size=$(dtrace -qn 'BEGIN { | ||||||
| 		    printf("%u\n", `arc_stats.arcstat_c_min.value.ui64); | 		    printf("%u\n", `arc_stats.arcstat_c_min.value.ui64); | ||||||
| 		    exit(0); | 		    exit(0); | ||||||
| 		}') | 		}') | ||||||
|  | 	elif is_linux; then | ||||||
|  | 		min_arc_size=`awk '$1 == "c_min" { print $3 }' \ | ||||||
|  | 		    /proc/spl/kstat/zfs/arcstats` | ||||||
| 	fi | 	fi | ||||||
| 
 | 
 | ||||||
| 	[[ $? -eq 0 ]] || log_fail "get_min_arc_size failed" | 	[[ $? -eq 0 ]] || log_fail "get_min_arc_size failed" | ||||||
| @ -400,14 +404,18 @@ function get_min_arc_size | |||||||
| 
 | 
 | ||||||
| function get_max_arc_size | function get_max_arc_size | ||||||
| { | { | ||||||
| 	if is_linux; then | 	typeset -l max_arc_size | ||||||
| 		typeset -l max_arc_size=`awk '$1 == "c_max" { print $3 }' \ | 
 | ||||||
| 		    /proc/spl/kstat/zfs/arcstats` | 	if is_freebsd; then | ||||||
| 	else | 		max_arc_size=$(sysctl -n kstat.zfs.misc.arcstats.c_max) | ||||||
| 		typeset -l max_arc_size=$(dtrace -qn 'BEGIN { | 	elif is_illumos; then | ||||||
|  | 		max_arc_size=$(dtrace -qn 'BEGIN { | ||||||
| 		    printf("%u\n", `arc_stats.arcstat_c_max.value.ui64); | 		    printf("%u\n", `arc_stats.arcstat_c_max.value.ui64); | ||||||
| 		    exit(0); | 		    exit(0); | ||||||
| 		}') | 		}') | ||||||
|  | 	elif is_linux; then | ||||||
|  | 		max_arc_size=`awk '$1 == "c_max" { print $3 }' \ | ||||||
|  | 		    /proc/spl/kstat/zfs/arcstats` | ||||||
| 	fi | 	fi | ||||||
| 
 | 
 | ||||||
| 	[[ $? -eq 0 ]] || log_fail "get_max_arc_size failed" | 	[[ $? -eq 0 ]] || log_fail "get_max_arc_size failed" | ||||||
| @ -419,17 +427,17 @@ function get_max_dbuf_cache_size | |||||||
| { | { | ||||||
| 	typeset -l max_dbuf_cache_size | 	typeset -l max_dbuf_cache_size | ||||||
| 
 | 
 | ||||||
| 	if is_linux; then | 	if is_illumos; then | ||||||
| 		max_dbuf_cache_size=$(get_tunable DBUF_CACHE_MAX_BYTES) |  | ||||||
| 	else |  | ||||||
| 		max_dbuf_cache_size=$(dtrace -qn 'BEGIN { | 		max_dbuf_cache_size=$(dtrace -qn 'BEGIN { | ||||||
| 		    printf("%u\n", `dbuf_cache_max_bytes); | 		    printf("%u\n", `dbuf_cache_max_bytes); | ||||||
| 		    exit(0); | 		    exit(0); | ||||||
| 		}') | 		}') | ||||||
| 
 | 	else | ||||||
| 		[[ $? -eq 0 ]] || log_fail "get_max_dbuf_cache_size failed" | 		max_dbuf_cache_size=$(get_tunable DBUF_CACHE_MAX_BYTES) | ||||||
| 	fi | 	fi | ||||||
| 
 | 
 | ||||||
|  | 	[[ $? -eq 0 ]] || log_fail "get_max_dbuf_cache_size failed" | ||||||
|  | 
 | ||||||
| 	echo $max_dbuf_cache_size | 	echo $max_dbuf_cache_size | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| @ -531,14 +539,7 @@ function pool_to_lun_list | |||||||
| 	typeset ctd ctds devname lun | 	typeset ctd ctds devname lun | ||||||
| 	typeset lun_list=':' | 	typeset lun_list=':' | ||||||
| 
 | 
 | ||||||
| 	if is_linux; then | 	if is_illumos; then | ||||||
| 		ctds=$(zpool list -HLv $pool | \ |  | ||||||
| 		    awk '/sd[a-z]*|loop[0-9]*|dm-[0-9]*/ {print $1}') |  | ||||||
| 
 |  | ||||||
| 		for ctd in $ctds; do |  | ||||||
| 			lun_list="$lun_list$ctd:" |  | ||||||
| 		done |  | ||||||
| 	else |  | ||||||
| 		ctds=$(zpool list -v $pool | | 		ctds=$(zpool list -v $pool | | ||||||
| 		    awk '/c[0-9]*t[0-9a-fA-F]*d[0-9]*/ {print $1}') | 		    awk '/c[0-9]*t[0-9a-fA-F]*d[0-9]*/ {print $1}') | ||||||
| 
 | 
 | ||||||
| @ -550,7 +551,18 @@ function pool_to_lun_list | |||||||
| 		# number to the list for comparison with dev_statname. | 		# number to the list for comparison with dev_statname. | ||||||
| 		lun=$(sed 's/"//g' /etc/path_to_inst | grep \ | 		lun=$(sed 's/"//g' /etc/path_to_inst | grep \ | ||||||
| 		    $devname | awk '{print $3$2}') | 		    $devname | awk '{print $3$2}') | ||||||
| 		un_list="$lun_list$lun:" | 		lun_list="$lun_list$lun:" | ||||||
|  | 		done | ||||||
|  | 	elif is_freebsd; then | ||||||
|  | 		lun_list+=$(zpool list -HLv $pool | \ | ||||||
|  | 		    awk '/a?da[0-9]+|md[0-9]+|mfid[0-9]+|nda[0-9]+|nvd[0-9]+|vtbd[0-9]+/ | ||||||
|  | 		         { printf "%s:", $1 }') | ||||||
|  | 	elif is_linux; then | ||||||
|  | 		ctds=$(zpool list -HLv $pool | \ | ||||||
|  | 		    awk '/sd[a-z]*|loop[0-9]*|dm-[0-9]*/ {print $1}') | ||||||
|  | 
 | ||||||
|  | 		for ctd in $ctds; do | ||||||
|  | 			lun_list="$lun_list$ctd:" | ||||||
| 		done | 		done | ||||||
| 	fi | 	fi | ||||||
| 	echo $lun_list | 	echo $lun_list | ||||||
|  | |||||||
		Loading…
	
		Reference in New Issue
	
	Block a user
	 Ryan Moeller
						Ryan Moeller