ZTS: Fix zpool_expand_001_pos

`zpool_expand_001_pos` was often failing due to not seeing autoexpand
commands in the `zpool history`.  During testing, I found this to be
unreliable (sometimes the "online" wouldn't appear in `zpool history`)
and unnecessary, as we could simply check that the pool increased in
size.

This commit revamps the test to check for the expanded pool size
and corresponding new free space.

Reviewed-by: Brian Behlendorf <behlendorf1@llnl.gov>
Signed-off-by: Tony Hutter <hutter2@llnl.gov>
Closes #13743
This commit is contained in:
Tony Hutter 2022-08-09 13:26:46 -07:00 committed by GitHub
parent 91983265b6
commit b3d0568cfd
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23

View File

@ -54,6 +54,14 @@
verify_runnable "global"
# We override $org_size and $exp_size from zpool_expand.cfg to make sure we get
# an expected free space value every time. Otherwise, if we left it
# configurable, the free space ratio to pool size ratio would diverge too much
# much at low $org_size values.
#
org_size=$((1024 * 1024 * 1024))
exp_size=$(($org_size * 2))
function cleanup
{
poolexists $TESTPOOL1 && destroy_pool $TESTPOOL1
@ -68,6 +76,30 @@ function cleanup
unload_scsi_debug
}
# Wait for the size of a pool to autoexpand to $1 and the total free space to
# expand to $2 (both values allowing a 10% tolerance).
#
# Wait for up to 10 seconds for this to happen (typically takes 1-2 seconds)
#
function wait_for_autoexpand
{
typeset exp_new_size=$1
typeset exp_new_free=$2
for i in $(seq 1 10) ; do
typeset new_size=$(get_pool_prop size $TESTPOOL1)
typeset new_free=$(get_prop avail $TESTPOOL1)
# Values need to be within 90% of each other (10% tolerance)
if within_percent $new_size $exp_new_size 90 > /dev/null && \
within_percent $new_free $exp_new_free 90 > /dev/null ; then
return
fi
sleep 1
done
log_fail "$TESTPOOL never expanded to $exp_new_size with $exp_new_free" \
" free space (got $new_size with $new_free free space)"
}
log_onexit cleanup
log_assert "zpool can be autoexpanded after set autoexpand=on on vdev expansion"
@ -105,63 +137,38 @@ for type in " " mirror raidz draid:1s; do
log_note "Expanding loopback, scsi_debug, and file vdevs"
log_must truncate -s $exp_size $FILE_LO
log_must losetup -c $DEV1
sleep 3
echo "2" > /sys/bus/pseudo/drivers/scsi_debug/virtual_gb
echo "1" > /sys/class/block/$DEV2/device/rescan
block_device_wait
sleep 3
log_must truncate -s $exp_size $FILE_RAW
log_must zpool online -e $TESTPOOL1 $FILE_RAW
typeset expand_size=$(get_pool_prop size $TESTPOOL1)
typeset zfs_expand_size=$(get_prop avail $TESTPOOL1)
log_note "$TESTPOOL1 $type has previous size: $prev_size and " \
"expanded size: $expand_size"
# compare available pool size from zfs
if [[ $zfs_expand_size -gt $zfs_prev_size ]]; then
# check for zpool history for the pool size expansion
if [[ $type == " " ]]; then
typeset expansion_size=$(($exp_size-$org_size))
typeset size_addition=$(zpool history -il $TESTPOOL1 |\
grep "pool '$TESTPOOL1' size:" | \
grep "vdev online" | \
grep -c "(+${expansion_size}")
if [[ $size_addition -ne 3 ]]; then
log_fail "pool $TESTPOOL1 has not expanded, " \
"$size_addition/3 vdevs expanded"
fi
elif [[ $type == "mirror" ]]; then
typeset expansion_size=$(($exp_size-$org_size))
zpool history -il $TESTPOOL1 | \
grep "pool '$TESTPOOL1' size:" | \
grep "vdev online" | \
grep -q "(+${expansion_size})" ||
log_fail "pool $TESTPOOL1 has not expanded"
elif [[ $type == "draid:1s" ]]; then
typeset expansion_size=$((2*($exp_size-$org_size)))
zpool history -il $TESTPOOL1 | \
grep "pool '$TESTPOOL1' size:" | \
grep "vdev online" | \
grep -q "(+${expansion_size})" ||
log_fail "pool $TESTPOOL has not expanded"
else
typeset expansion_size=$((3*($exp_size-$org_size)))
zpool history -il $TESTPOOL1 | \
grep "pool '$TESTPOOL1' size:" | \
grep "vdev online" | \
grep -q "(+${expansion_size})" ||
log_fail "pool $TESTPOOL has not expanded"
fi
else
log_fail "pool $TESTPOOL1 is not autoexpanded after vdev " \
"expansion. Previous size: $zfs_prev_size and expanded " \
"size: $zfs_expand_size"
# The expected free space values below were observed at the time of
# this commit. However, we know ZFS overhead will change over time,
# and thus we do not do an exact comparison to these values in
# wait_for_autoexpand. Rather, we make sure the free space
# is within some small percentage threshold of these values.
typeset exp_new_size=$(($prev_size * 2))
if [[ "$type" == " " ]] ; then
exp_new_free=6045892608
elif [[ "$type" == "mirror" ]] ; then
exp_new_free=1945997312
elif [[ "$type" == "raidz" ]] ; then
exp_new_free=3977637338
elif [[ "$type" == "draid:1s" ]] then
exp_new_free=1946000384
fi
wait_for_autoexpand $exp_new_size $exp_new_free
expand_size=$(get_pool_prop size $TESTPOOL1)
log_note "$TESTPOOL1 '$type' grew from $prev_size -> $expand_size with" \
"free space from $zfs_prev_size -> $(get_prop avail $TESTPOOL1)"
cleanup
done