diff options
author | ISHIDA Wataru <ishida.wataru@lab.ntt.co.jp> | 2016-04-03 10:10:07 +0900 |
---|---|---|
committer | FUJITA Tomonori <fujita.tomonori@lab.ntt.co.jp> | 2016-04-05 22:15:19 +0900 |
commit | a5b81ba381af74d872fb9fea0a4581262241aaae (patch) | |
tree | d5b54c57728f51a697e11bf1fd320777209753d2 /test/scenario_test/monitor_test.py | |
parent | f94eb1fe9230f614a8fa8f5a40329cc43bdd173f (diff) |
server: add missing broadcastBests when dropping peer's routes
fix regression introduced by e6682c52ba3e09c4111bc94c938909cdcacd7d72
also add a test to check the behavior.
Signed-off-by: ISHIDA Wataru <ishida.wataru@lab.ntt.co.jp>
Diffstat (limited to 'test/scenario_test/monitor_test.py')
-rw-r--r-- | test/scenario_test/monitor_test.py | 112 |
1 files changed, 112 insertions, 0 deletions
diff --git a/test/scenario_test/monitor_test.py b/test/scenario_test/monitor_test.py new file mode 100644 index 00000000..8b4fabe5 --- /dev/null +++ b/test/scenario_test/monitor_test.py @@ -0,0 +1,112 @@ +# Copyright (C) 2016 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.quagga import * +import sys +import os +import time +import nose +from noseplugin import OptionParser, parser_option +from itertools import chain +import Queue + + +class GoBGPTestBase(unittest.TestCase): + + @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) + q1 = QuaggaBGPContainer(name='q1', asn=65001, router_id='192.168.0.2') + q2 = QuaggaBGPContainer(name='q2', asn=65002, router_id='192.168.0.3') + q3 = QuaggaBGPContainer(name='q3', asn=65003, router_id='192.168.0.4') + + qs = [q1, q2, q3] + ctns = [g1, q1, q2, q3] + + # advertise a route from q1, q2, q3 + for idx, q in enumerate(qs): + route = '10.0.{0}.0/24'.format(idx+1) + q.add_route(route) + + initial_wait_time = max(ctn.run() for ctn in ctns) + + time.sleep(initial_wait_time) + + for q in qs: + g1.add_peer(q, reload_config=False, passwd='passwd') + q.add_peer(g1, passwd='passwd', passive=True) + + g1.create_config() + g1.reload_config() + + cls.gobgp = g1 + cls.quaggas = {'q1': q1, 'q2': q2, 'q3': q3} + + def test_01_monitor_initial_adv(self): + qu = Queue.Queue() + self.gobgp.monitor_global_rib(qu) + for q in self.quaggas.itervalues(): + self.gobgp.wait_for(expected_state=BGP_FSM_ESTABLISHED, peer=q) + print '{0} get established'.format(q.name) + + cnt = 0 + + while True: + try: + info = qu.get(timeout=1) + if info == 'timeout': + raise Exception('timeout') + cnt += 1 + if cnt == len(self.quaggas): + break + except Queue.Empty: + pass + + def test_02_stop_q1(self): + qu = Queue.Queue() + self.gobgp.monitor_global_rib(qu) + self.quaggas['q1'].stop() + + while True: + try: + info = qu.get(timeout=1) + if info == 'timeout': + raise Exception('timeout') + self.assertTrue(info['isWithdraw']) + break + except Queue.Empty: + pass + + +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]) |