ZTS: Eliminate functions named 'random'

The name overlaps with a command needed by FreeBSD.
There is also no sense having two 'random' functions that do nearly
the same thing, so consolidate to just the more general one and name
it 'random_int_between'.

Reviewed-by: John Kennedy <john.kennedy@delphix.com>
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 #9820
This commit is contained in:
Ryan Moeller 2020-01-08 12:08:30 -05:00 committed by Brian Behlendorf
parent 028e3b3b1a
commit f8d55b95a5
10 changed files with 34 additions and 35 deletions

View File

@ -3349,15 +3349,6 @@ function get_min
echo $min echo $min
} }
#
# Generate a random number between 1 and the argument.
#
function random
{
typeset max=$1
echo $(( ($RANDOM % $max) + 1 ))
}
# Write data that can be compressed into a directory # Write data that can be compressed into a directory
function write_compressible function write_compressible
{ {

View File

@ -119,3 +119,25 @@ function verify_ne # <a> <b> <type>
log_fail "Compared $type should be not equal: $a == $b" log_fail "Compared $type should be not equal: $a == $b"
fi fi
} }
# A simple function to get a random number between two bounds (inclusive)
#
# Probably not the most efficient for large ranges, but it's okay.
#
# Note since we're using $RANDOM, 32767 is the largest number we
# can accept as the upper bound.
#
# $1 lower bound
# $2 upper bound
function random_int_between
{
typeset -i min=$1
typeset -i max=$2
typeset -i rand=0
while [[ $rand -lt $min ]] ; do
rand=$(( $RANDOM % $max + 1))
done
echo $rand
}

View File

@ -50,7 +50,7 @@ function create_random # <fspath> <count>
while (( i < count )); do while (( i < count )); do
log_must touch "$fspath/file$i" log_must touch "$fspath/file$i"
sleep $(random 3) sleep $(random_int_between 1 3)
(( i = i + 1 )) (( i = i + 1 ))
done done
} }

View File

@ -138,22 +138,3 @@ function check_poolversion
log_fail "$pool: zpool reported version $actual, expected $vers" log_fail "$pool: zpool reported version $actual, expected $vers"
fi fi
} }
# A simple function to get a random number between two bounds
# probably not the most efficient for large ranges, but it's okay.
# Note since we're using $RANDOM, 32767 is the largest number we
# can accept as the upper bound.
# $1 lower bound
# $2 upper bound
function random
{
typeset min=$1
typeset max=$2
typeset rand=0
while [[ $rand -lt $min ]] ; do
rand=$(( $RANDOM % $max + 1))
done
echo $rand
}

View File

@ -30,6 +30,7 @@
# Copyright 2015 Nexenta Systems, Inc. All rights reserved. # Copyright 2015 Nexenta Systems, Inc. All rights reserved.
# #
. $STF_SUITE/include/libtest.shlib
. $STF_SUITE/tests/functional/cli_root/zpool_upgrade/zpool_upgrade.kshlib . $STF_SUITE/tests/functional/cli_root/zpool_upgrade/zpool_upgrade.kshlib
# #
@ -67,7 +68,7 @@ MAX_VER=15
for ver_old in $VERSIONS; do for ver_old in $VERSIONS; do
typeset -n pool_name=ZPOOL_VERSION_${ver_old}_NAME typeset -n pool_name=ZPOOL_VERSION_${ver_old}_NAME
typeset ver_new=$(random $ver_old $MAX_VER) typeset -i ver_new=$(random_int_between $ver_old $MAX_VER)
create_old_pool $ver_old create_old_pool $ver_old
log_must zpool upgrade -V $ver_new $pool_name > /dev/null log_must zpool upgrade -V $ver_new $pool_name > /dev/null

View File

