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:
Ryan Moeller 2020-02-13 16:52:34 -05:00 committed by GitHub
parent 71439163bb
commit 4f4ddf98ee
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
12 changed files with 85 additions and 41 deletions

View File

@ -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
# #

View File

@ -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

View File

@ -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]" | \

View File

@ -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

View File

@ -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

View File

@ -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
} }

View File

@ -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

View File

@ -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

View File

@ -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

View File

@ -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

View File

@ -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

View File

@ -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