Refactor test definitions

Move create_rhizome_identities() from testdefs_rhizome.sh to
create_identities() in testdefs.sh

Rename create_identity() in testdefs.sh to create_single_identity(), uses
create_identities() to do its work.
This commit is contained in:
Andrew Bettison 2012-09-14 15:04:05 +09:30
parent 9546903ce7
commit e994626429
5 changed files with 108 additions and 87 deletions

View File

@ -416,41 +416,89 @@ assert_all_servald_servers_no_errors() {
} }
# Utility function # Utility function
# - create an identity # - create an identity in the current instance {I}
# - assign a phone number (DID) and name to the new identity, use defaults # - assign a phone number (DID) and name to the new identity, use defaults
# if not specified by arg1 and arg2 # if not specified by arg1 and arg2
# - set the SID variable to the SID of the new identity # - assert the new identity is the only one in this instance
# - set the DID variable to the phone number of the new identity # - set the SID{I} variable, eg SIDA, to the SID of the new identity
# - set the NAME variable to the name of the new identity # - set the DID{I} variable, eg DIDA, to the phone number of the new identity
create_identity() { # - set the NAME{I} variable, eg NAMEA, to the name of the new identity
create_single_identity() {
DID${instance_name}1="${1-$((5550000 + $instance_number))}"
NAME${instance_name}1="${2-Agent $instance_name Smith}"
create_identities 1
local sidvar=SID${instance_name}1
local didvar=DID${instance_name}1
local namevar=NAME${instance_name}1
eval SID$instance_name="${!sidvar}"
eval DID$instance_name="${!didvar}"
eval NAME$instance_name="${!namevar}"
}
# Utility function:
# - create N identities in the current instance {I}
# - if variables DID{I}{1..N} and/or NAME{I}{1..N} are already set, then use
# them to set the DIDs and names of each identity
# - assert that all SIDs are unique
# - assert that all SIDs appear in keyring list
# - set variables SID{I}{1..N} to SIDs of identities, eg, SIDA1, SIDA2...
# - set variables DID{I}{1..N} to DIDs of identities, eg, DIDA1, DIDA2...
# - set variables NAME{I}{1..N} to names of identities, eg, NAMEA1, NAMEA2...
create_identities() {
local N="$1"
case "$N" in
+([0-9]));;
*) error "invalid arg1: $N";;
esac
local i j
for ((i = 1; i <= N; ++i)); do
executeOk_servald keyring add executeOk_servald keyring add
assert [ -e "$SERVALINSTANCE_PATH/serval.keyring" ] assert [ -e "$SERVALINSTANCE_PATH/serval.keyring" ]
local sidvar=SID$instance_name$i
local didvar=DID$instance_name$i
local namevar=NAME$instance_name$i
extract_stdout_keyvalue $sidvar sid "$rexp_sid"
tfw_log "$sidvar=${!sidvar}"
# If the DID and/or NAME is already specified in the variables, then use
# them, otherwise extract the DID and NAME automatically generated by
# servald.
if [ -n "${!didvar}" -o -n "${!namevar}" ]; then
executeOk_servald set did $SID "${!didvar}" "${!namevar}"
eval "$didvar=\${!didvar}"
eval "$namevar=\${!namevar}"
else
extract_stdout_keyvalue_optional DID$instance_name$i did "$rexp_did" && tfw_log "$didvar=${!didvar}"
extract_stdout_keyvalue_optional NAME$instance_name$i name ".*" && tfw_log "$namevar=${!namevar}"
fi
done
for ((i = 1; i <= N; ++i)); do
for ((j = 1; j <= N; ++j)); do
[ $i -ne $j ] && eval assert [ "\$SID$instance_name$i" != "\$SID$instance_name$j" ]
done
done
executeOk_servald keyring list executeOk_servald keyring list
SID=$(replayStdout | sed -ne "1s/^\($rexp_sid\):.*\$/\1/p") assertStdoutLineCount '==' $N
assert --message='main identity known' [ -n "$SID" ] for ((i = 1; i <= N; ++i)); do
DID="${1-$((5550000 + $instance_number))}" local sidvar=SID$instance_name$i
NAME="${2-Agent $instance_name Smith}" local didvar=DID$instance_name$i
executeOk_servald set did $SID "$DID" "$NAME" local namevar=NAME$instance_name$i
tfw_log "Identity $instance_name: $SID $DID $NAME" local re_name=$(escape_grep_basic "${!namevar}")
assertStdoutGrep --matches=1 "^${!sidvar}:${!didvar}:${re_name}\$"
done
} }
# Utility function, to be overridden as needed: # Utility function, to be overridden as needed:
# - set up the configuration immediately prior to starting a servald server # - set up the configuration immediately prior to starting a servald server process
# process
# - called by start_servald_instances # - called by start_servald_instances
configure_servald_server() { configure_servald_server() {
: :
} }
# Utility function: # Utility function:
# - start a set of servald server processes running on a shared dummy interface # - start a set of servald server processes running on a shared dummy interface and with its own
# and with its own private monitor and MDP abstract socket names # private monitor and MDP abstract socket names
# - set variable DUMMYNET to the full path name of shared dummy interface # - set variable DUMMYNET to the full path name of shared dummy interface
# - set variables SIDx to the SID of instance x: SIDA, SIDB, etc. # - set variables LOGx to the full path of server log file for instance x: LOGA, LOGB, etc,
# - set variables DIDx to the DID of instance x: DIDA, DIDB, etc.
# - set variables NAMEx to the names of instance x: NAMEA, NAMEB, etc.
# - set variables LOGx to the full path of server log file for instance x: LOGA,
# LOGB, etc,
# - wait for all instances to detect each other # - wait for all instances to detect each other
# - assert that all instances are in each others' peer lists # - assert that all instances are in each others' peer lists
start_servald_instances() { start_servald_instances() {
@ -458,48 +506,64 @@ start_servald_instances() {
tfw_log "# start servald instances $*" tfw_log "# start servald instances $*"
DUMMYNET=$SERVALD_VAR/dummy DUMMYNET=$SERVALD_VAR/dummy
>$DUMMYNET >$DUMMYNET
local I J local I
for I; do for I; do
set_instance $I set_instance $I
create_identity # These config settings can be overridden in a caller-supplied configure_servald_server().
# They are extremely useful for the majority of fixtures.
executeOk_servald config set interfaces "+>$DUMMYNET" executeOk_servald config set interfaces "+>$DUMMYNET"
executeOk_servald config set monitor.socket "org.servalproject.servald.monitor.socket.$TFWUNIQUE.$instance_name" executeOk_servald config set monitor.socket "org.servalproject.servald.monitor.socket.$TFWUNIQUE.$instance_name"
executeOk_servald config set mdp.socket "org.servalproject.servald.mdp.socket.$TFWUNIQUE.$instance_name" executeOk_servald config set mdp.socket "org.servalproject.servald.mdp.socket.$TFWUNIQUE.$instance_name"
configure_servald_server configure_servald_server
start_servald_server start_servald_server
eval SID$instance_name="$SID"
eval DID$instance_name="$(shellarg "$DID")"
eval NAME$instance_name="$(shellarg "$NAME")"
eval LOG$instance_name="$(shellarg "$instance_servald_log")" eval LOG$instance_name="$(shellarg "$instance_servald_log")"
done done
# Now wait until they see each other. # Now wait until they see each other.
wait_until --sleep=0.25 instances_see_each_other "$@" wait_until --sleep=0.25 instances_see_each_other "$@"
tfw_log "# dummynet file:" $(ls -l $DUMMYNET) tfw_log "# dummynet file:" $(ls -l $DUMMYNET)
# Assert that all instances report complete all-peer lists. pop_instance
}
# Assertion function:
# - asserts that all running instances report peer lists that contain all the SIDs of all the other
# running instances
# - uses the SID{I}{1..N} variables set by create_instances()
assert_all_instance_peers_complete() {
push_instance
local I J N
for I; do for I; do
set_instance $I set_instance $I
executeOk_servald id allpeers executeOk_servald id allpeers
assertStdoutLineCount '==' $(($# - 1))
for J; do for J; do
[ $I = $J ] && continue [ $I = $J ] && continue
local sidvar=SID${J#+} for ((N=1; 1; ++N)); do
local sidvar=SID${J#+}$N
[ -n "${!sidvar}" ] || break
assertStdoutGrep "${!sidvar}" assertStdoutGrep "${!sidvar}"
done done
done done
done
pop_instance pop_instance
} }
# Predicate function:
# - useful in combination with assert() and wait_until()
# - return true if all instances have logged that they have seen all other instances via the
# selfannounce mechanism
instances_see_each_other() { instances_see_each_other() {
local I J local I J N
for I; do for I; do
local logvar=LOG${I#+}
for J; do for J; do
[ $I = $J ] && continue [ $I = $J ] && continue
local logvar=LOG${I#+} for ((N=1; 1; ++N)); do
local sidvar=SID${J#+} local sidvar=SID${J#+}$N
[ -n "${!sidvar}" ] || break
if ! grep "ADD OVERLAY NODE sid=${!sidvar}" "${!logvar}"; then if ! grep "ADD OVERLAY NODE sid=${!sidvar}" "${!logvar}"; then
return 1 return 1
fi fi
done done
done done
done
return 0 return 0
} }

View File

@ -26,52 +26,6 @@ rexp_filesize='[0-9]\{1,\}'
rexp_version='[0-9]\{1,\}' rexp_version='[0-9]\{1,\}'
rexp_date='[0-9]\{1,\}' rexp_date='[0-9]\{1,\}'
# Utility function:
# - create N identities in the current instance (I)
# - set variable SID to SID of first identity
# - set variable SID{I} to SID of first identity, eg, SIDA
# - set variables SID{I}{1..N} to SIDs of identities, eg, SIDA1, SIDA2...
# - set variables DID{I}{1..N} to DIDs of identities, eg, DIDA1, DIDA2...
# - set variables NAME{I}{1..N} to names of identities, eg, NAMEA1, NAMEA2...
# - assert that all SIDs are unique
# - assert that all SIDs appear in keyring list
create_rhizome_identities() {
local N="$1"
case "$N" in
+([0-9]));;
*) error "invalid arg1: $N";;
esac
local i j
for ((i = 1; i <= N; ++i)); do
executeOk_servald keyring add
local sidvar=SID$instance_name$i
local didvar=DID$instance_name$i
local namevar=NAME$instance_name$i
extract_stdout_keyvalue $sidvar sid "$rexp_sid"
tfw_log "$sidvar=${!sidvar}"
if [ $i -eq 1 ]; then
SID="${!sidvar}"
eval SID$instance_name="$SID"
fi
extract_stdout_keyvalue_optional DID$instance_name$i did "$rexp_did" && tfw_log "$didvar=${!didvar}"
extract_stdout_keyvalue_optional NAME$instance_name$i name ".*" && tfw_log "$namevar=${!namevar}"
done
for ((i = 1; i <= N; ++i)); do
for ((j = 1; j <= N; ++j)); do
[ $i -ne $j ] && eval assert [ "\$SID$instance_name$i" != "\$SID$instance_name$j" ]
done
done
executeOk_servald keyring list
assertStdoutLineCount '==' $N
for ((i = 1; i <= N; ++i)); do
local sidvar=SID$instance_name$i
local didvar=DID$instance_name$i
local namevar=NAME$instance_name$i
local re_name=$(escape_grep_basic "${!namevar}")
assertStdoutGrep --matches=1 "^${!sidvar}:${!didvar}:${re_name}\$"
done
}
assert_manifest_complete() { assert_manifest_complete() {
local manifest="$1" local manifest="$1"
tfw_cat -v "$manifest" tfw_cat -v "$manifest"

View File

@ -26,6 +26,7 @@ setup() {
assert_no_servald_processes assert_no_servald_processes
setup_dnahelper setup_dnahelper
start_servald_instances +A start_servald_instances +A
assert_all_instance_peers_complete +A
} }
teardown() { teardown() {
@ -221,6 +222,7 @@ setup_ExecError() {
dnahelper=/non/existent dnahelper=/non/existent
assert [ ! -e "$dnahelper" ] assert [ ! -e "$dnahelper" ]
start_servald_instances +A start_servald_instances +A
assert_all_instance_peers_complete +A
} }
test_ExecError() { test_ExecError() {
executeOk_servald dna lookup 12345 executeOk_servald dna lookup 12345
@ -246,6 +248,7 @@ done
EOF EOF
chmod 0755 "$dnahelper" chmod 0755 "$dnahelper"
start_servald_instances +A start_servald_instances +A
assert_all_instance_peers_complete +A
} }
test_ExecArg1() { test_ExecArg1() {
executeOk_servald dna lookup 12345 executeOk_servald dna lookup 12345

View File

@ -27,10 +27,10 @@ shopt -s extglob
setup_rhizome() { setup_rhizome() {
set_instance +A set_instance +A
executeOk_servald config set debug.rhizome on executeOk_servald config set debug.rhizome on
create_rhizome_identities 1 create_identities 1
set_instance +B set_instance +B
executeOk_servald config set debug.rhizome on executeOk_servald config set debug.rhizome on
create_rhizome_identities 4 create_identities 4
assert [ $SIDB1 != $SIDA1 ] assert [ $SIDB1 != $SIDA1 ]
assert [ $SIDB2 != $SIDA1 ] assert [ $SIDB2 != $SIDA1 ]
assert [ $SIDB3 != $SIDA1 ] assert [ $SIDB3 != $SIDA1 ]

View File

@ -32,9 +32,9 @@ teardown() {
setup_rhizome() { setup_rhizome() {
set_instance +A set_instance +A
create_rhizome_identities 1 create_identities 1
set_instance +B set_instance +B
create_rhizome_identities 1 create_identities 1
} }
# Called by start_servald_instances for each instance. # Called by start_servald_instances for each instance.