@ -100,7 +100,7 @@ function setup_holes
log_must zfs create $sendfs/manyrm log_must zfs create $sendfs/manyrm
for i in {1..256}; do for i in {1..256}; do
log_must stride_dd -i /dev/urandom -o $mntpnt/manyrm/f$i -b 512 \ log_must stride_dd -i /dev/urandom -o $mntpnt/manyrm/f$i -b 512 \
-c $(random 100) -s $(random 4) -c $(random_int_between 1 100) -s $(random_int_between 1 4)
done done
log_must zfs snapshot $sendfs/manyrm@snap log_must zfs snapshot $sendfs/manyrm@snap

View File

@ -29,6 +29,7 @@
# Copyright (c) 2013 by Delphix. All rights reserved. # Copyright (c) 2013 by Delphix. All rights reserved.
# #
. $STF_SUITE/include/libtest.shlib
. $STF_SUITE/tests/functional/redundancy/redundancy.kshlib . $STF_SUITE/tests/functional/redundancy/redundancy.kshlib
# #
@ -50,7 +51,7 @@ verify_runnable "global"
log_assert "Verify raidz pool can withstand one device is failing." log_assert "Verify raidz pool can withstand one device is failing."
log_onexit cleanup log_onexit cleanup
typeset -i cnt=$(random 2 5) typeset -i cnt=$(random_int_between 2 5)
setup_test_env $TESTPOOL raidz $cnt setup_test_env $TESTPOOL raidz $cnt
# #

View File

@ -29,6 +29,7 @@
# Copyright (c) 2013 by Delphix. All rights reserved. # Copyright (c) 2013 by Delphix. All rights reserved.
# #
. $STF_SUITE/include/libtest.shlib
. $STF_SUITE/tests/functional/redundancy/redundancy.kshlib . $STF_SUITE/tests/functional/redundancy/redundancy.kshlib
# #
@ -50,7 +51,7 @@ verify_runnable "global"
log_assert "Verify raidz2 pool can withstand two devices are failing." log_assert "Verify raidz2 pool can withstand two devices are failing."
log_onexit cleanup log_onexit cleanup
typeset -i cnt=$(random 3 5) typeset -i cnt=$(random_int_between 3 5)
setup_test_env $TESTPOOL raidz2 $cnt setup_test_env $TESTPOOL raidz2 $cnt
# #

View File

@ -29,6 +29,7 @@
# Copyright (c) 2013 by Delphix. All rights reserved. # Copyright (c) 2013 by Delphix. All rights reserved.
# #
. $STF_SUITE/include/libtest.shlib
. $STF_SUITE/tests/functional/redundancy/redundancy.kshlib . $STF_SUITE/tests/functional/redundancy/redundancy.kshlib
# #
@ -50,7 +51,7 @@ verify_runnable "global"
log_assert "Verify mirrored pool can withstand N-1 devices are failing or missing." log_assert "Verify mirrored pool can withstand N-1 devices are failing or missing."
log_onexit cleanup log_onexit cleanup
typeset -i cnt=$(random 2 5) typeset -i cnt=$(random_int_between 2 5)
setup_test_env $TESTPOOL mirror $cnt setup_test_env $TESTPOOL mirror $cnt
typeset -i i=1 typeset -i i=1

View File

@ -29,6 +29,7 @@
# Copyright (c) 2013, 2016 by Delphix. All rights reserved. # Copyright (c) 2013, 2016 by Delphix. All rights reserved.
# #
. $STF_SUITE/include/libtest.shlib
. $STF_SUITE/tests/functional/redundancy/redundancy.kshlib . $STF_SUITE/tests/functional/redundancy/redundancy.kshlib
# #
@ -50,7 +51,7 @@ verify_runnable "global"
log_assert "Verify striped pool have no data redundancy." log_assert "Verify striped pool have no data redundancy."
log_onexit cleanup log_onexit cleanup
typeset -i cnt=$(random 2 5) typeset -i cnt=$(random_int_between 2 5)
setup_test_env $TESTPOOL "" $cnt setup_test_env $TESTPOOL "" $cnt
damage_devs $TESTPOOL 1 "keep_label" damage_devs $TESTPOOL 1 "keep_label"