diff options
Diffstat (limited to 'test/lib/gobgp.py')
-rw-r--r-- | test/lib/gobgp.py | 42 |
1 files changed, 22 insertions, 20 deletions
diff --git a/test/lib/gobgp.py b/test/lib/gobgp.py index 84e30198..14fbfe1f 100644 --- a/test/lib/gobgp.py +++ b/test/lib/gobgp.py @@ -152,9 +152,7 @@ class GoBGPContainer(BGPContainer): return None def _trigger_peer_cmd(self, cmd, peer): - if peer not in self.peers: - raise Exception('not found peer {0}'.format(peer.router_id)) - peer_addr = self.peers[peer]['neigh_addr'].split('/')[0] + peer_addr = self.peer_name(peer) cmd = 'gobgp neighbor {0} {1}'.format(peer_addr, cmd) self.local(cmd) @@ -171,9 +169,7 @@ class GoBGPContainer(BGPContainer): self._trigger_peer_cmd('softreset{0} -a {1}'.format(type, rf), peer) def get_local_rib(self, peer, prefix='', rf='ipv4'): - if peer not in self.peers: - raise Exception('not found peer {0}'.format(peer.router_id)) - peer_addr = self.peers[peer]['neigh_addr'].split('/')[0] + peer_addr = self.peer_name(peer) cmd = 'gobgp -j neighbor {0} local {1} -a {2}'.format(peer_addr, prefix, rf) output = self.local(cmd, capture=True) ret = json.loads(output) @@ -226,9 +222,7 @@ class GoBGPContainer(BGPContainer): t.start() def _get_adj_rib(self, adj_type, peer, prefix='', rf='ipv4'): - if peer not in self.peers: - raise Exception('not found peer {0}'.format(peer.router_id)) - peer_addr = self.peers[peer]['neigh_addr'].split('/')[0] + peer_addr = self.peer_name(peer) cmd = 'gobgp neighbor {0} adj-{1} {2} -a {3} -j'.format(peer_addr, adj_type, prefix, rf) @@ -249,10 +243,7 @@ class GoBGPContainer(BGPContainer): return self._get_adj_rib('out', peer, prefix, rf) def get_neighbor(self, peer): - if peer not in self.peers: - raise Exception('not found peer {0}'.format(peer.router_id)) - peer_addr = self.peers[peer]['neigh_addr'].split('/')[0] - cmd = 'gobgp -j neighbor {0}'.format(peer_addr) + cmd = 'gobgp -j neighbor {0}'.format(self.peer_name(peer)) return json.loads(self.local(cmd, capture=True)) def get_neighbor_state(self, peer): @@ -317,13 +308,17 @@ class GoBGPContainer(BGPContainer): for peer, info in self.peers.iteritems(): afi_safi_list = [] - version = netaddr.IPNetwork(info['neigh_addr']).version - if version == 4: - afi_safi_list.append({'config': {'afi-safi-name': 'ipv4-unicast'}}) - elif version == 6: - afi_safi_list.append({'config': {'afi-safi-name': 'ipv6-unicast'}}) + if info['interface'] != '': + afi_safi_list.append({'config':{'afi-safi-name': 'ipv4-unicast'}}) + afi_safi_list.append({'config':{'afi-safi-name': 'ipv6-unicast'}}) else: - Exception('invalid ip address version. {0}'.format(version)) + version = netaddr.IPNetwork(info['neigh_addr']).version + if version == 4: + afi_safi_list.append({'config':{'afi-safi-name': 'ipv4-unicast'}}) + elif version == 6: + afi_safi_list.append({'config':{'afi-safi-name': 'ipv6-unicast'}}) + else: + Exception('invalid ip address version. {0}'.format(version)) if info['vpn']: afi_safi_list.append({'config': {'afi-safi-name': 'l3vpn-ipv4-unicast'}}) @@ -337,9 +332,16 @@ class GoBGPContainer(BGPContainer): afi_safi_list.append({'config': {'afi-safi-name': 'ipv6-flowspec'}}) afi_safi_list.append({'config': {'afi-safi-name': 'l3vpn-ipv6-flowspec'}}) + neigh_addr = None + interface = None + if info['interface'] == '': + neigh_addr = info['neigh_addr'].split('/')[0] + else: + interface = info['interface'] n = { 'config': { - 'neighbor-address': info['neigh_addr'].split('/')[0], + 'neighbor-address': neigh_addr, + 'neighbor-interface': interface, 'peer-as': peer.asn, 'auth-password': info['passwd'], 'vrf': info['vrf'], |