diff options
author | ISHIDA Wataru <ishida.wataru@lab.ntt.co.jp> | 2016-01-09 15:42:08 +0900 |
---|---|---|
committer | ISHIDA Wataru <ishida.wataru@lab.ntt.co.jp> | 2016-01-09 15:56:39 +0900 |
commit | 78dd33b5a58db3d213e9ef9bf244d20bb063947b (patch) | |
tree | 6e10ceb07473ab91096443134badb28d5d3f2c34 /test/scenario_test | |
parent | f42b8fbae6d8eb381967e82867a1b67188bdcbc5 (diff) |
test: add test to check as2 peer handling
Signed-off-by: ISHIDA Wataru <ishida.wataru@lab.ntt.co.jp>
Diffstat (limited to 'test/scenario_test')
-rw-r--r-- | test/scenario_test/route_server_as2_test.py | 115 | ||||
-rwxr-xr-x | test/scenario_test/run_all_tests.sh | 4 |
2 files changed, 119 insertions, 0 deletions
diff --git a/test/scenario_test/route_server_as2_test.py b/test/scenario_test/route_server_as2_test.py new file mode 100644 index 00000000..4049d634 --- /dev/null +++ b/test/scenario_test/route_server_as2_test.py @@ -0,0 +1,115 @@ +# Copyright (C) 2015 Nippon Telegraph and Telephone Corporation. +# +# Licensed under the Apache License, Version 2.0 (the "License"); +# you may not use this file except in compliance with the License. +# You may obtain a copy of the License at +# +# http://www.apache.org/licenses/LICENSE-2.0 +# +# Unless required by applicable law or agreed to in writing, software +# distributed under the License is distributed on an "AS IS" BASIS, +# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or +# implied. +# See the License for the specific language governing permissions and +# limitations under the License. + +import unittest +from fabric.api import local +from lib import base +from lib.gobgp import * +from lib.exabgp import * +import sys +import os +import time +import nose +from noseplugin import OptionParser, parser_option + + +class GoBGPTestBase(unittest.TestCase): + + wait_per_retry = 5 + retry_limit = 10 + + @classmethod + def setUpClass(cls): + gobgp_ctn_image_name = parser_option.gobgp_image + base.TEST_PREFIX = parser_option.test_prefix + + g1 = GoBGPContainer(name='g1', asn=65000, router_id='192.168.0.1', + ctn_image_name=gobgp_ctn_image_name, + log_level=parser_option.gobgp_log_level) + + rs_clients = [ExaBGPContainer(name='q{0}'.format(i+1), asn=65001+i, + router_id='192.168.0.{0}'.format(i+2)) + for i in range(4)] + ctns = [g1] + rs_clients + q1 = rs_clients[0] + q2 = rs_clients[1] + q3 = rs_clients[2] + q4 = rs_clients[3] + + # advertise a route from route-server-clients + for idx, rs_client in enumerate(rs_clients): + route = '10.0.{0}.0/24'.format(idx+1) + rs_client.add_route(route) + if idx < 2: + route = '10.0.10.0/24' + rs_client.add_route(route) + + initial_wait_time = max(ctn.run() for ctn in ctns) + + time.sleep(initial_wait_time) + + for i, rs_client in enumerate(rs_clients): + g1.add_peer(rs_client, is_rs_client=True) + as2 = False + if i > 1: + as2 = True + rs_client.add_peer(g1, as2=as2) + + cls.gobgp = g1 + cls.quaggas = { x.name: x for x in rs_clients } + + + # test each neighbor state is turned establish + def test_01_neighbor_established(self): + for q in self.quaggas.itervalues(): + self.gobgp.wait_for(expected_state=BGP_FSM_ESTABLISHED, peer=q) + + def test_02_check_gobgp_local_rib(self): + for rs_client in self.quaggas.itervalues(): + done = False + for _ in range(self.retry_limit): + if done: + break + local_rib = self.gobgp.get_local_rib(rs_client) + local_rib = [p['prefix'] for p in local_rib] + if len(local_rib) < len(self.quaggas)-1: + time.sleep(self.wait_per_retry) + continue + + self.assertTrue(len(local_rib) == 4) + done = True + + if done: + continue + # should not reach here + self.assertTrue(False) + + def test_03_stop_q2_and_check_neighbor_status(self): + q2 = self.quaggas['q2'] + q2.remove() + self.gobgp.wait_for(expected_state=BGP_FSM_IDLE, peer=q2) + + +if __name__ == '__main__': + if os.geteuid() is not 0: + print "you are not root." + sys.exit(1) + output = local("which docker 2>&1 > /dev/null ; echo $?", capture=True) + if int(output) is not 0: + print "docker not found" + sys.exit(1) + + nose.main(argv=sys.argv, addplugins=[OptionParser()], + defaultTest=sys.argv[0]) diff --git a/test/scenario_test/run_all_tests.sh b/test/scenario_test/run_all_tests.sh index 4a6e7aff..b9d196dd 100755 --- a/test/scenario_test/run_all_tests.sh +++ b/test/scenario_test/run_all_tests.sh @@ -67,6 +67,10 @@ PIDS=("${PIDS[@]}" $!) sudo -E PYTHONPATH=$GOBGP/test python global_policy_test.py --gobgp-image $GOBGP_IMAGE --test-prefix gpol -s -x --with-xunit --xunit-file=${WS}/nosetest_global_policy.xml & PIDS=("${PIDS[@]}" $!) +# route server as2 test +sudo -E PYTHONPATH=$GOBGP/test python route_server_as2_test.py --gobgp-image $GOBGP_IMAGE --test-prefix as2 -s -x --with-xunit --xunit-file=${WS}/nosetest_rs_as2.xml & +PIDS=("${PIDS[@]}" $!) + # route server malformed message test NUM=$(sudo -E PYTHONPATH=$GOBGP/test python route_server_malformed_test.py --test-index -1 -s 2> /dev/null | awk '/invalid/{print $NF}') PARALLEL_NUM=10 |