diff options
Diffstat (limited to 'test')
-rw-r--r-- | test/lib/base.py | 4 | ||||
-rw-r--r-- | test/lib/gobgp.py | 8 | ||||
-rw-r--r-- | test/scenario_test/evpn_test.py | 6 | ||||
-rw-r--r-- | test/scenario_test/rtc_test.py | 94 |
4 files changed, 105 insertions, 7 deletions
diff --git a/test/lib/base.py b/test/lib/base.py index d5dfc221..41807cbf 100644 --- a/test/lib/base.py +++ b/test/lib/base.py @@ -250,7 +250,7 @@ class BGPContainer(Container): super(BGPContainer, self).run() return self.WAIT_FOR_BOOT - def add_peer(self, peer, passwd=None, evpn=False, is_rs_client=False, + def add_peer(self, peer, passwd=None, vpn=False, is_rs_client=False, policies=None, passive=False, is_rr_client=False, cluster_id=None, flowspec=False, bridge='', reload_config=True, as2=False, @@ -273,7 +273,7 @@ class BGPContainer(Container): self.peers[peer] = {'neigh_addr': neigh_addr, 'passwd': passwd, - 'evpn': evpn, + 'vpn': vpn, 'flowspec': flowspec, 'is_rs_client': is_rs_client, 'is_rr_client': is_rr_client, diff --git a/test/lib/gobgp.py b/test/lib/gobgp.py index 36b4b86e..0b352fa5 100644 --- a/test/lib/gobgp.py +++ b/test/lib/gobgp.py @@ -212,10 +212,12 @@ class GoBGPContainer(BGPContainer): else: Exception('invalid ip address version. {0}'.format(version)) - if info['evpn']: + if info['vpn']: + afi_safi_list.append({'afi-safi-name': 'l3vpn-ipv4-unicast'}) + afi_safi_list.append({'afi-safi-name': 'l3vpn-ipv6-unicast'}) afi_safi_list.append({'afi-safi-name': 'l2vpn-evpn'}) - afi_safi_list.append({'afi-safi-name': 'encap'}) - afi_safi_list.append({'afi-safi-name': 'rtc'}) + afi_safi_list.append({'afi-safi-name': 'rtc', + 'route-target-membership': {'deferral-time': 10}}) if info['flowspec']: afi_safi_list.append({'afi-safi-name': 'ipv4-flowspec'}) diff --git a/test/scenario_test/evpn_test.py b/test/scenario_test/evpn_test.py index 7920bf2b..01827805 100644 --- a/test/scenario_test/evpn_test.py +++ b/test/scenario_test/evpn_test.py @@ -56,10 +56,12 @@ class GoBGPTestBase(unittest.TestCase): initial_wait_time = max(ctn.run() for ctn in ctns) time.sleep(initial_wait_time) + g1.local("gobgp vrf add vrf1 rd 10:10 rt both 10:10") + g2.local("gobgp vrf add vrf1 rd 10:10 rt both 10:10") for a, b in combinations(ctns, 2): - a.add_peer(b, evpn=True, passwd='evpn') - b.add_peer(a, evpn=True, passwd='evpn') + a.add_peer(b, vpn=True, passwd='evpn') + b.add_peer(a, vpn=True, passwd='evpn') cls.g1 = g1 cls.g2 = g2 diff --git a/test/scenario_test/rtc_test.py b/test/scenario_test/rtc_test.py new file mode 100644 index 00000000..f1f417c7 --- /dev/null +++ b/test/scenario_test/rtc_test.py @@ -0,0 +1,94 @@ +# 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 combinations + + +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) + 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) + + time.sleep(initial_wait_time) + + g1.local("gobgp vrf add vrf1 rd 100:100 rt both 100:100") + g1.local("gobgp vrf add vrf2 rd 200:200 rt both 200:200") + g2.local("gobgp vrf add vrf1 rd 100:100 rt both 100:100") + g2.local("gobgp vrf add vrf3 rd 300:300 rt both 300:300") + + g1.local("gobgp vrf vrf1 rib add 10.0.0.0/24") + g1.local("gobgp vrf vrf2 rib add 10.0.0.0/24") + 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): + 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 + + # 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) + 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) + 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) + self.assertTrue(len(self.g1.get_adj_rib_in(self.g2, rf='ipv4-l3vpn')) == 1) + +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]) |