mirror of
https://github.com/servalproject/serval-dna.git
synced 2025-01-02 11:26:45 +00:00
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:
parent
9546903ce7
commit
e994626429
126
testdefs.sh
126
testdefs.sh
@ -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
|
||||||
}
|
}
|
||||||
|
@ -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"
|
||||||
|
@ -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
|
||||||
|
@ -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 ]
|
||||||
|
@ -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.
|
||||||
|
Loading…
Reference in New Issue
Block a user