diff options
author | IWASE Yusuke <iwase.yusuke0@gmail.com> | 2017-07-20 13:50:48 +0900 |
---|---|---|
committer | IWASE Yusuke <iwase.yusuke0@gmail.com> | 2017-07-20 14:49:51 +0900 |
commit | 11faf518286152684ed6dcf3485d92c148b28bc7 (patch) | |
tree | 6c5bc179625f7ebccb08157f82d8eee4b199a9f1 /test | |
parent | 51a84fe36c69f72a48247ec61b137e545245452e (diff) |
addpath_test: Test cases with non add-path router
This patch adds the test cases for the mixed situation of add-path
enabled routers and non add-path enabled routers and advertising and
withdrawing routes in such situation.
Signed-off-by: IWASE Yusuke <iwase.yusuke0@gmail.com>
Diffstat (limited to 'test')
-rw-r--r-- | test/scenario_test/addpath_test.py | 39 |
1 files changed, 35 insertions, 4 deletions
diff --git a/test/scenario_test/addpath_test.py b/test/scenario_test/addpath_test.py index c2d2c5bf..2789c3b2 100644 --- a/test/scenario_test/addpath_test.py +++ b/test/scenario_test/addpath_test.py @@ -37,9 +37,12 @@ class GoBGPTestBase(unittest.TestCase): 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) - e1 = ExaBGPContainer(name='e1', asn=65000, router_id='192.168.0.2') + g2 = GoBGPContainer(name='g2', asn=65000, router_id='192.168.0.2', + ctn_image_name=gobgp_ctn_image_name, + log_level=parser_option.gobgp_log_level) + e1 = ExaBGPContainer(name='e1', asn=65000, router_id='192.168.0.3') - ctns = [g1, e1] + ctns = [g1, g2, e1] e1.add_route(route='192.168.100.0/24', identifier=10, aspath=[100, 200, 300]) e1.add_route(route='192.168.100.0/24', identifier=20, aspath=[100, 200]) @@ -51,18 +54,46 @@ class GoBGPTestBase(unittest.TestCase): g1.add_peer(e1, addpath=True) e1.add_peer(g1, addpath=True) + + g1.add_peer(g2, addpath=False, is_rr_client=True) + g2.add_peer(g1, addpath=False) + cls.g1 = g1 + cls.g2 = g2 cls.e1 = e1 # test each neighbor state is turned establish def test_01_neighbor_established(self): + self.g1.wait_for(expected_state=BGP_FSM_ESTABLISHED, peer=self.g2) self.g1.wait_for(expected_state=BGP_FSM_ESTABLISHED, peer=self.e1) # test three routes are installed to the rib due to add-path feature def test_02_check_g1_global_rib(self): rib = self.g1.get_global_rib() - self.assertTrue(len(rib) == 1) - self.assertTrue(len(rib[0]['paths']) == 3) + self.assertEqual(len(rib), 1) + self.assertEqual(len(rib[0]['paths']), 3) + + # test only the best path is advertised to g2 + def test_03_check_g2_global_rib(self): + rib = self.g2.get_global_rib() + self.assertEqual(len(rib), 1) + self.assertEqual(len(rib[0]['paths']), 1) + self.assertEqual(rib[0]['paths'][0]["aspath"], [100]) + + # test a withdraw route with path_id is removed from the rib + def test_04_withdraw_route_with_path_id(self): + self.e1.del_route(route='192.168.100.0/24', identifier=30) + + rib = self.g1.get_global_rib() + self.assertEqual(len(rib), 1) + self.assertEqual(len(rib[0]['paths']), 2) + + # test the best path is replaced due to the removal from g1 rib + def test_05_check_g2_global_rib(self): + rib = self.g2.get_global_rib() + self.assertEqual(len(rib), 1) + self.assertEqual(len(rib[0]['paths']), 1) + self.assertEqual(rib[0]['paths'][0]["aspath"], [100, 200]) if __name__ == '__main__': |