mirror of
https://git.proxmox.com/git/mirror_zfs.git
synced 2025-06-14 09:44:58 +03:00
ZTS: Clean up properties.shlib a bit
Fixes the last property having an empty value on FreeBSD and makes the code a bit more readable. Reviewed-by: Kjeld Schouten <kjeld@schouten-lebbing.nl> Reviewed-by: Igor Kozhukhov <igor@dilos.org> Reviewed-by: Brian Behlendorf <behlendorf1@llnl.gov> Reviewed-by: George Melikov <mail@gmelikov.ru> Signed-off-by: Ryan Moeller <ryan@ixsystems.com> Closes #9834
This commit is contained in:
parent
6e1c594d64
commit
602f667285
@ -34,47 +34,54 @@ typeset -a vol_props=('compress' 'checksum' 'copies' 'logbias' 'primarycache'
|
|||||||
'secondarycache' 'redundant_metadata' 'sync')
|
'secondarycache' 'redundant_metadata' 'sync')
|
||||||
|
|
||||||
#
|
#
|
||||||
# Given the property array passed in, return 'num_props' elements to the
|
# Given the 'prop' passed in, return 'num_vals' elements of the corresponding
|
||||||
# user, excluding any elements below 'start.' This allows us to exclude
|
# values array to the user, excluding any elements below 'first.' This allows
|
||||||
# 'off' and 'on' which can be either unwanted, or a duplicate of another
|
# us to exclude 'off' and 'on' which can be either unwanted, or a duplicate of
|
||||||
# property respectively.
|
# another property respectively.
|
||||||
#
|
#
|
||||||
function get_rand_prop
|
function get_rand_prop_vals
|
||||||
{
|
{
|
||||||
typeset prop_array=($(eval echo \${$1[@]}))
|
typeset prop=$1
|
||||||
typeset -i num_props=$2
|
typeset -i num_vals=$2
|
||||||
typeset -i start=$3
|
typeset -i first=$3
|
||||||
|
|
||||||
|
[[ -z $prop || -z $num_vals || -z $first ]] && \
|
||||||
|
log_fail "get_rand_prop_vals: bad arguments"
|
||||||
|
|
||||||
typeset retstr=""
|
typeset retstr=""
|
||||||
|
|
||||||
[[ -z $prop_array || -z $num_props || -z $start ]] && \
|
typeset prop_vals_var=${prop}_prop_vals
|
||||||
log_fail "get_rand_prop: bad arguments"
|
typeset -a prop_vals=($(eval echo \${${prop_vals_var}[@]}))
|
||||||
|
|
||||||
typeset prop_max=$((${#prop_array[@]} - 1))
|
[[ -z $prop_vals ]] && \
|
||||||
|
log_fail "get_rand_prop_vals: bad prop $prop"
|
||||||
|
|
||||||
|
typeset -i last=$((${#prop_vals[@]} - 1))
|
||||||
typeset -i i
|
typeset -i i
|
||||||
for i in $(range_shuffle $start $prop_max | head -n $num_props); do
|
for i in $(range_shuffle $first $last | head -n $num_vals); do
|
||||||
retstr="${prop_array[$i]} $retstr"
|
retstr="${prop_vals[$i]} $retstr"
|
||||||
done
|
done
|
||||||
echo $retstr
|
echo $retstr
|
||||||
}
|
}
|
||||||
|
|
||||||
function get_rand_checksum
|
function get_rand_checksum
|
||||||
{
|
{
|
||||||
get_rand_prop checksum_prop_vals $1 2
|
get_rand_prop_vals checksum $1 2
|
||||||
}
|
}
|
||||||
|
|
||||||
function get_rand_checksum_any
|
function get_rand_checksum_any
|
||||||
{
|
{
|
||||||
get_rand_prop checksum_prop_vals $1 0
|
get_rand_prop_vals checksum $1 0
|
||||||
}
|
}
|
||||||
|
|
||||||
function get_rand_recsize
|
function get_rand_recsize
|
||||||
{
|
{
|
||||||
get_rand_prop recsize_prop_vals $1 0
|
get_rand_prop_vals recsize $1 0
|
||||||
}
|
}
|
||||||
|
|
||||||
function get_rand_large_recsize
|
function get_rand_large_recsize
|
||||||
{
|
{
|
||||||
get_rand_prop recsize_prop_vals $1 9
|
get_rand_prop_vals recsize $1 9
|
||||||
}
|
}
|
||||||
|
|
||||||
#
|
#
|
||||||
@ -137,7 +144,7 @@ function randomize_ds_props
|
|||||||
fi
|
fi
|
||||||
|
|
||||||
for prop in $proplist; do
|
for prop in $proplist; do
|
||||||
typeset val=$(get_rand_prop "${prop}_prop_vals" 1 0)
|
typeset val=$(get_rand_prop_vals $prop 1 0)
|
||||||
log_must zfs set $prop=$val $ds
|
log_must zfs set $prop=$val $ds
|
||||||
done
|
done
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user