2012-10-09 04:19:24 +00:00
|
|
|
#!/bin/bash
|
|
|
|
|
|
|
|
# Tests for Route discovery
|
2013-02-06 08:25:31 +00:00
|
|
|
#
|
|
|
|
# Copyright 2012 Serval Project, Inc.
|
2012-10-09 04:19:24 +00:00
|
|
|
#
|
|
|
|
# This program is free software; you can redistribute it and/or
|
|
|
|
# modify it under the terms of the GNU General Public License
|
|
|
|
# as published by the Free Software Foundation; either version 2
|
|
|
|
# of the License, or (at your option) any later version.
|
|
|
|
#
|
|
|
|
# This program is distributed in the hope that it will be useful,
|
|
|
|
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
# GNU General Public License for more details.
|
|
|
|
#
|
|
|
|
# You should have received a copy of the GNU General Public License
|
|
|
|
# along with this program; if not, write to the Free Software
|
|
|
|
# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
|
|
|
|
|
2013-05-29 02:18:48 +00:00
|
|
|
|
2012-10-09 04:19:24 +00:00
|
|
|
source "${0%/*}/../testframework.sh"
|
|
|
|
source "${0%/*}/../testdefs.sh"
|
|
|
|
|
|
|
|
add_interface() {
|
2012-12-08 04:39:41 +00:00
|
|
|
>$SERVALD_VAR/dummy$1
|
|
|
|
executeOk_servald config \
|
2013-02-14 03:48:56 +00:00
|
|
|
set interfaces.$1.file dummy$1 \
|
2012-12-08 04:39:41 +00:00
|
|
|
set interfaces.$1.dummy_address 127.0.$1.$instance_number \
|
2013-05-10 02:35:28 +00:00
|
|
|
set interfaces.$1.dummy_netmask 255.255.255.224
|
2012-12-08 04:39:41 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
interface_up() {
|
2013-02-14 03:48:56 +00:00
|
|
|
grep "Interface .* is up" $instance_servald_log || return 1
|
2012-12-08 04:39:41 +00:00
|
|
|
return 0
|
2012-10-09 04:19:24 +00:00
|
|
|
}
|
|
|
|
|
2013-07-08 07:42:56 +00:00
|
|
|
has_link() {
|
|
|
|
set_instance $1
|
|
|
|
executeOk_servald route print
|
|
|
|
tfw_log "Looking for link from $1 to $2 ($4)"
|
2013-08-08 05:50:31 +00:00
|
|
|
if ! grep "^${4}:\(BROADCAST\|UNICAST\):dummy.*:0*\$" $_tfw_tmp/stdout; then
|
2013-07-08 07:42:56 +00:00
|
|
|
tfw_log "Link not found"
|
2013-08-08 05:50:31 +00:00
|
|
|
# tfw_log "^${4}:\(BROADCAST\|UNICAST\):dummy.*:0*\$"
|
2013-07-08 07:42:56 +00:00
|
|
|
# tfw_cat --stdout --stderr
|
|
|
|
return 1
|
|
|
|
fi
|
|
|
|
[ $4 = $5 ] && return 0;
|
|
|
|
tfw_log "Path from $1 to $3 should be via $2 ($5, $4)"
|
2013-08-08 05:50:31 +00:00
|
|
|
if ! grep "^${5}:INDIRECT::${4}\$" $_tfw_tmp/stdout; then
|
2013-07-08 07:42:56 +00:00
|
|
|
tfw_log "No path found"
|
2013-08-08 05:50:31 +00:00
|
|
|
# tfw_log "^${5}:INDIRECT::${4}\$"
|
2013-07-08 07:42:56 +00:00
|
|
|
# tfw_cat --stdout --stderr
|
|
|
|
return 1
|
|
|
|
fi
|
|
|
|
}
|
|
|
|
|
2013-05-10 02:35:28 +00:00
|
|
|
path_exists() {
|
|
|
|
local dest
|
|
|
|
for dest; do tru; done;
|
|
|
|
local dest_sidvar=SID${dest#+}
|
|
|
|
local next_inst=$1
|
|
|
|
shift
|
|
|
|
local I N
|
|
|
|
for I; do
|
|
|
|
local sidvar=SID${I#+}
|
|
|
|
[ -n "${!sidvar}" ] || break
|
2013-07-08 07:42:56 +00:00
|
|
|
has_link $next_inst $I $dest ${!sidvar} ${!dest_sidvar} || return 1
|
2013-05-10 02:35:28 +00:00
|
|
|
next_inst=$I
|
|
|
|
done
|
|
|
|
return 0
|
|
|
|
}
|
|
|
|
|
2012-10-09 04:19:24 +00:00
|
|
|
start_routing_instance() {
|
2012-12-06 02:01:19 +00:00
|
|
|
executeOk_servald config \
|
2013-02-14 03:48:56 +00:00
|
|
|
set server.interface_path "$SERVALD_VAR" \
|
2012-12-06 02:01:19 +00:00
|
|
|
set monitor.socket "org.servalproject.servald.monitor.socket.$TFWUNIQUE.$instance_name" \
|
|
|
|
set mdp.socket "org.servalproject.servald.mdp.socket.$TFWUNIQUE.$instance_name" \
|
2013-04-12 07:48:25 +00:00
|
|
|
set debug.mdprequests yes \
|
2013-04-29 00:36:22 +00:00
|
|
|
set debug.linkstate yes \
|
2013-04-30 07:05:45 +00:00
|
|
|
set debug.verbose yes \
|
2013-05-01 06:50:04 +00:00
|
|
|
set debug.overlayrouting yes \
|
2013-05-24 04:22:31 +00:00
|
|
|
set log.console.level debug \
|
|
|
|
set log.console.show_pid on \
|
|
|
|
set log.console.show_time on \
|
2012-12-10 23:26:21 +00:00
|
|
|
set rhizome.enable no
|
2012-10-09 04:19:24 +00:00
|
|
|
start_servald_server
|
2012-12-08 04:39:41 +00:00
|
|
|
wait_until interface_up
|
2012-10-09 04:19:24 +00:00
|
|
|
}
|
|
|
|
|
2012-11-26 04:10:22 +00:00
|
|
|
log_routing_table() {
|
|
|
|
executeOk_servald route print
|
|
|
|
tfw_cat --stdout --stderr
|
|
|
|
}
|
|
|
|
|
2012-10-09 04:19:24 +00:00
|
|
|
teardown() {
|
2012-11-26 04:10:22 +00:00
|
|
|
foreach_instance_with_pidfile log_routing_table
|
2012-10-09 04:19:24 +00:00
|
|
|
stop_all_servald_servers
|
|
|
|
kill_all_servald_processes
|
|
|
|
assert_no_servald_processes
|
2012-11-26 04:10:22 +00:00
|
|
|
report_all_servald_servers
|
2012-10-09 04:19:24 +00:00
|
|
|
}
|
|
|
|
|
2013-02-14 05:32:09 +00:00
|
|
|
doc_single_link="Start 2 instances on one link"
|
2012-10-09 04:19:24 +00:00
|
|
|
setup_single_link() {
|
|
|
|
setup_servald
|
|
|
|
assert_no_servald_processes
|
|
|
|
foreach_instance +A +B create_single_identity
|
2012-12-08 04:39:41 +00:00
|
|
|
foreach_instance +A +B add_interface 1
|
2012-11-30 03:15:08 +00:00
|
|
|
foreach_instance +A +B start_routing_instance
|
2012-10-09 04:19:24 +00:00
|
|
|
}
|
|
|
|
test_single_link() {
|
2013-08-08 05:50:31 +00:00
|
|
|
wait_until --timeout=10 path_exists +A +B
|
|
|
|
wait_until --timeout=5 path_exists +B +A
|
2012-10-09 04:19:24 +00:00
|
|
|
set_instance +A
|
2013-04-26 07:23:04 +00:00
|
|
|
executeOk_servald mdp ping --timeout=3 $SIDB 1
|
2012-10-09 05:39:33 +00:00
|
|
|
tfw_cat --stdout --stderr
|
2012-10-09 04:19:24 +00:00
|
|
|
}
|
|
|
|
|
2013-04-08 00:33:25 +00:00
|
|
|
doc_multiple_ids="Route between multiple identities"
|
|
|
|
setup_multiple_ids() {
|
|
|
|
setup_servald
|
|
|
|
assert_no_servald_processes
|
|
|
|
foreach_instance +A +B create_identities 2
|
|
|
|
foreach_instance +A +B add_interface 1
|
|
|
|
foreach_instance +A +B start_routing_instance
|
|
|
|
}
|
|
|
|
test_multiple_ids() {
|
2013-05-10 02:35:28 +00:00
|
|
|
wait_until path_exists +A +B
|
2013-07-08 07:42:56 +00:00
|
|
|
wait_until has_link +A +B +B $SIDB1 $SIDB2
|
2013-05-10 02:35:28 +00:00
|
|
|
wait_until path_exists +B +A
|
2013-07-08 07:42:56 +00:00
|
|
|
wait_until has_link +B +A +A $SIDA1 $SIDA2
|
2013-04-08 00:33:25 +00:00
|
|
|
set_instance +A
|
2013-04-26 07:23:04 +00:00
|
|
|
executeOk_servald mdp ping --timeout=3 $SIDB2 1
|
2013-04-08 00:33:25 +00:00
|
|
|
tfw_cat --stdout --stderr
|
|
|
|
executeOk_servald route print
|
2013-08-08 05:50:31 +00:00
|
|
|
assertStdoutGrep --matches=1 "^$SIDB1:BROADCAST:dummy.*:0*"
|
|
|
|
assertStdoutGrep --matches=1 "^$SIDB2:INDIRECT::$SIDB1"
|
2013-04-08 00:33:25 +00:00
|
|
|
set_instance +B
|
2013-04-26 07:23:04 +00:00
|
|
|
executeOk_servald mdp ping --timeout=3 $SIDA2 1
|
2013-04-08 00:33:25 +00:00
|
|
|
tfw_cat --stdout --stderr
|
|
|
|
executeOk_servald route print
|
2013-08-08 05:50:31 +00:00
|
|
|
assertStdoutGrep --matches=1 "^$SIDA1:BROADCAST:dummy.*:0*"
|
|
|
|
assertStdoutGrep --matches=1 "^$SIDA2:INDIRECT::$SIDA1"
|
2013-04-08 00:33:25 +00:00
|
|
|
}
|
|
|
|
|
2013-02-14 03:48:56 +00:00
|
|
|
doc_single_mdp="Use single MDP per packet encapsulation"
|
|
|
|
setup_single_mdp() {
|
|
|
|
setup_servald
|
|
|
|
assert_no_servald_processes
|
|
|
|
foreach_instance +A +B create_single_identity
|
|
|
|
foreach_instance +A +B add_interface 1
|
|
|
|
foreach_instance +A +B executeOk_servald config set interfaces.1.encapsulation single
|
|
|
|
foreach_instance +A +B start_routing_instance
|
|
|
|
}
|
|
|
|
test_single_mdp() {
|
2013-05-10 02:35:28 +00:00
|
|
|
wait_until path_exists +A +B
|
|
|
|
wait_until path_exists +B +A
|
2013-02-14 03:48:56 +00:00
|
|
|
set_instance +A
|
2013-04-26 07:23:04 +00:00
|
|
|
executeOk_servald mdp ping --timeout=3 $SIDB 1
|
2013-02-14 03:48:56 +00:00
|
|
|
tfw_cat --stdout --stderr
|
|
|
|
}
|
|
|
|
|
|
|
|
doc_mismatched_encap="Mismatched MDP packet encapsulation"
|
|
|
|
setup_mismatched_encap() {
|
|
|
|
setup_servald
|
|
|
|
assert_no_servald_processes
|
|
|
|
foreach_instance +A +B create_single_identity
|
|
|
|
foreach_instance +A +B add_interface 1
|
|
|
|
foreach_instance +A executeOk_servald config set interfaces.1.encapsulation single
|
|
|
|
foreach_instance +A +B start_routing_instance
|
|
|
|
}
|
|
|
|
test_mismatched_encap() {
|
2013-05-10 02:35:28 +00:00
|
|
|
wait_until path_exists +A +B
|
|
|
|
wait_until path_exists +B +A
|
2013-02-14 03:48:56 +00:00
|
|
|
set_instance +A
|
2013-04-26 07:23:04 +00:00
|
|
|
executeOk_servald mdp ping --timeout=3 $SIDB 1
|
2013-02-14 03:48:56 +00:00
|
|
|
tfw_cat --stdout --stderr
|
|
|
|
}
|
|
|
|
|
2013-07-16 05:46:07 +00:00
|
|
|
doc_single_p2p="Start 2 instances on a point to point link"
|
|
|
|
setup_single_p2p() {
|
|
|
|
setup_servald
|
|
|
|
assert_no_servald_processes
|
|
|
|
foreach_instance +A +B create_single_identity
|
|
|
|
foreach_instance +A +B add_interface 1
|
|
|
|
foreach_instance +A +B \
|
|
|
|
executeOk_servald config \
|
|
|
|
set interfaces.1.debug 1 \
|
|
|
|
set interfaces.1.encapsulation single \
|
|
|
|
set interfaces.1.point_to_point on
|
|
|
|
foreach_instance +A +B start_routing_instance
|
|
|
|
}
|
|
|
|
test_single_p2p() {
|
|
|
|
wait_until path_exists +A +B
|
|
|
|
wait_until path_exists +B +A
|
|
|
|
assertGrep "$instance_servald_log" 'Established point to point link'
|
|
|
|
set_instance +A
|
|
|
|
executeOk_servald mdp ping --timeout=3 $SIDB 1
|
|
|
|
tfw_cat --stdout --stderr
|
|
|
|
}
|
|
|
|
|
2013-02-19 23:51:56 +00:00
|
|
|
doc_slip_encoding="Test slip encoding and decoding"
|
|
|
|
setup_slip_encoding() {
|
|
|
|
setup_servald
|
|
|
|
assert_no_servald_processes
|
|
|
|
}
|
|
|
|
test_slip_encoding() {
|
2013-04-22 06:31:38 +00:00
|
|
|
executeOk_servald test slip --seed=1 --iterations=2000
|
2013-02-19 23:51:56 +00:00
|
|
|
}
|
|
|
|
|
2013-02-14 05:32:09 +00:00
|
|
|
doc_multiple_nodes="Multiple nodes on one link"
|
2012-11-30 03:15:08 +00:00
|
|
|
setup_multiple_nodes() {
|
|
|
|
setup_servald
|
|
|
|
assert_no_servald_processes
|
|
|
|
foreach_instance +A +B +C +D create_single_identity
|
2012-12-08 04:39:41 +00:00
|
|
|
foreach_instance +A +B +C +D add_interface 1
|
2012-11-30 03:15:08 +00:00
|
|
|
foreach_instance +A +B +C +D start_routing_instance
|
|
|
|
}
|
|
|
|
test_multiple_nodes() {
|
2013-05-10 02:35:28 +00:00
|
|
|
wait_until path_exists +A +B
|
|
|
|
wait_until path_exists +A +C
|
|
|
|
wait_until path_exists +A +D
|
2013-08-12 04:51:31 +00:00
|
|
|
wait_until path_exists +B +A
|
|
|
|
wait_until path_exists +C +A
|
|
|
|
wait_until path_exists +D +A
|
2012-11-30 03:15:08 +00:00
|
|
|
set_instance +A
|
2013-04-26 07:23:04 +00:00
|
|
|
executeOk_servald mdp ping --timeout=3 $SIDB 1
|
2012-11-30 03:15:08 +00:00
|
|
|
tfw_cat --stdout --stderr
|
2013-04-26 07:23:04 +00:00
|
|
|
executeOk_servald mdp ping --timeout=3 $SIDC 1
|
2012-11-30 03:15:08 +00:00
|
|
|
tfw_cat --stdout --stderr
|
2013-04-26 07:23:04 +00:00
|
|
|
executeOk_servald mdp ping --timeout=3 $SIDD 1
|
2012-11-30 03:15:08 +00:00
|
|
|
tfw_cat --stdout --stderr
|
|
|
|
}
|
|
|
|
|
2013-08-09 02:48:14 +00:00
|
|
|
doc_scan="Network scan with isolated clients"
|
2012-12-08 04:39:41 +00:00
|
|
|
setup_scan() {
|
|
|
|
setup_servald
|
|
|
|
assert_no_servald_processes
|
2013-08-09 06:49:45 +00:00
|
|
|
foreach_instance +A +B +C create_single_identity
|
|
|
|
foreach_instance +A +B +C add_interface 1
|
|
|
|
foreach_instance +A +B +C \
|
2012-12-08 04:39:41 +00:00
|
|
|
executeOk_servald config \
|
2013-08-12 04:51:31 +00:00
|
|
|
set interfaces.1.drop_broadcasts on
|
2013-08-09 06:49:45 +00:00
|
|
|
foreach_instance +A +B +C start_routing_instance
|
2012-12-08 04:39:41 +00:00
|
|
|
}
|
|
|
|
test_scan() {
|
2012-12-10 23:26:21 +00:00
|
|
|
set_instance +A
|
|
|
|
executeOk_servald scan
|
|
|
|
wait_until scan_completed
|
2013-08-09 06:49:45 +00:00
|
|
|
wait_until --timeout=10 has_seen_instances +B +C
|
|
|
|
executeOk_servald route print
|
|
|
|
assertStdoutGrep --matches=1 "^$SIDB:UNICAST:"
|
|
|
|
assertStdoutGrep --matches=1 "^$SIDC:UNICAST:"
|
2013-04-26 07:23:04 +00:00
|
|
|
executeOk_servald mdp ping --timeout=3 $SIDB 1
|
2012-12-14 01:44:55 +00:00
|
|
|
tfw_cat --stdout --stderr
|
2013-08-09 06:49:45 +00:00
|
|
|
set_instance +B
|
2012-12-10 23:26:21 +00:00
|
|
|
executeOk_servald route print
|
2013-08-09 06:49:45 +00:00
|
|
|
assertStdoutGrep --matches=1 "^$SIDA:UNICAST:"
|
|
|
|
assertStdoutGrep --matches=1 "^$SIDC:INDIRECT:"
|
|
|
|
executeOk_servald mdp ping --timeout=3 $SIDC 1
|
|
|
|
tfw_cat --stdout --stderr
|
2012-12-08 04:39:41 +00:00
|
|
|
}
|
|
|
|
|
2013-08-12 04:51:31 +00:00
|
|
|
doc_scan_one="Network scan a single address"
|
|
|
|
setup_scan_one() {
|
|
|
|
setup_scan
|
|
|
|
}
|
|
|
|
test_scan_one() {
|
|
|
|
set_instance +A
|
|
|
|
executeOk_servald scan 127.0.1.2
|
|
|
|
wait_until scan_completed
|
|
|
|
wait_until --timeout=10 has_seen_instances +B
|
|
|
|
executeOk_servald route print
|
|
|
|
assertStdoutGrep --matches=1 "^$SIDB:UNICAST:"
|
|
|
|
assertStdoutGrep --matches=0 "^$SIDC:"
|
|
|
|
executeOk_servald mdp ping --timeout=3 $SIDB 1
|
|
|
|
tfw_cat --stdout --stderr
|
|
|
|
}
|
|
|
|
|
2013-02-14 05:32:09 +00:00
|
|
|
scan_completed() {
|
2013-08-09 06:49:45 +00:00
|
|
|
grep "Scan completed" $instance_servald_log || return 1
|
2013-02-14 05:32:09 +00:00
|
|
|
return 0
|
|
|
|
}
|
|
|
|
|
2013-05-29 02:18:48 +00:00
|
|
|
doc_single_filter="Single device with a broadcast filter"
|
|
|
|
setup_single_filter() {
|
|
|
|
setup_servald
|
|
|
|
assert_no_servald_processes
|
|
|
|
foreach_instance +A +B create_single_identity
|
|
|
|
foreach_instance +A +B add_interface 1
|
|
|
|
set_instance +B
|
|
|
|
executeOk_servald config \
|
2013-08-12 04:51:31 +00:00
|
|
|
set interfaces.1.drop_broadcasts on
|
2013-05-29 02:18:48 +00:00
|
|
|
foreach_instance +A +B start_routing_instance
|
|
|
|
}
|
|
|
|
test_single_filter() {
|
2013-08-09 02:48:14 +00:00
|
|
|
wait_until --timeout=10 path_exists +A +B
|
|
|
|
wait_until --timeout=5 path_exists +B +A
|
2013-05-29 02:18:48 +00:00
|
|
|
set_instance +A
|
|
|
|
executeOk_servald mdp ping --timeout=3 $SIDB 1
|
|
|
|
tfw_cat --stdout --stderr
|
2013-08-09 02:48:14 +00:00
|
|
|
executeOk_servald route print
|
|
|
|
assertStdoutGrep --matches=1 "^$SIDB:UNICAST:"
|
|
|
|
set_instance +B
|
|
|
|
executeOk_servald route print
|
|
|
|
assertStdoutGrep --matches=1 "^$SIDA:BROADCAST:"
|
2013-05-29 02:18:48 +00:00
|
|
|
}
|
|
|
|
|
2013-02-14 05:32:09 +00:00
|
|
|
doc_broadcast_only="Broadcast packets only"
|
2013-01-29 00:57:13 +00:00
|
|
|
setup_broadcast_only() {
|
|
|
|
setup_servald
|
|
|
|
assert_no_servald_processes
|
|
|
|
foreach_instance +A +B create_single_identity
|
|
|
|
foreach_instance +A +B add_interface 1
|
2013-05-10 02:35:28 +00:00
|
|
|
foreach_instance +A +B \
|
|
|
|
executeOk_servald config set interfaces.1.drop_unicasts 1
|
2013-01-29 00:57:13 +00:00
|
|
|
foreach_instance +A +B start_routing_instance
|
|
|
|
}
|
|
|
|
test_broadcast_only() {
|
2013-05-29 02:18:48 +00:00
|
|
|
wait_until path_exists +A +B
|
|
|
|
wait_until path_exists +B +A
|
2013-01-29 00:57:13 +00:00
|
|
|
set_instance +A
|
2013-04-26 07:23:04 +00:00
|
|
|
executeOk_servald mdp ping --timeout=3 $SIDB 1
|
2013-01-29 00:57:13 +00:00
|
|
|
tfw_cat --stdout --stderr
|
|
|
|
executeOk_servald route print
|
2013-08-08 05:50:31 +00:00
|
|
|
assertStdoutGrep --matches=1 "^$SIDB:BROADCAST:"
|
2013-01-29 00:57:13 +00:00
|
|
|
}
|
|
|
|
|
2013-02-14 05:32:09 +00:00
|
|
|
doc_prefer_unicast="Prefer unicast packets"
|
2013-01-29 00:57:13 +00:00
|
|
|
setup_prefer_unicast() {
|
|
|
|
setup_servald
|
|
|
|
assert_no_servald_processes
|
|
|
|
foreach_instance +A +B create_single_identity
|
|
|
|
foreach_instance +A +B add_interface 1
|
|
|
|
foreach_instance +A +B \
|
|
|
|
executeOk_servald config \
|
|
|
|
set interfaces.1.prefer_unicast 1 \
|
|
|
|
set debug.overlayframes 1
|
|
|
|
foreach_instance +A +B start_routing_instance
|
|
|
|
}
|
|
|
|
test_prefer_unicast() {
|
2013-05-29 02:18:48 +00:00
|
|
|
wait_until path_exists +A +B
|
|
|
|
wait_until path_exists +B +A
|
2013-01-29 00:57:13 +00:00
|
|
|
set_instance +A
|
2013-04-26 07:23:04 +00:00
|
|
|
executeOk_servald mdp ping --timeout=3 $SIDB 1
|
2013-01-29 00:57:13 +00:00
|
|
|
tfw_cat --stdout --stderr
|
|
|
|
executeOk_servald route print
|
2013-08-08 05:50:31 +00:00
|
|
|
assertStdoutGrep --matches=1 "^$SIDB:UNICAST:"
|
2013-01-29 00:57:13 +00:00
|
|
|
}
|
|
|
|
|
2013-02-14 05:32:09 +00:00
|
|
|
doc_multihop_linear="Start 4 instances in a linear arrangement"
|
2012-10-09 04:19:24 +00:00
|
|
|
setup_multihop_linear() {
|
|
|
|
setup_servald
|
|
|
|
assert_no_servald_processes
|
|
|
|
foreach_instance +A +B +C +D create_single_identity
|
2012-12-08 04:39:41 +00:00
|
|
|
foreach_instance +A +B add_interface 1
|
|
|
|
foreach_instance +B +C add_interface 2
|
|
|
|
foreach_instance +C +D add_interface 3
|
2012-10-09 04:19:24 +00:00
|
|
|
foreach_instance +A +B +C +D start_routing_instance
|
|
|
|
}
|
|
|
|
test_multihop_linear() {
|
2013-05-10 02:35:28 +00:00
|
|
|
wait_until path_exists +A +B +C +D
|
|
|
|
wait_until path_exists +D +C +B +A
|
2012-10-09 04:19:24 +00:00
|
|
|
set_instance +A
|
2013-04-26 07:23:04 +00:00
|
|
|
executeOk_servald --stdout --stderr mdp ping --timeout=3 $SIDD 1
|
2012-10-09 05:39:33 +00:00
|
|
|
tfw_cat --stdout --stderr
|
2013-02-18 04:01:01 +00:00
|
|
|
executeOk_servald mdp trace $SIDD
|
2013-05-10 02:35:28 +00:00
|
|
|
assertStdoutGrep --matches=1 "^0:$SIDA\$"
|
|
|
|
assertStdoutGrep --matches=1 "^1:$SIDB\$"
|
|
|
|
assertStdoutGrep --matches=1 "^2:$SIDC\$"
|
|
|
|
assertStdoutGrep --matches=1 "^3:$SIDD\$"
|
|
|
|
assertStdoutGrep --matches=1 "^4:$SIDC\$"
|
|
|
|
assertStdoutGrep --matches=1 "^5:$SIDB\$"
|
|
|
|
assertStdoutGrep --matches=1 "^6:$SIDA\$"
|
2012-10-09 04:19:24 +00:00
|
|
|
}
|
|
|
|
|
2013-08-09 06:49:45 +00:00
|
|
|
doc_unicast_route="Route across unicast links"
|
|
|
|
setup_unicast_route() {
|
|
|
|
setup_servald
|
|
|
|
assert_no_servald_processes
|
|
|
|
foreach_instance +A +B +C +D create_single_identity
|
|
|
|
foreach_instance +A +B add_interface 1
|
|
|
|
foreach_instance +B +C add_interface 2
|
|
|
|
foreach_instance +C +D add_interface 3
|
|
|
|
set_instance +A
|
|
|
|
executeOk_servald config \
|
2013-08-12 04:51:31 +00:00
|
|
|
set interfaces.1.drop_broadcasts on
|
2013-08-09 06:49:45 +00:00
|
|
|
set_instance +C
|
|
|
|
executeOk_servald config \
|
2013-08-12 04:51:31 +00:00
|
|
|
set interfaces.2.drop_broadcasts on \
|
|
|
|
set interfaces.3.drop_broadcasts on
|
2013-08-09 06:49:45 +00:00
|
|
|
foreach_instance +A +B +C +D start_routing_instance
|
|
|
|
}
|
|
|
|
test_unicast_route() {
|
|
|
|
wait_until --timeout=20 path_exists +A +B +C +D
|
|
|
|
wait_until --timeout=5 path_exists +D +C +B +A
|
|
|
|
set_instance +A
|
|
|
|
executeOk_servald mdp ping --timeout=3 $SIDD 1
|
|
|
|
tfw_cat --stdout --stderr
|
|
|
|
}
|
|
|
|
|
2013-04-29 07:37:36 +00:00
|
|
|
setup_offline() {
|
|
|
|
setup_servald
|
|
|
|
assert_no_servald_processes
|
|
|
|
foreach_instance +A +B +C +D create_single_identity
|
|
|
|
foreach_instance +A +B +C add_interface 1
|
|
|
|
foreach_instance +A +B +D add_interface 2
|
|
|
|
foreach_instance +A +B +C +D start_routing_instance
|
|
|
|
}
|
|
|
|
|
|
|
|
instance_offline() {
|
|
|
|
local I N
|
|
|
|
for I; do
|
|
|
|
[ $I = $instance_arg ] && continue
|
|
|
|
for ((N=1; 1; ++N)); do
|
|
|
|
local sidvar=SID${I#+}$N
|
|
|
|
[ -n "${!sidvar}" ] || break
|
2013-08-08 05:50:31 +00:00
|
|
|
if ! grep "NOT REACHABLE sid=${!sidvar}" $instance_servald_log; then
|
2013-04-29 07:37:36 +00:00
|
|
|
return 1
|
|
|
|
fi
|
|
|
|
done
|
|
|
|
done
|
|
|
|
}
|
|
|
|
|
|
|
|
doc_offline="One node going offline"
|
|
|
|
test_offline() {
|
|
|
|
foreach_instance +A +B +C +D \
|
|
|
|
wait_until has_seen_instances +A +B +C +D
|
|
|
|
stop_servald_server +C
|
|
|
|
foreach_instance +A +B +D \
|
|
|
|
wait_until --timeout=30 instance_offline +C
|
|
|
|
}
|
|
|
|
|
2013-05-31 02:02:13 +00:00
|
|
|
doc_lose_neighbours="Lose and regain neighbours"
|
|
|
|
setup_lose_neighbours() {
|
|
|
|
setup_servald
|
|
|
|
assert_no_servald_processes
|
|
|
|
foreach_instance +A +B +C create_single_identity
|
|
|
|
foreach_instance +A +B add_interface 1
|
|
|
|
foreach_instance +B +C add_interface 2
|
|
|
|
foreach_instance +A +B +C start_routing_instance
|
|
|
|
}
|
|
|
|
test_lose_neighbours() {
|
|
|
|
wait_until path_exists +A +B +C
|
|
|
|
wait_until path_exists +C +B +A
|
|
|
|
stop_servald_server +B
|
|
|
|
foreach_instance +A +C \
|
|
|
|
wait_until --timeout=30 instance_offline +B
|
2013-06-11 00:47:41 +00:00
|
|
|
set_instance +A
|
|
|
|
wait_until --timeout=30 instance_offline +C
|
2013-05-31 02:02:13 +00:00
|
|
|
start_servald_server +B
|
|
|
|
wait_until path_exists +A +B +C
|
|
|
|
wait_until path_exists +C +B +A
|
|
|
|
}
|
|
|
|
|
2013-05-01 06:16:47 +00:00
|
|
|
setup_multi_interface() {
|
|
|
|
setup_servald
|
|
|
|
assert_no_servald_processes
|
|
|
|
foreach_instance +A +B create_single_identity
|
|
|
|
>$SERVALD_VAR/dummywifi
|
|
|
|
>$SERVALD_VAR/dummyeth
|
|
|
|
foreach_instance +A +B \
|
|
|
|
executeOk_servald config \
|
|
|
|
set interfaces.1.file dummywifi \
|
|
|
|
set interfaces.1.dummy_address 127.0.1.$instance_number \
|
|
|
|
set interfaces.1.dummy_netmask 255.255.255.224 \
|
|
|
|
set interfaces.1.type wifi \
|
|
|
|
set interfaces.2.file dummyeth \
|
|
|
|
set interfaces.2.dummy_address 127.0.2.$instance_number \
|
|
|
|
set interfaces.2.dummy_netmask 255.255.255.224 \
|
2013-05-01 06:50:04 +00:00
|
|
|
set interfaces.2.type ethernet
|
2013-05-01 06:16:47 +00:00
|
|
|
foreach_instance +A +B start_routing_instance
|
|
|
|
}
|
|
|
|
|
2013-05-01 06:50:04 +00:00
|
|
|
multi_has_link() {
|
|
|
|
executeOk_servald route print
|
2013-08-08 05:50:31 +00:00
|
|
|
grep "^$1:BROADCAST:dummyeth" $_tfw_tmp/stdout || return 1
|
2013-05-01 06:50:04 +00:00
|
|
|
return 0
|
|
|
|
}
|
|
|
|
|
2013-05-01 06:16:47 +00:00
|
|
|
doc_multi_interface="Multiple links of different types to the same neighbour"
|
|
|
|
test_multi_interface() {
|
|
|
|
set_instance +A
|
2013-05-01 06:50:04 +00:00
|
|
|
wait_until multi_has_link $SIDB
|
2013-05-01 06:16:47 +00:00
|
|
|
set_instance +B
|
2013-05-01 06:50:04 +00:00
|
|
|
wait_until multi_has_link $SIDA
|
2013-05-01 06:16:47 +00:00
|
|
|
}
|
|
|
|
|
2013-05-15 06:26:43 +00:00
|
|
|
# TODO assert that all packets arrive? assert that no duplicates arrive?
|
2013-05-15 04:57:38 +00:00
|
|
|
doc_ping_unreliable="Ping over a 1-hop unreliable link"
|
2013-05-15 02:03:43 +00:00
|
|
|
setup_ping_unreliable() {
|
|
|
|
setup_servald
|
|
|
|
assert_no_servald_processes
|
|
|
|
foreach_instance +A +B create_single_identity
|
|
|
|
foreach_instance +A +B add_interface 1
|
|
|
|
foreach_instance +A +B \
|
|
|
|
executeOk_servald config \
|
2013-08-12 04:51:31 +00:00
|
|
|
set interfaces.1.drop_packets 40
|
2013-05-15 02:03:43 +00:00
|
|
|
foreach_instance +A +B start_routing_instance
|
|
|
|
}
|
|
|
|
test_ping_unreliable() {
|
|
|
|
wait_until path_exists +A +B
|
|
|
|
wait_until path_exists +B +A
|
|
|
|
set_instance +A
|
2013-05-27 04:45:06 +00:00
|
|
|
executeOk_servald mdp ping --interval=0.100 --timeout=3 $SIDB 100
|
2013-05-24 04:22:31 +00:00
|
|
|
tfw_cat --stdout --stderr
|
|
|
|
}
|
|
|
|
|
2013-05-27 04:52:31 +00:00
|
|
|
doc_ping_unreliable2="Ping over a 2-hop unreliable link"
|
|
|
|
setup_ping_unreliable2() {
|
2013-05-24 04:22:31 +00:00
|
|
|
setup_servald
|
|
|
|
assert_no_servald_processes
|
|
|
|
foreach_instance +A +B +C create_single_identity
|
|
|
|
foreach_instance +A +B add_interface 1
|
|
|
|
foreach_instance +A +B \
|
|
|
|
executeOk_servald config \
|
2013-08-12 04:51:31 +00:00
|
|
|
set interfaces.1.drop_packets 40
|
2013-05-24 04:22:31 +00:00
|
|
|
foreach_instance +B +C add_interface 2
|
|
|
|
foreach_instance +B +C \
|
|
|
|
executeOk_servald config \
|
2013-08-12 04:51:31 +00:00
|
|
|
set interfaces.2.drop_packets 40
|
2013-05-24 04:22:31 +00:00
|
|
|
foreach_instance +A +B +C start_routing_instance
|
|
|
|
}
|
2013-05-27 04:52:31 +00:00
|
|
|
test_ping_unreliable2() {
|
2013-05-24 04:22:31 +00:00
|
|
|
wait_until path_exists +A +B +C
|
|
|
|
wait_until path_exists +C +B +A
|
|
|
|
set_instance +A
|
2013-05-27 04:45:06 +00:00
|
|
|
executeOk_servald mdp ping --interval=0.100 --timeout=3 $SIDC 100
|
2013-05-15 02:03:43 +00:00
|
|
|
tfw_cat --stdout --stderr
|
|
|
|
}
|
|
|
|
|
2013-05-20 03:53:35 +00:00
|
|
|
doc_brping_unreliable="Broadcast ping over a 1-hop unreliable link"
|
|
|
|
setup_brping_unreliable() {
|
|
|
|
setup_servald
|
|
|
|
assert_no_servald_processes
|
|
|
|
foreach_instance +A +B create_single_identity
|
|
|
|
foreach_instance +A +B add_interface 1
|
|
|
|
foreach_instance +A +B \
|
|
|
|
executeOk_servald config \
|
2013-08-12 04:51:31 +00:00
|
|
|
set interfaces.1.drop_packets 20
|
2013-05-20 03:53:35 +00:00
|
|
|
foreach_instance +A +B start_routing_instance
|
|
|
|
}
|
|
|
|
test_brping_unreliable() {
|
|
|
|
wait_until path_exists +A +B
|
|
|
|
wait_until path_exists +B +A
|
|
|
|
set_instance +A
|
2013-05-27 04:45:06 +00:00
|
|
|
executeOk_servald mdp ping --interval=0.100 --timeout=2 broadcast 100
|
2013-05-20 03:53:35 +00:00
|
|
|
tfw_cat --stdout --stderr
|
|
|
|
}
|
|
|
|
|
2013-05-16 04:36:08 +00:00
|
|
|
doc_unreliable_links="Prefer a longer, better path vs an unreliable link"
|
2013-05-07 03:59:42 +00:00
|
|
|
setup_unreliable_links() {
|
|
|
|
setup_servald
|
|
|
|
assert_no_servald_processes
|
|
|
|
foreach_instance +A +B +C create_single_identity
|
|
|
|
foreach_instance +A +B add_interface 1
|
|
|
|
foreach_instance +B +C add_interface 2
|
|
|
|
foreach_instance +A +C add_interface 3
|
|
|
|
set_instance +A
|
|
|
|
executeOk_servald config \
|
2013-08-12 04:51:31 +00:00
|
|
|
set interfaces.1.drop_packets 5 \
|
|
|
|
set interfaces.3.drop_packets 70
|
2013-05-08 01:28:26 +00:00
|
|
|
set_instance +B
|
|
|
|
executeOk_servald config \
|
2013-08-12 04:51:31 +00:00
|
|
|
set interfaces.1.drop_packets 5 \
|
|
|
|
set interfaces.2.drop_packets 5
|
2013-05-07 03:59:42 +00:00
|
|
|
set_instance +C
|
|
|
|
executeOk_servald config \
|
2013-08-12 04:51:31 +00:00
|
|
|
set interfaces.2.drop_packets 5 \
|
|
|
|
set interfaces.3.drop_packets 70
|
2013-05-07 03:59:42 +00:00
|
|
|
foreach_instance +A +B +C start_routing_instance
|
|
|
|
}
|
|
|
|
test_unreliable_links() {
|
2013-05-10 02:35:28 +00:00
|
|
|
wait_until path_exists +A +B +C
|
|
|
|
wait_until path_exists +C +B +A
|
2013-05-07 03:59:42 +00:00
|
|
|
set_instance +A
|
2013-05-16 04:36:08 +00:00
|
|
|
executeOk_servald mdp ping --interval=0.100 --timeout=3 $SIDC 30
|
2013-05-07 03:59:42 +00:00
|
|
|
tfw_cat --stdout --stderr
|
2013-05-20 03:53:35 +00:00
|
|
|
wait_until path_exists +A +B +C
|
|
|
|
wait_until path_exists +C +B +A
|
2013-05-07 03:59:42 +00:00
|
|
|
}
|
|
|
|
|
2013-05-08 01:28:26 +00:00
|
|
|
doc_unreliable_links2="Choose the best multihop path with some unreliable links"
|
|
|
|
setup_unreliable_links2() {
|
|
|
|
setup_servald
|
|
|
|
assert_no_servald_processes
|
|
|
|
foreach_instance +A +B +C +D create_single_identity
|
|
|
|
foreach_instance +A +B add_interface 1
|
|
|
|
foreach_instance +A +C add_interface 2
|
|
|
|
foreach_instance +A +D add_interface 3
|
|
|
|
foreach_instance +B +C add_interface 4
|
|
|
|
foreach_instance +B +D add_interface 5
|
|
|
|
foreach_instance +C +D add_interface 6
|
|
|
|
set_instance +A
|
|
|
|
executeOk_servald config \
|
2013-08-12 04:51:31 +00:00
|
|
|
set interfaces.1.drop_packets 5 \
|
|
|
|
set interfaces.2.drop_packets 40 \
|
|
|
|
set interfaces.3.drop_packets 90
|
2013-05-08 01:28:26 +00:00
|
|
|
set_instance +B
|
|
|
|
executeOk_servald config \
|
2013-08-12 04:51:31 +00:00
|
|
|
set interfaces.1.drop_packets 5 \
|
|
|
|
set interfaces.4.drop_packets 5 \
|
|
|
|
set interfaces.5.drop_packets 40
|
2013-05-08 01:28:26 +00:00
|
|
|
set_instance +C
|
|
|
|
executeOk_servald config \
|
2013-08-12 04:51:31 +00:00
|
|
|
set interfaces.2.drop_packets 40 \
|
|
|
|
set interfaces.4.drop_packets 5 \
|
|
|
|
set interfaces.6.drop_packets 5
|
2013-05-08 01:28:26 +00:00
|
|
|
set_instance +D
|
|
|
|
executeOk_servald config \
|
2013-08-12 04:51:31 +00:00
|
|
|
set interfaces.3.drop_packets 90 \
|
|
|
|
set interfaces.5.drop_packets 40 \
|
|
|
|
set interfaces.6.drop_packets 5
|
2013-05-08 01:28:26 +00:00
|
|
|
foreach_instance +A +B +C +D start_routing_instance
|
|
|
|
}
|
|
|
|
test_unreliable_links2() {
|
2013-05-10 02:35:28 +00:00
|
|
|
wait_until path_exists +A +B +C +D
|
|
|
|
wait_until path_exists +D +C +B +A
|
2013-05-08 01:28:26 +00:00
|
|
|
set_instance +A
|
|
|
|
executeOk_servald mdp ping --timeout=3 $SIDD 5
|
|
|
|
tfw_cat --stdout --stderr
|
|
|
|
}
|
|
|
|
|
2013-04-29 07:37:36 +00:00
|
|
|
setup_circle() {
|
|
|
|
setup_servald
|
|
|
|
assert_no_servald_processes
|
|
|
|
foreach_instance +A +B +C +D +E +F +G +H create_single_identity
|
|
|
|
foreach_instance +A +B add_interface 1
|
|
|
|
foreach_instance +B +C add_interface 2
|
|
|
|
foreach_instance +C +D add_interface 3
|
|
|
|
foreach_instance +D +E add_interface 4
|
|
|
|
foreach_instance +E +F add_interface 5
|
|
|
|
foreach_instance +F +G add_interface 6
|
|
|
|
foreach_instance +G +H add_interface 7
|
|
|
|
foreach_instance +H +A add_interface 8
|
|
|
|
foreach_instance +A +B +C +D +E +F +G +H start_routing_instance
|
|
|
|
}
|
|
|
|
|
|
|
|
doc_circle="Circle of nodes with one going offline"
|
|
|
|
test_circle() {
|
|
|
|
foreach_instance +A +B +C +D +E +F +G +H \
|
|
|
|
wait_until has_seen_instances +A +B +C +D +E +F +G +H
|
2013-05-10 02:35:28 +00:00
|
|
|
wait_until path_exists +A +B +C
|
|
|
|
wait_until path_exists +C +B +A
|
2013-04-29 07:37:36 +00:00
|
|
|
set_instance +A
|
|
|
|
executeOk_servald mdp ping --timeout=3 $SIDC 1
|
|
|
|
tfw_cat --stdout --stderr
|
|
|
|
executeOk_servald route print
|
2013-08-08 05:50:31 +00:00
|
|
|
assertStdoutGrep --matches=1 "^$SIDC:INDIRECT:"
|
2013-04-29 07:37:36 +00:00
|
|
|
stop_servald_server +B
|
2013-04-30 07:05:45 +00:00
|
|
|
foreach_instance +A +C \
|
|
|
|
wait_until --timeout=10 instance_offline +B
|
2013-05-10 02:35:28 +00:00
|
|
|
wait_until path_exists +A +H +G +F +E +D +C
|
|
|
|
wait_until path_exists +C +D +E +F +G +H +A
|
2013-04-30 07:05:45 +00:00
|
|
|
set_instance +A
|
2013-04-29 07:37:36 +00:00
|
|
|
executeOk_servald mdp ping --timeout=3 $SIDC 1
|
|
|
|
tfw_cat --stdout --stderr
|
|
|
|
executeOk_servald route print
|
2013-08-08 05:50:31 +00:00
|
|
|
assertStdoutGrep --matches=1 "^$SIDC:INDIRECT:"
|
2013-04-29 07:37:36 +00:00
|
|
|
}
|
|
|
|
|
2012-10-10 05:52:31 +00:00
|
|
|
setup_crowded_mess() {
|
|
|
|
setup_servald
|
|
|
|
assert_no_servald_processes
|
|
|
|
# BCDE & DEFG form squares, ABC & FGH form triangles
|
|
|
|
foreach_instance +A +B +C +D +E +F +G +H create_single_identity
|
2012-12-08 04:39:41 +00:00
|
|
|
foreach_instance +A +B +C add_interface 1
|
|
|
|
foreach_instance +B +D add_interface 2
|
|
|
|
foreach_instance +C +E add_interface 3
|
|
|
|
foreach_instance +D +E add_interface 4
|
|
|
|
foreach_instance +D +F add_interface 5
|
|
|
|
foreach_instance +E +G add_interface 6
|
|
|
|
foreach_instance +F +G +H add_interface 7
|
2012-10-10 05:52:31 +00:00
|
|
|
foreach_instance +A +B +C +D +E +F +G +H start_routing_instance
|
|
|
|
}
|
|
|
|
|
|
|
|
doc_crowded_mess="Multiple possible paths"
|
|
|
|
test_crowded_mess() {
|
2012-12-10 23:26:21 +00:00
|
|
|
foreach_instance +A +H \
|
|
|
|
wait_until has_seen_instances +A +H
|
2012-10-10 05:52:31 +00:00
|
|
|
set_instance +A
|
2012-12-10 23:26:21 +00:00
|
|
|
executeOk_servald route print
|
2013-08-08 05:50:31 +00:00
|
|
|
assertStdoutGrep --matches=1 "^$SIDH:INDIRECT:"
|
2013-08-09 06:49:45 +00:00
|
|
|
executeOk_servald mdp ping --timeout=3 $SIDH 1
|
|
|
|
tfw_cat --stdout --stderr
|
2012-10-10 05:52:31 +00:00
|
|
|
}
|
|
|
|
|
2012-10-09 04:19:24 +00:00
|
|
|
runTests "$@"
|