diff options
author | Hiroshi Yokoi <yokoi.hiroshi@po.ntts.co.jp> | 2015-04-10 20:11:32 +0900 |
---|---|---|
committer | FUJITA Tomonori <fujita.tomonori@lab.ntt.co.jp> | 2015-04-14 08:10:28 +0900 |
commit | a1114dc7bb6dcb165c6494799be94b5d10fe5b17 (patch) | |
tree | e32c0500e153f8693c387905c8fb5f0c64c96fe3 /test/scenario_test | |
parent | 9ce5445ce939db263740220d90bb6429872d71de (diff) |
scenario_test: route_server_ipv4_v6_test retry checking rib
Diffstat (limited to 'test/scenario_test')
-rw-r--r-- | test/scenario_test/route_server_ipv4_v6_test.py | 129 |
1 files changed, 85 insertions, 44 deletions
diff --git a/test/scenario_test/route_server_ipv4_v6_test.py b/test/scenario_test/route_server_ipv4_v6_test.py index 4233988f..bf47c516 100644 --- a/test/scenario_test/route_server_ipv4_v6_test.py +++ b/test/scenario_test/route_server_ipv4_v6_test.py @@ -70,24 +70,45 @@ class GoBGPIPv6Test(GoBGPTestBase): for address in self.get_neighbor_address(self.gobgp_config): print "check of [ " + address + " ]" af = fab.IPv6 if ":" in address else fab.IPv4 - local_rib = self.ask_gobgp(LOCAL_RIB, address, af) - - for quagga_config in self.quagga_configs: - if quagga_config.peer_ip == address or quagga_config.ip_version != af: - for c_dest in quagga_config.destinations.itervalues(): - # print "config : ", c_dest.prefix, "my ip or different ip version!!!" - exist_n = 0 - for g_dest in local_rib: - if c_dest.prefix == g_dest['prefix']: - exist_n += 1 - self.assertEqual(exist_n, 0) + + def check_func(): + local_rib = self.ask_gobgp(LOCAL_RIB, address, af) + + for quagga_config in self.quagga_configs: + if quagga_config.peer_ip == address or quagga_config.ip_version != af: + for c_dest in quagga_config.destinations.itervalues(): + # print "config : ", c_dest.prefix, "my ip or different ip version!!!" + exist_n = 0 + for g_dest in local_rib: + if c_dest.prefix == g_dest['prefix']: + exist_n += 1 + if exist_n != 0: + return False + else: + for c_dest in quagga_config.destinations.itervalues(): + exist_n = 0 + for g_dest in local_rib: + if c_dest.prefix == g_dest['prefix']: + exist_n += 1 + if exist_n != 1: + return False + return True + + retry_count = 0 + cmp_result = False + while retry_count < self.dest_check_limit: + + cmp_result = check_func() + + if cmp_result: + print "compare OK" + break else: - for c_dest in quagga_config.destinations.itervalues(): - exist_n = 0 - for g_dest in local_rib: - if c_dest.prefix == g_dest['prefix']: - exist_n += 1 - self.assertEqual(exist_n, 1) + retry_count += 1 + print "compare NG -> retry ( %d / %d )" % (retry_count, self.dest_check_limit) + time.sleep(self.wait_per_retry) + + self.assertEqual(cmp_result, True) def test_03_advertising_route(self): print "test_advertising_route" @@ -97,35 +118,55 @@ class GoBGPIPv6Test(GoBGPTestBase): for address in self.get_neighbor_address(self.gobgp_config): print "check of [ " + address + " ]" af = fab.IPv6 if ":" in address else fab.IPv4 - tn = qaccess.login(address) - q_rib = qaccess.show_rib(tn, af) - - for quagga_config in self.quagga_configs: - if quagga_config.peer_ip == address or quagga_config.ip_version != af: - for c_dest in quagga_config.destinations.itervalues(): - exist_n = 0 - for c_path in c_dest.paths: - # print "conf : ", c_path.network, c_path.nexthop, "my ip or different ip version!!!" - for q_path in q_rib: - # print "quag : ", q_path['Network'], q_path['Next Hop'] - if "0.0.0.0" == q_path['Next Hop'] or "::" == q_path['Next Hop']: - continue - if c_path.network.split("/")[0] == q_path['Network']: - exist_n += 1 - self.assertEqual(exist_n, 0) + def check_func(): + tn = qaccess.login(address) + q_rib = qaccess.show_rib(tn, af) + + for quagga_config in self.quagga_configs: + if quagga_config.peer_ip == address or quagga_config.ip_version != af: + for c_dest in quagga_config.destinations.itervalues(): + exist_n = 0 + for c_path in c_dest.paths: + # print "conf : ", c_path.network, c_path.nexthop, "my ip or different ip version!!!" + for q_path in q_rib: + # print "quag : ", q_path['Network'], q_path['Next Hop'] + if "0.0.0.0" == q_path['Next Hop'] or "::" == q_path['Next Hop']: + continue + if c_path.network.split("/")[0] == q_path['Network']: + exist_n += 1 + if exist_n != 0: + return False + else: + for c_dest in quagga_config.destinations.itervalues(): + exist_n = 0 + for c_path in c_dest.paths: + # print "conf : ", c_path.network, c_path.nexthop + for q_path in q_rib: + # print "quag : ", q_path['Network'], q_path['Next Hop'] + if quagga_config.ip_version != fab.IPv6: + c_path.network = c_path.network.split("/")[0] + if c_path.network == q_path['Network'] and c_path.nexthop == q_path['Next Hop']: + exist_n += 1 + if exist_n != 1: + return False + return True + + retry_count = 0 + check_result = False + while retry_count < self.dest_check_limit: + + check_result = check_func() + + if check_result: + print "compare OK" + break else: - for c_dest in quagga_config.destinations.itervalues(): - exist_n = 0 - for c_path in c_dest.paths: - # print "conf : ", c_path.network, c_path.nexthop - for q_path in q_rib: - # print "quag : ", q_path['Network'], q_path['Next Hop'] - if quagga_config.ip_version != fab.IPv6: - c_path.network = c_path.network.split("/")[0] - if c_path.network == q_path['Network'] and c_path.nexthop == q_path['Next Hop']: - exist_n += 1 - self.assertEqual(exist_n, 1) + retry_count += 1 + print "compare NG -> retry ( %d / %d )" % (retry_count, self.dest_check_limit) + time.sleep(self.wait_per_retry) + + self.assertEqual(check_result, True) if __name__ == '__main__': if fab.test_user_check() is False: |