summaryrefslogtreecommitdiffhomepage
path: root/test
diff options
context:
space:
mode:
authorISHIDA Wataru <ishida.wataru@lab.ntt.co.jp>2016-05-21 15:00:41 +0000
committerFUJITA Tomonori <fujita.tomonori@lab.ntt.co.jp>2016-05-23 09:46:53 +0900
commita7521827e1d8c964f1c9f342dc39d02f45660c49 (patch)
treece40585522e52bc881c7640f95c25961948342f1 /test
parent31342564c9e7a78a183f11dd637e36c08e0f274b (diff)
server/table: fix intra-AS RTC route distribution
Signed-off-by: ISHIDA Wataru <ishida.wataru@lab.ntt.co.jp>
Diffstat (limited to 'test')
-rw-r--r--test/lib/base.py2
-rw-r--r--test/scenario_test/rtc_test.py144
2 files changed, 140 insertions, 6 deletions
diff --git a/test/lib/base.py b/test/lib/base.py
index d31ec14b..ffbf03b5 100644
--- a/test/lib/base.py
+++ b/test/lib/base.py
@@ -39,6 +39,8 @@ BGP_ATTR_TYPE_NEXT_HOP = 3
BGP_ATTR_TYPE_MULTI_EXIT_DISC = 4
BGP_ATTR_TYPE_LOCAL_PREF = 5
BGP_ATTR_TYPE_COMMUNITIES = 8
+BGP_ATTR_TYPE_ORIGINATOR_ID = 9
+BGP_ATTR_TYPE_CLUSTER_LIST = 10
BGP_ATTR_TYPE_MP_REACH_NLRI = 14
BGP_ATTR_TYPE_EXTENDED_COMMUNITIES = 16
diff --git a/test/scenario_test/rtc_test.py b/test/scenario_test/rtc_test.py
index f1f417c7..6f247213 100644
--- a/test/scenario_test/rtc_test.py
+++ b/test/scenario_test/rtc_test.py
@@ -39,9 +39,10 @@ class GoBGPTestBase(unittest.TestCase):
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)
- ctns = [g1, g2]
- initial_wait_time = max(ctn.run() for ctn in ctns)
+ ctns = {ctn.name: ctn for ctn in [g1, g2]}
+
+ initial_wait_time = max(ctn.run() for ctn in ctns.values())
time.sleep(initial_wait_time)
@@ -55,31 +56,162 @@ class GoBGPTestBase(unittest.TestCase):
g2.local("gobgp vrf vrf1 rib add 20.0.0.0/24")
g2.local("gobgp vrf vrf3 rib add 20.0.0.0/24")
- for a, b in combinations(ctns, 2):
+ for a, b in combinations(ctns.values(), 2):
a.add_peer(b, vpn=True, passwd='rtc', graceful_restart=True)
b.add_peer(a, vpn=True, passwd='rtc', graceful_restart=True)
cls.g1 = g1
cls.g2 = g2
+ cls.ctns = ctns
# 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)
def test_02_check_gobgp_adj_rib_out(self):
- time.sleep(10)
+ time.sleep(2)
self.assertTrue(len(self.g1.get_adj_rib_out(self.g2, rf='ipv4-l3vpn')) == 1)
self.assertTrue(len(self.g2.get_adj_rib_out(self.g1, rf='ipv4-l3vpn')) == 1)
def test_03_add_vrf(self):
self.g1.local("gobgp vrf add vrf3 rd 300:300 rt both 300:300")
- time.sleep(10)
+ time.sleep(2)
+ self.assertTrue(len(self.g1.get_adj_rib_out(self.g2, rf='rtc')) == 3)
self.assertTrue(len(self.g1.get_adj_rib_in(self.g2, rf='ipv4-l3vpn')) == 2)
def test_04_del_vrf(self):
self.g1.local("gobgp vrf del vrf1")
- time.sleep(10)
+ time.sleep(2)
self.assertTrue(len(self.g1.get_adj_rib_in(self.g2, rf='ipv4-l3vpn')) == 1)
+ self.assertTrue(len(self.g1.get_adj_rib_out(self.g2, rf='rtc')) == 2)
+
+ def test_05_rr_setup(self):
+ gobgp_ctn_image_name = parser_option.gobgp_image
+ g3 = GoBGPContainer(name='g3', asn=65000, router_id='192.168.0.3',
+ ctn_image_name=gobgp_ctn_image_name,
+ log_level=parser_option.gobgp_log_level)
+ g4 = GoBGPContainer(name='g4', asn=65000, router_id='192.168.0.4',
+ ctn_image_name=gobgp_ctn_image_name,
+ log_level=parser_option.gobgp_log_level)
+ g5 = GoBGPContainer(name='g5', asn=65000, router_id='192.168.0.5',
+ ctn_image_name=gobgp_ctn_image_name,
+ log_level=parser_option.gobgp_log_level)
+
+ time.sleep(max(ctn.run() for ctn in [g3, g4, g5]))
+
+ g3.add_peer(g4, vpn=True, is_rr_client=True)
+ g4.add_peer(g3, vpn=True)
+
+ g3.add_peer(g5, vpn=True, is_rr_client=True)
+ g5.add_peer(g3, vpn=True)
+
+ for v in [g3, g4, g5]:
+ self.ctns[v.name] = v
+
+ def test_06_neighbor_established(self):
+ g3 = self.ctns['g3']
+ g4 = self.ctns['g4']
+ g5 = self.ctns['g5']
+ g3.wait_for(expected_state=BGP_FSM_ESTABLISHED, peer=g4)
+ g3.wait_for(expected_state=BGP_FSM_ESTABLISHED, peer=g5)
+
+ def test_07_rr_test(self):
+ g3 = self.ctns['g3']
+ g4 = self.ctns['g4']
+ g5 = self.ctns['g5']
+ g4.local("gobgp vrf add vrf1 rd 100:100 rt both 100:100")
+ time.sleep(1)
+ g5.local("gobgp vrf add vrf1 rd 100:100 rt both 100:100")
+
+ time.sleep(1)
+ def check(client):
+ rib = g3.get_adj_rib_out(client, rf='rtc')
+ self.assertTrue(len(rib) == 1)
+ path = rib[0]
+ self.assertTrue(path['nexthop'] == g3.peers[client]['local_addr'].split('/')[0])
+ ids = [attr['value'] for attr in path['attrs'] if attr['type'] == base.BGP_ATTR_TYPE_ORIGINATOR_ID]
+ self.assertTrue(len(ids) == 1)
+ self.assertTrue(ids[0] == g3.router_id)
+ check(g4)
+ check(g5)
+
+ g4.local("gobgp vrf vrf1 rib add 40.0.0.0/24")
+ g5.local("gobgp vrf vrf1 rib add 50.0.0.0/24")
+ time.sleep(1)
+ def check(client):
+ rib = g3.get_adj_rib_out(client, rf='ipv4-l3vpn')
+ self.assertTrue(len(rib) == 1)
+ path = rib[0]
+ self.assertTrue(path['nexthop'] != g3.peers[client]['local_addr'].split('/')[0])
+ ids = [attr['value'] for attr in path['attrs'] if attr['type'] == base.BGP_ATTR_TYPE_ORIGINATOR_ID]
+ self.assertTrue(len(ids) == 1)
+ self.assertTrue(ids[0] != client.router_id)
+ check(g4)
+ check(g5)
+
+ def test_08_rr_setup2(self):
+ g1 = self.ctns['g1']
+ g2 = self.ctns['g2']
+ g3 = self.ctns['g3']
+
+ g1.local("gobgp vrf del vrf2")
+ g1.local("gobgp vrf del vrf3")
+ g2.local("gobgp vrf del vrf1")
+ g2.local("gobgp vrf del vrf3")
+
+ g3.add_peer(g1, vpn=True)
+ g1.add_peer(g3, vpn=True)
+ g3.add_peer(g2, vpn=True)
+ g2.add_peer(g3, vpn=True)
+
+ g3.wait_for(expected_state=BGP_FSM_ESTABLISHED, peer=g1)
+ g3.wait_for(expected_state=BGP_FSM_ESTABLISHED, peer=g2)
+
+ def test_09_rr_test2(self):
+ g1 = self.ctns['g1']
+ g2 = self.ctns['g2']
+ g3 = self.ctns['g3']
+ g4 = self.ctns['g4']
+ g5 = self.ctns['g5']
+
+ self.assertTrue(len(g1.get_adj_rib_in(g3, rf='ipv4-l3vpn')) == 0)
+ self.assertTrue(len(g2.get_adj_rib_in(g3, rf='ipv4-l3vpn')) == 0)
+
+ g1.local("gobgp vrf add vrf1 rd 100:100 rt both 100:100")
+ g1.local("gobgp vrf vrf1 rib add 10.0.0.0/24")
+
+ time.sleep(1)
+
+ self.assertTrue(len(g1.get_adj_rib_in(g3, rf='ipv4-l3vpn')) == 2)
+ self.assertTrue(len(g2.get_adj_rib_in(g3, rf='ipv4-l3vpn')) == 0)
+ self.assertTrue(len(g3.get_adj_rib_in(g1, rf='ipv4-l3vpn')) == 1)
+ self.assertTrue(len(g3.get_adj_rib_in(g2, rf='ipv4-l3vpn')) == 0)
+ self.assertTrue(len(g4.get_adj_rib_in(g3, rf='ipv4-l3vpn')) == 2)
+ self.assertTrue(len(g5.get_adj_rib_in(g3, rf='ipv4-l3vpn')) == 2)
+
+ g2.local("gobgp vrf add vrf2 rd 200:200 rt both 200:200")
+ g2.local("gobgp vrf vrf2 rib add 20.0.0.0/24")
+
+ time.sleep(1)
+
+ self.assertTrue(len(g1.get_adj_rib_in(g3, rf='ipv4-l3vpn')) == 2)
+ self.assertTrue(len(g2.get_adj_rib_in(g3, rf='ipv4-l3vpn')) == 0)
+ self.assertTrue(len(g3.get_adj_rib_in(g1, rf='ipv4-l3vpn')) == 1)
+ self.assertTrue(len(g3.get_adj_rib_in(g2, rf='ipv4-l3vpn')) == 0)
+ self.assertTrue(len(g4.get_adj_rib_in(g3, rf='ipv4-l3vpn')) == 2)
+ self.assertTrue(len(g5.get_adj_rib_in(g3, rf='ipv4-l3vpn')) == 2)
+
+ g4.local("gobgp vrf add vrf2 rd 200:200 rt both 200:200")
+
+ time.sleep(1)
+
+ self.assertTrue(len(g1.get_adj_rib_in(g3, rf='ipv4-l3vpn')) == 2)
+ self.assertTrue(len(g2.get_adj_rib_in(g3, rf='ipv4-l3vpn')) == 0)
+ self.assertTrue(len(g3.get_adj_rib_in(g1, rf='ipv4-l3vpn')) == 1)
+ self.assertTrue(len(g3.get_adj_rib_in(g2, rf='ipv4-l3vpn')) == 1)
+ self.assertTrue(len(g4.get_adj_rib_in(g3, rf='ipv4-l3vpn')) == 3)
+ self.assertTrue(len(g5.get_adj_rib_in(g3, rf='ipv4-l3vpn')) == 2)
+
if __name__ == '__main__':
if os.geteuid() is not 0: