Improve tests

This commit is contained in:
Jeremy Lakeman 2013-12-16 14:54:16 +10:30
parent 4bb3336b33
commit 6d942f8d4f
5 changed files with 121 additions and 121 deletions

View File

@ -259,6 +259,7 @@ setup_servald_so() {
start_servald_server() { start_servald_server() {
push_instance push_instance
set_instance_fromarg "$1" && shift set_instance_fromarg "$1" && shift
configure_servald_server
# Start servald server # Start servald server
local -a before_pids local -a before_pids
local -a after_pids local -a after_pids
@ -699,14 +700,8 @@ add_servald_interface() {
start_servald_instances() { start_servald_instances() {
push_instance push_instance
tfw_log "# start servald instances $*" tfw_log "# start servald instances $*"
local I foreach_instance "$@" \
for I; do
set_instance $I
# These config settings can be overridden in a caller-supplied configure_servald_server().
# They are extremely useful for the majority of fixtures.
configure_servald_server
start_servald_server start_servald_server
done
# Now wait until they see each other. # Now wait until they see each other.
foreach_instance "$@" \ foreach_instance "$@" \
wait_until --sleep=0.25 has_seen_instances "$@" wait_until --sleep=0.25 has_seen_instances "$@"

View File

@ -45,17 +45,10 @@ set_server_vars() {
set log.console.level debug \ set log.console.level debug \
set log.console.show_pid on \ set log.console.show_pid on \
set log.console.show_time on \ set log.console.show_time on \
set mdp.iftype.wifi.tick_ms 100 \
set rhizome.enable No \ set rhizome.enable No \
set debug.overlayinterfaces No \
set debug.overlaybuffer No \
set debug.packetformats No \
set debug.overlayframes No \
set debug.overlayrouting No \
set debug.packettx No \
set debug.packetrx No \
set debug.mdprequests Yes \ set debug.mdprequests Yes \
set debug.keyring Yes set debug.keyring Yes \
set debug.linkstate Yes
} }
doc_LookupWildcard="Lookup by wildcard" doc_LookupWildcard="Lookup by wildcard"

View File

@ -36,7 +36,7 @@ teardown() {
# Called by start_servald_instances for each instance. # Called by start_servald_instances for each instance.
configure_servald_server() { configure_servald_server() {
add_servald_interface add_servald_interface --file
executeOk_servald config \ executeOk_servald config \
set log.console.level debug \ set log.console.level debug \
set log.console.show_pid on \ set log.console.show_pid on \

View File

@ -27,30 +27,33 @@ interface_up() {
return 0 return 0
} }
has_link() { link_matches() {
interface_ex=".*" local interface_ex=".*"
local link_type="\(BROADCAST\|\UNICAST\)"
local via="0*"
local sid=""
while [ $# -ne 0 ]; do
case "$1" in case "$1" in
dummy*) interface_ex="$1"; shift;; --interface) interface_ex="$2"; shift 2;;
--broadcast) link_type="BROADCAST"; shift;;
--unicast) link_type="UNICAST"; shift;;
--via) link_type="INDIRECT"; via="$2"; interface_ex=""; shift 2;;
*) break;;
esac esac
set_instance $1 done
executeOk_servald route print sid="$1"
tfw_log "Looking for link from $1 to $2 ($4)" tfw_log "Looking for link ${sid}, ${link_type}, ${interface_ex}, ${via}"
if ! grep "^${4}:\(BROADCAST\|UNICAST\):${interface_ex}:0*\$" $_tfw_tmp/stdout; then if ! grep "^${sid}:${link_type}:${interface_ex}:${via}\$" $_tfw_tmp/stdout; then
tfw_log "Link not found" tfw_log "Link not found"
# tfw_log "^${4}:\(BROADCAST\|UNICAST\):${interface_ex}:0*\$"
# tfw_cat --stdout --stderr
return 1
fi
[ $4 = $5 ] && return 0;
tfw_log "Path from $1 to $3 should be via $2 ($5, $4)"
if ! grep "^${5}:INDIRECT::${4}\$" $_tfw_tmp/stdout; then
tfw_log "No path found"
# tfw_log "^${5}:INDIRECT::${4}\$"
# tfw_cat --stdout --stderr
return 1 return 1
fi fi
} }
has_link() {
executeOk_servald route print
link_matches $@
}
path_exists() { path_exists() {
local dest local dest
eval dest=\$$# eval dest=\$$#
@ -61,13 +64,17 @@ path_exists() {
for I; do for I; do
local sidvar=SID${I#+} local sidvar=SID${I#+}
[ -n "${!sidvar}" ] || break [ -n "${!sidvar}" ] || break
has_link $next_inst $I $dest ${!sidvar} ${!dest_sidvar} || return 1 set_instance $next_inst
executeOk_servald route print
link_matches ${!sidvar} || return 1
[ $I = $dest ] && return 0
link_matches --via ${!sidvar} ${!dest_sidvar} || return 1
next_inst=$I next_inst=$I
done done
return 0 return 0
} }
start_routing_instance() { configure_servald_server() {
executeOk_servald config \ executeOk_servald config \
set debug.mdprequests yes \ set debug.mdprequests yes \
set debug.linkstate yes \ set debug.linkstate yes \
@ -77,8 +84,6 @@ start_routing_instance() {
set log.console.show_pid on \ set log.console.show_pid on \
set log.console.show_time on \ set log.console.show_time on \
set rhizome.enable no set rhizome.enable no
start_servald_server
wait_until interface_up
} }
log_routing_table() { log_routing_table() {
@ -100,7 +105,7 @@ setup_single_link() {
assert_no_servald_processes assert_no_servald_processes
foreach_instance +A +B create_single_identity foreach_instance +A +B create_single_identity
foreach_instance +A +B add_servald_interface 1 foreach_instance +A +B add_servald_interface 1
foreach_instance +A +B start_routing_instance foreach_instance +A +B start_servald_server
} }
test_single_link() { test_single_link() {
wait_until --timeout=10 path_exists +A +B wait_until --timeout=10 path_exists +A +B
@ -116,25 +121,27 @@ setup_multiple_ids() {
assert_no_servald_processes assert_no_servald_processes
foreach_instance +A +B create_identities 2 foreach_instance +A +B create_identities 2
foreach_instance +A +B add_servald_interface 1 foreach_instance +A +B add_servald_interface 1
foreach_instance +A +B start_routing_instance foreach_instance +A +B start_servald_server
} }
test_multiple_ids() { test_multiple_ids() {
wait_until path_exists +A +B wait_until path_exists +A +B
wait_until has_link +A +B +B $SIDB1 $SIDB2 set_instance +A
wait_until has_link --via $SIDB1 $SIDB2
wait_until path_exists +B +A wait_until path_exists +B +A
wait_until has_link +B +A +A $SIDA1 $SIDA2 set_instance +B
wait_until has_link --via $SIDA1 $SIDA2
set_instance +A set_instance +A
executeOk_servald mdp ping --timeout=3 $SIDB2 1 executeOk_servald mdp ping --timeout=3 $SIDB2 1
tfw_cat --stdout --stderr tfw_cat --stdout --stderr
executeOk_servald route print executeOk_servald route print
assertStdoutGrep --matches=1 "^$SIDB1:BROADCAST:dummy.*:0*" link_matches --broadcast $SIDB1
assertStdoutGrep --matches=1 "^$SIDB2:INDIRECT::$SIDB1" link_matches --via $SIDB1 $SIDB2
set_instance +B set_instance +B
executeOk_servald mdp ping --timeout=3 $SIDA2 1 executeOk_servald mdp ping --timeout=3 $SIDA2 1
tfw_cat --stdout --stderr tfw_cat --stdout --stderr
executeOk_servald route print executeOk_servald route print
assertStdoutGrep --matches=1 "^$SIDA1:BROADCAST:dummy.*:0*" link_matches --broadcast $SIDA1
assertStdoutGrep --matches=1 "^$SIDA2:INDIRECT::$SIDA1" link_matches --via $SIDA1 $SIDA2
} }
doc_unlock_ids="Routes appear and disappear as identities are [un]locked" doc_unlock_ids="Routes appear and disappear as identities are [un]locked"
@ -146,14 +153,15 @@ setup_unlock_ids() {
set_instance +A set_instance +A
executeOk_servald keyring add 'entry-pin' executeOk_servald keyring add 'entry-pin'
extract_stdout_keyvalue SIDX sid "$rexp_sid" extract_stdout_keyvalue SIDX sid "$rexp_sid"
foreach_instance +A +B start_routing_instance foreach_instance +A +B start_servald_server
} }
test_unlock_ids() { test_unlock_ids() {
wait_until path_exists +A +B wait_until path_exists +A +B
wait_until path_exists +B +A wait_until path_exists +B +A
set_instance +A set_instance +A
executeOk_servald id enter pin 'entry-pin' executeOk_servald id enter pin 'entry-pin'
wait_until has_link +B +A +A $SIDA $SIDX set_instance +B
wait_until has_link --via $SIDA $SIDX
set_instance +A set_instance +A
executeOk_servald id relinquish pin 'entry-pin' executeOk_servald id relinquish pin 'entry-pin'
set_instance +B set_instance +B
@ -173,17 +181,19 @@ setup_migrate_id() {
executeOk_servald keyring load sidx '' 'entry-pin' executeOk_servald keyring load sidx '' 'entry-pin'
foreach_instance +A +B create_single_identity foreach_instance +A +B create_single_identity
foreach_instance +A +B add_servald_interface 1 foreach_instance +A +B add_servald_interface 1
foreach_instance +A +B start_routing_instance foreach_instance +A +B start_servald_server
} }
test_migrate_id() { test_migrate_id() {
wait_until path_exists +A +B wait_until path_exists +A +B
wait_until path_exists +B +A wait_until path_exists +B +A
set_instance +A set_instance +A
executeOk_servald id enter pin 'entry-pin' executeOk_servald id enter pin 'entry-pin'
wait_until has_link +B +A +A $SIDA $SIDX set_instance +B
wait_until has_link --via $SIDA $SIDX
set_instance +B set_instance +B
executeOk_servald id enter pin 'entry-pin' executeOk_servald id enter pin 'entry-pin'
wait_until --timeout=30 has_link +A +B +B $SIDB $SIDX set_instance +A
wait_until --timeout=30 has_link --via $SIDB $SIDX
} }
doc_single_mdp="Use single MDP per packet encapsulation" doc_single_mdp="Use single MDP per packet encapsulation"
@ -193,7 +203,7 @@ setup_single_mdp() {
foreach_instance +A +B create_single_identity foreach_instance +A +B create_single_identity
foreach_instance +A +B add_servald_interface 1 foreach_instance +A +B add_servald_interface 1
foreach_instance +A +B executeOk_servald config set interfaces.1.encapsulation single foreach_instance +A +B executeOk_servald config set interfaces.1.encapsulation single
foreach_instance +A +B start_routing_instance foreach_instance +A +B start_servald_server
} }
test_single_mdp() { test_single_mdp() {
wait_until path_exists +A +B wait_until path_exists +A +B
@ -210,7 +220,7 @@ setup_mismatched_encap() {
foreach_instance +A +B create_single_identity foreach_instance +A +B create_single_identity
foreach_instance +A +B add_servald_interface 1 foreach_instance +A +B add_servald_interface 1
foreach_instance +A executeOk_servald config set interfaces.1.encapsulation single foreach_instance +A executeOk_servald config set interfaces.1.encapsulation single
foreach_instance +A +B start_routing_instance foreach_instance +A +B start_servald_server
} }
test_mismatched_encap() { test_mismatched_encap() {
wait_until path_exists +A +B wait_until path_exists +A +B
@ -230,7 +240,7 @@ setup_single_p2p() {
executeOk_servald config \ executeOk_servald config \
set interfaces.1.encapsulation single \ set interfaces.1.encapsulation single \
set interfaces.1.point_to_point on set interfaces.1.point_to_point on
foreach_instance +A +B start_routing_instance foreach_instance +A +B start_servald_server
} }
test_single_p2p() { test_single_p2p() {
wait_until path_exists +A +B wait_until path_exists +A +B
@ -282,7 +292,7 @@ setup_simulate_extender() {
set interfaces.1.socket_type STREAM \ set interfaces.1.socket_type STREAM \
set interfaces.1.encapsulation SINGLE \ set interfaces.1.encapsulation SINGLE \
set interfaces.1.point_to_point on set interfaces.1.point_to_point on
foreach_instance +A +B start_routing_instance foreach_instance +A +B start_servald_server
} }
test_simulate_extender() { test_simulate_extender() {
wait_until path_exists +A +B wait_until path_exists +A +B
@ -304,7 +314,7 @@ setup_multiple_nodes() {
assert_no_servald_processes assert_no_servald_processes
foreach_instance +A +B +C +D create_single_identity foreach_instance +A +B +C +D create_single_identity
foreach_instance +A +B +C +D add_servald_interface 1 foreach_instance +A +B +C +D add_servald_interface 1
foreach_instance +A +B +C +D start_routing_instance foreach_instance +A +B +C +D start_servald_server
} }
test_multiple_nodes() { test_multiple_nodes() {
wait_until path_exists +A +B wait_until path_exists +A +B
@ -331,7 +341,9 @@ setup_scan() {
foreach_instance +A +B +C \ foreach_instance +A +B +C \
executeOk_servald config \ executeOk_servald config \
set interfaces.1.drop_broadcasts on set interfaces.1.drop_broadcasts on
foreach_instance +A +B +C start_routing_instance foreach_instance +A +B +C start_servald_server
foreach_instance +A +B +C \
wait_until interface_up
} }
test_scan() { test_scan() {
set_instance +A set_instance +A
@ -339,14 +351,14 @@ test_scan() {
wait_until scan_completed wait_until scan_completed
wait_until --timeout=10 has_seen_instances +B +C wait_until --timeout=10 has_seen_instances +B +C
executeOk_servald route print executeOk_servald route print
assertStdoutGrep --matches=1 "^$SIDB:UNICAST:" link_matches --unicast $SIDB
assertStdoutGrep --matches=1 "^$SIDC:UNICAST:" link_matches --unicast $SIDC
executeOk_servald mdp ping --timeout=3 $SIDB 1 executeOk_servald mdp ping --timeout=3 $SIDB 1
tfw_cat --stdout --stderr tfw_cat --stdout --stderr
set_instance +B set_instance +B
executeOk_servald route print executeOk_servald route print
assertStdoutGrep --matches=1 "^$SIDA:UNICAST:" link_matches --unicast $SIDA
assertStdoutGrep --matches=1 "^$SIDC:INDIRECT:" link_matches --via $SIDA $SIDC
executeOk_servald mdp ping --timeout=3 $SIDC 1 executeOk_servald mdp ping --timeout=3 $SIDC 1
tfw_cat --stdout --stderr tfw_cat --stdout --stderr
} }
@ -361,7 +373,7 @@ test_scan_one() {
wait_until scan_completed wait_until scan_completed
wait_until --timeout=10 has_seen_instances +B wait_until --timeout=10 has_seen_instances +B
executeOk_servald route print executeOk_servald route print
assertStdoutGrep --matches=1 "^$SIDB:UNICAST:" link_matches --unicast $SIDB
assertStdoutGrep --matches=0 "^$SIDC:" assertStdoutGrep --matches=0 "^$SIDC:"
executeOk_servald mdp ping --timeout=3 $SIDB 1 executeOk_servald mdp ping --timeout=3 $SIDB 1
tfw_cat --stdout --stderr tfw_cat --stdout --stderr
@ -381,19 +393,15 @@ setup_single_filter() {
set_instance +B set_instance +B
executeOk_servald config \ executeOk_servald config \
set interfaces.1.drop_broadcasts on set interfaces.1.drop_broadcasts on
foreach_instance +A +B start_routing_instance foreach_instance +A +B start_servald_server
} }
test_single_filter() { test_single_filter() {
wait_until --timeout=10 path_exists +A +B
wait_until --timeout=5 path_exists +B +A
set_instance +A set_instance +A
wait_until --timeout=10 has_link --unicast $SIDB
set_instance +B
wait_until --timeout=5 has_link --broadcast $SIDA
executeOk_servald mdp ping --timeout=3 $SIDB 1 executeOk_servald mdp ping --timeout=3 $SIDB 1
tfw_cat --stdout --stderr tfw_cat --stdout --stderr
executeOk_servald route print
assertStdoutGrep --matches=1 "^$SIDB:UNICAST:"
set_instance +B
executeOk_servald route print
assertStdoutGrep --matches=1 "^$SIDA:BROADCAST:"
} }
doc_broadcast_only="Broadcast packets only" doc_broadcast_only="Broadcast packets only"
@ -404,16 +412,16 @@ setup_broadcast_only() {
foreach_instance +A +B add_servald_interface --file 1 foreach_instance +A +B add_servald_interface --file 1
foreach_instance +A +B \ foreach_instance +A +B \
executeOk_servald config set interfaces.1.drop_unicasts 1 executeOk_servald config set interfaces.1.drop_unicasts 1
foreach_instance +A +B start_routing_instance foreach_instance +A +B start_servald_server
} }
test_broadcast_only() { test_broadcast_only() {
wait_until path_exists +A +B set_instance +A
wait_until path_exists +B +A wait_until has_link --broadcast $SIDB
set_instance +B
wait_until has_link --broadcast $SIDA
set_instance +A set_instance +A
executeOk_servald mdp ping --timeout=3 $SIDB 1 executeOk_servald mdp ping --timeout=3 $SIDB 1
tfw_cat --stdout --stderr tfw_cat --stdout --stderr
executeOk_servald route print
assertStdoutGrep --matches=1 "^$SIDB:BROADCAST:"
} }
doc_prefer_unicast="Prefer unicast packets" doc_prefer_unicast="Prefer unicast packets"
@ -426,16 +434,18 @@ setup_prefer_unicast() {
executeOk_servald config \ executeOk_servald config \
set interfaces.1.prefer_unicast 1 \ set interfaces.1.prefer_unicast 1 \
set debug.overlayframes 1 set debug.overlayframes 1
foreach_instance +A +B start_routing_instance foreach_instance +A +B start_servald_server
} }
test_prefer_unicast() { test_prefer_unicast() {
set_instance +A
wait_until has_link --unicast $SIDB
set_instance +B
wait_until has_link --unicast $SIDA
wait_until path_exists +A +B wait_until path_exists +A +B
wait_until path_exists +B +A wait_until path_exists +B +A
set_instance +A set_instance +A
executeOk_servald mdp ping --timeout=3 $SIDB 1 executeOk_servald mdp ping --timeout=3 $SIDB 1
tfw_cat --stdout --stderr tfw_cat --stdout --stderr
executeOk_servald route print
assertStdoutGrep --matches=1 "^$SIDB:UNICAST:"
} }
doc_multihop_linear="Start 4 instances in a linear arrangement" doc_multihop_linear="Start 4 instances in a linear arrangement"
@ -446,7 +456,7 @@ setup_multihop_linear() {
foreach_instance +A +B add_servald_interface 1 foreach_instance +A +B add_servald_interface 1
foreach_instance +B +C add_servald_interface 2 foreach_instance +B +C add_servald_interface 2
foreach_instance +C +D add_servald_interface 3 foreach_instance +C +D add_servald_interface 3
foreach_instance +A +B +C +D start_routing_instance foreach_instance +A +B +C +D start_servald_server
} }
test_multihop_linear() { test_multihop_linear() {
wait_until path_exists +A +B +C +D wait_until path_exists +A +B +C +D
@ -479,7 +489,7 @@ setup_unicast_route() {
executeOk_servald config \ executeOk_servald config \
set interfaces.2.drop_broadcasts on \ set interfaces.2.drop_broadcasts on \
set interfaces.3.drop_broadcasts on set interfaces.3.drop_broadcasts on
foreach_instance +A +B +C +D start_routing_instance foreach_instance +A +B +C +D start_servald_server
} }
test_unicast_route() { test_unicast_route() {
wait_until --timeout=20 path_exists +A +B +C +D wait_until --timeout=20 path_exists +A +B +C +D
@ -495,7 +505,7 @@ setup_offline() {
foreach_instance +A +B +C +D create_single_identity foreach_instance +A +B +C +D create_single_identity
foreach_instance +A +B +C add_servald_interface 1 foreach_instance +A +B +C add_servald_interface 1
foreach_instance +A +B +D add_servald_interface 2 foreach_instance +A +B +D add_servald_interface 2
foreach_instance +A +B +C +D start_routing_instance foreach_instance +A +B +C +D start_servald_server
} }
sid_offline() { sid_offline() {
@ -534,7 +544,7 @@ setup_lose_neighbours() {
foreach_instance +A +B +C create_single_identity foreach_instance +A +B +C create_single_identity
foreach_instance +A +B add_servald_interface 1 foreach_instance +A +B add_servald_interface 1
foreach_instance +B +C add_servald_interface 2 foreach_instance +B +C add_servald_interface 2
foreach_instance +A +B +C start_routing_instance foreach_instance +A +B +C start_servald_server
} }
test_lose_neighbours() { test_lose_neighbours() {
wait_until path_exists +A +B +C wait_until path_exists +A +B +C
@ -555,25 +565,25 @@ setup_multi_interface() {
foreach_instance +A +B create_single_identity foreach_instance +A +B create_single_identity
foreach_instance +A +B add_servald_interface --wifi 1 foreach_instance +A +B add_servald_interface --wifi 1
foreach_instance +A +B add_servald_interface --ethernet 2 foreach_instance +A +B add_servald_interface --ethernet 2
foreach_instance +A +B start_routing_instance foreach_instance +A +B start_servald_server
} }
doc_multi_interface="Multiple links of different types to the same neighbour" doc_multi_interface="Multiple links of different types to the same neighbour"
test_multi_interface() { test_multi_interface() {
set_instance +A set_instance +A
wait_until has_link "dummy2.*" +A +B +B $SIDB $SIDB wait_until has_link --interface "dummy2.*" $SIDB
set_instance +B set_instance +B
wait_until has_link "dummy2.*" +B +A +A $SIDA $SIDA wait_until has_link --interface "dummy2.*" $SIDA
set_instance +A set_instance +A
executeOk_servald config set interfaces.2.exclude 1 executeOk_servald config set interfaces.2.exclude 1
wait_until has_link "dummy1.*" +A +B +B $SIDB $SIDB wait_until has_link --interface "dummy1.*" $SIDB
set_instance +B set_instance +B
wait_until has_link "dummy1.*" +B +A +A $SIDA $SIDA wait_until has_link --interface "dummy1.*" $SIDA
set_instance +A set_instance +A
executeOk_servald config del interfaces.2.exclude executeOk_servald config del interfaces.2.exclude
wait_until has_link "dummy2.*" +A +B +B $SIDB $SIDB wait_until has_link --interface "dummy2.*" $SIDB
set_instance +B set_instance +B
wait_until has_link "dummy2.*" +B +A +A $SIDA $SIDA wait_until has_link --interface "dummy2.*" $SIDA
} }
# TODO assert that all packets arrive? assert that no duplicates arrive? # TODO assert that all packets arrive? assert that no duplicates arrive?
@ -586,7 +596,7 @@ setup_ping_unreliable() {
foreach_instance +A +B \ foreach_instance +A +B \
executeOk_servald config \ executeOk_servald config \
set interfaces.1.drop_packets 40 set interfaces.1.drop_packets 40
foreach_instance +A +B start_routing_instance foreach_instance +A +B start_servald_server
} }
test_ping_unreliable() { test_ping_unreliable() {
wait_until path_exists +A +B wait_until path_exists +A +B
@ -609,7 +619,7 @@ setup_ping_unreliable2() {
foreach_instance +B +C \ foreach_instance +B +C \
executeOk_servald config \ executeOk_servald config \
set interfaces.2.drop_packets 40 set interfaces.2.drop_packets 40
foreach_instance +A +B +C start_routing_instance foreach_instance +A +B +C start_servald_server
} }
test_ping_unreliable2() { test_ping_unreliable2() {
wait_until path_exists +A +B +C wait_until path_exists +A +B +C
@ -628,7 +638,7 @@ setup_brping_unreliable() {
foreach_instance +A +B \ foreach_instance +A +B \
executeOk_servald config \ executeOk_servald config \
set interfaces.1.drop_packets 20 set interfaces.1.drop_packets 20
foreach_instance +A +B start_routing_instance foreach_instance +A +B start_servald_server
} }
test_brping_unreliable() { test_brping_unreliable() {
wait_until path_exists +A +B wait_until path_exists +A +B
@ -658,7 +668,7 @@ setup_unreliable_links() {
executeOk_servald config \ executeOk_servald config \
set interfaces.2.drop_packets 5 \ set interfaces.2.drop_packets 5 \
set interfaces.3.drop_packets 70 set interfaces.3.drop_packets 70
foreach_instance +A +B +C start_routing_instance foreach_instance +A +B +C start_servald_server
} }
test_unreliable_links() { test_unreliable_links() {
wait_until path_exists +A +B +C wait_until path_exists +A +B +C
@ -701,7 +711,7 @@ setup_unreliable_links2() {
set interfaces.3.drop_packets 90 \ set interfaces.3.drop_packets 90 \
set interfaces.5.drop_packets 40 \ set interfaces.5.drop_packets 40 \
set interfaces.6.drop_packets 5 set interfaces.6.drop_packets 5
foreach_instance +A +B +C +D start_routing_instance foreach_instance +A +B +C +D start_servald_server
} }
test_unreliable_links2() { test_unreliable_links2() {
wait_until path_exists +A +B +C +D wait_until path_exists +A +B +C +D
@ -723,7 +733,7 @@ setup_circle() {
foreach_instance +F +G add_servald_interface 6 foreach_instance +F +G add_servald_interface 6
foreach_instance +G +H add_servald_interface 7 foreach_instance +G +H add_servald_interface 7
foreach_instance +H +A add_servald_interface 8 foreach_instance +H +A add_servald_interface 8
foreach_instance +A +B +C +D +E +F +G +H start_routing_instance foreach_instance +A +B +C +D +E +F +G +H start_servald_server
} }
doc_circle="Circle of nodes with one going offline" doc_circle="Circle of nodes with one going offline"
@ -735,8 +745,6 @@ test_circle() {
set_instance +A set_instance +A
executeOk_servald mdp ping --timeout=3 $SIDC 1 executeOk_servald mdp ping --timeout=3 $SIDC 1
tfw_cat --stdout --stderr tfw_cat --stdout --stderr
executeOk_servald route print
assertStdoutGrep --matches=1 "^$SIDC:INDIRECT:"
stop_servald_server +B stop_servald_server +B
foreach_instance +A +C \ foreach_instance +A +C \
wait_until --timeout=10 instance_offline +B wait_until --timeout=10 instance_offline +B
@ -745,8 +753,6 @@ test_circle() {
set_instance +A set_instance +A
executeOk_servald mdp ping --timeout=3 $SIDC 1 executeOk_servald mdp ping --timeout=3 $SIDC 1
tfw_cat --stdout --stderr tfw_cat --stdout --stderr
executeOk_servald route print
assertStdoutGrep --matches=1 "^$SIDC:INDIRECT:"
} }
setup_crowded_mess() { setup_crowded_mess() {
@ -764,16 +770,15 @@ setup_crowded_mess() {
foreach_instance +A +B +C +D +E +F +G +H \ foreach_instance +A +B +C +D +E +F +G +H \
executeOk_servald config \ executeOk_servald config \
set mdp.iftype.wifi.reachable_timeout_ms 60000 set mdp.iftype.wifi.reachable_timeout_ms 60000
foreach_instance +A +B +C +D +E +F +G +H start_routing_instance foreach_instance +A +B +C +D +E +F +G +H start_servald_server
} }
doc_crowded_mess="Multiple possible paths" doc_crowded_mess="Multiple possible paths"
test_crowded_mess() { test_crowded_mess() {
foreach_instance +A +H \ set_instance +H
wait_until has_seen_instances +A +H wait_until has_link --via "[0-9A-F]*" $SIDA
set_instance +A set_instance +A
executeOk_servald route print wait_until has_link --via "[0-9A-F]*" $SIDH
assertStdoutGrep --matches=1 "^$SIDH:INDIRECT:"
executeOk_servald mdp ping --timeout=3 $SIDH 1 executeOk_servald mdp ping --timeout=3 $SIDH 1
tfw_cat --stdout --stderr tfw_cat --stdout --stderr
} }

View File

@ -26,17 +26,17 @@ setup() {
assert_no_servald_processes assert_no_servald_processes
} }
setup_interfaces() {
>$TFWTMP/dummy
executeOk_servald config set interfaces "+>$TFWTMP/dummy"
}
teardown() { teardown() {
get_servald_server_pidfile && stop_servald_server get_servald_server_pidfile && stop_servald_server
kill_all_servald_processes kill_all_servald_processes
assert_no_servald_processes assert_no_servald_processes
} }
# make sure servald config is blank
configure_servald_server() {
:
}
doc_StartCreateInstanceDir="Starting server creates instance directory" doc_StartCreateInstanceDir="Starting server creates instance directory"
setup_StartCreateInstanceDir() { setup_StartCreateInstanceDir() {
setup setup
@ -53,10 +53,8 @@ setup_StartLogfile() {
executeOk_servald config set log.file.directory_path "$PWD/log" executeOk_servald config set log.file.directory_path "$PWD/log"
} }
test_StartLogfile() { test_StartLogfile() {
executeOk_servald start start_servald_server
sleep 0.1 assert_servald_server_no_errors
assert [ -s log/*.log ]
tfw_cat log/*.log
} }
doc_StartNoInterfaces="Starting server with no configured interfaces gives warning" doc_StartNoInterfaces="Starting server with no configured interfaces gives warning"
@ -70,14 +68,26 @@ test_StartNoInterfaces() {
tfw_cat "$instance_servald_log" tfw_cat "$instance_servald_log"
} }
doc_StartNoErrors="Starting server on dummy interface gives no errors" doc_StartNoErrors="Starting server on dummy file interface gives no errors"
setup_StartNoErrors() { setup_StartNoErrors() {
setup setup
setup_interfaces add_servald_interface --file
} }
test_StartNoErrors() { test_StartNoErrors() {
start_servald_server start_servald_server
sleep 0.1 wait_until grep "Interface .* is up" $instance_servald_log
assert_servald_server_no_errors
tfw_cat "$instance_servald_log"
}
doc_StartLocalNoErrors="Starting server on local interface gives no errors"
setup_StartLocalNoErrors() {
setup
add_servald_interface
}
test_StartLocalNoErrors() {
start_servald_server
wait_until grep "Interface .* is up" $instance_servald_log
assert_servald_server_no_errors assert_servald_server_no_errors
tfw_cat "$instance_servald_log" tfw_cat "$instance_servald_log"
} }
@ -85,7 +95,6 @@ test_StartNoErrors() {
doc_StartStart="Start server while already running" doc_StartStart="Start server while already running"
setup_StartStart() { setup_StartStart() {
setup setup
setup_interfaces
start_servald_server start_servald_server
} }
test_StartStart() { test_StartStart() {
@ -99,7 +108,6 @@ test_StartStart() {
doc_StartStopFast="Stop server before it finishes starting" doc_StartStopFast="Stop server before it finishes starting"
setup_StartStopFast() { setup_StartStopFast() {
setup setup
setup_interfaces
export SERVALD_SERVER_START_DELAY=250 export SERVALD_SERVER_START_DELAY=250
} }
test_StartStopFast() { test_StartStopFast() {
@ -110,7 +118,6 @@ test_StartStopFast() {
doc_NoZombie="Server process does not become a zombie" doc_NoZombie="Server process does not become a zombie"
setup_NoZombie() { setup_NoZombie() {
setup setup
setup_interfaces
export SERVALD_START_POST_SLEEP=1000 export SERVALD_START_POST_SLEEP=1000
servald_start & servald_start &
start_pid=$! start_pid=$!