#!/bin/bash # Tests for Route discovery # # Copyright 2012 Serval Project, Inc. # # 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. source "${0%/*}/../testframework.sh" source "${0%/*}/../testdefs.sh" add_interface() { >$SERVALD_VAR/dummy$1 executeOk_servald config \ set interfaces.$1.file dummy$1 \ set interfaces.$1.dummy_address 127.0.$1.$instance_number \ set interfaces.$1.dummy_netmask 255.255.255.224 } interface_up() { grep "Interface .* is up" $instance_servald_log || return 1 return 0 } start_routing_instance() { executeOk_servald config \ set server.interface_path "$SERVALD_VAR" \ set monitor.socket "org.servalproject.servald.monitor.socket.$TFWUNIQUE.$instance_name" \ set mdp.socket "org.servalproject.servald.mdp.socket.$TFWUNIQUE.$instance_name" \ set log.show_pid on \ set log.show_time on \ set debug.mdprequests Yes \ set rhizome.enable no start_servald_server wait_until interface_up } log_routing_table() { executeOk_servald route print tfw_cat --stdout --stderr } teardown() { foreach_instance_with_pidfile log_routing_table stop_all_servald_servers kill_all_servald_processes assert_no_servald_processes report_all_servald_servers } doc_single_link="Start 2 instances on one link" setup_single_link() { setup_servald assert_no_servald_processes foreach_instance +A +B create_single_identity foreach_instance +A +B add_interface 1 foreach_instance +A +B start_routing_instance } test_single_link() { foreach_instance +A +B \ wait_until has_seen_instances +A +B set_instance +A executeOk_servald mdp ping $SIDB 1 tfw_cat --stdout --stderr executeOk_servald route print assertStdoutGrep --matches=1 "^$SIDB:BROADCAST UNICAST :" } 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() { foreach_instance +A +B \ wait_until has_seen_instances +A +B set_instance +A executeOk_servald mdp ping $SIDB 1 tfw_cat --stdout --stderr executeOk_servald route print assertStdoutGrep --matches=1 "^$SIDB:BROADCAST UNICAST :" } 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() { foreach_instance +A +B \ wait_until has_seen_instances +A +B set_instance +A executeOk_servald mdp ping $SIDB 1 tfw_cat --stdout --stderr executeOk_servald route print assertStdoutGrep --matches=1 "^$SIDB:BROADCAST UNICAST :" } doc_slip_encoding="Test slip encoding and decoding" setup_slip_encoding() { setup_servald assert_no_servald_processes } test_slip_encoding() { executeOk_servald test slip } doc_multiple_nodes="Multiple nodes on one link" setup_multiple_nodes() { setup_servald assert_no_servald_processes foreach_instance +A +B +C +D create_single_identity foreach_instance +A +B +C +D add_interface 1 foreach_instance +A +B +C +D start_routing_instance } test_multiple_nodes() { foreach +A +B +C +D \ wait_until has_seen_instances +A +B +C +D set_instance +A executeOk_servald mdp ping $SIDB 1 tfw_cat --stdout --stderr executeOk_servald mdp ping $SIDC 1 tfw_cat --stdout --stderr executeOk_servald mdp ping $SIDD 1 tfw_cat --stdout --stderr executeOk_servald route print assertStdoutGrep --matches=1 "^$SIDB:BROADCAST " assertStdoutGrep --matches=1 "^$SIDC:BROADCAST " assertStdoutGrep --matches=1 "^$SIDD:BROADCAST " } doc_scan="Simulate isolated clients" setup_scan() { 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 \ set interfaces.1.dummy_address 127.0.1.11 foreach_instance +A +B \ executeOk_servald config \ set interfaces.1.drop_broadcasts 1 foreach_instance +A +B start_routing_instance } test_scan() { set_instance +A executeOk_servald scan wait_until scan_completed wait_until has_seen_instances +B executeOk_servald mdp ping $SIDB 1 tfw_cat --stdout --stderr executeOk_servald route print assertStdoutGrep --matches=1 "^$SIDB:UNICAST :" } scan_completed() { grep "Scan completed" $LOG||return1 return 0 } doc_broadcast_only="Broadcast packets only" setup_broadcast_only() { 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.drop_unicasts 1 foreach_instance +A +B start_routing_instance } test_broadcast_only() { foreach_instance +A +B \ wait_until has_seen_instances +A +B set_instance +A executeOk_servald mdp ping $SIDB 1 tfw_cat --stdout --stderr executeOk_servald route print assertStdoutGrep --matches=1 "^$SIDB:BROADCAST :" } doc_prefer_unicast="Prefer unicast packets" 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() { foreach_instance +A +B \ wait_until has_seen_instances +A +B set_instance +A executeOk_servald mdp ping $SIDB 1 tfw_cat --stdout --stderr executeOk_servald route print assertStdoutGrep --matches=1 "^$SIDB:BROADCAST UNICAST :" assertGrep "$instance_servald_log" 'Choosing to send via unicast' } doc_multihop_linear="Start 4 instances in a linear arrangement" setup_multihop_linear() { 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 foreach_instance +A +B +C +D start_routing_instance } test_multihop_linear() { foreach_instance +A +B +C +D \ wait_until has_seen_instances +A +B +C +D set_instance +A executeOk_servald mdp ping $SIDD 1 tfw_cat --stdout --stderr executeOk_servald mdp trace $SIDD tfw_cat --stdout --stderr executeOk_servald route print assertStdoutGrep --matches=1 "^$SIDB:BROADCAST UNICAST :" assertStdoutGrep --matches=1 "^$SIDC:INDIRECT :" assertStdoutGrep --matches=1 "^$SIDD:INDIRECT :" } 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 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 foreach_instance +A +B +C +D +E +F +G +H start_routing_instance } doc_crowded_mess="Multiple possible paths" test_crowded_mess() { foreach_instance +A +H \ wait_until has_seen_instances +A +H set_instance +A executeOk_servald mdp ping $SIDH 1 tfw_cat --stdout --stderr executeOk_servald route print assertStdoutGrep --matches=1 "^$SIDH:INDIRECT :" } runTests "$@"