blob: b3ca2cc61540bbad688c788be99a46a0e19aa3a3 [file] [log] [blame]
Chetan Gaonker3533faa2016-04-25 17:50:14 -07001import unittest
2from nose.tools import *
3from scapy.all import *
4from OnosCtrl import OnosCtrl
5from OltConfig import OltConfig
6from OnosFlowCtrl import OnosFlowCtrl, get_mac
7from onosclidriver import OnosCliDriver
Chetan Gaonker6cf6e472016-04-26 14:41:51 -07008from CordContainer import Container, Onos, Quagga
9from CordTestServer import cord_test_onos_restart, cord_test_quagga_restart
Chetan Gaonker3533faa2016-04-25 17:50:14 -070010from portmaps import g_subscriber_port_map
11import threading
12import time
13import os
14import json
15log.setLevel('INFO')
16
Chetan Gaonkerb6064fa2016-05-02 16:29:57 -070017class QuaggaStopWrapper(Container):
18
19 def __init__(self, name = 'cord-quagga', image = 'cord-test/quagga', tag = 'latest'):
20 super(QuaggaStopWrapper, self).__init__(name, image, tag = tag)
21 if self.exists():
22 self.kill()
23
Chetan Gaonker3533faa2016-04-25 17:50:14 -070024class vrouter_exchange(unittest.TestCase):
25
26 apps = ('org.onosproject.vrouter', 'org.onosproject.fwd')
27 device_id = 'of:' + get_mac('ovsbr0')
28 vrouter_device_dict = { "devices" : {
29 "{}".format(device_id) : {
30 "basic" : {
31 "driver" : "softrouter"
32 }
33 }
34 },
35 }
36 zebra_conf = '''
37password zebra
38log stdout
39service advanced-vty
40!
Chetan Gaonkerfd3d6502016-05-03 13:23:07 -070041!debug zebra rib
42!debug zebra kernel
43!debug zebra fpm
Chetan Gaonker3533faa2016-04-25 17:50:14 -070044!
45!interface eth1
46! ip address 10.10.0.3/16
47line vty
48 exec-timeout 0 0
49'''
50 test_path = os.path.dirname(os.path.realpath(__file__))
51 quagga_config_path = os.path.join(test_path, '..', 'setup/quagga-config')
52 onos_config_path = os.path.join(test_path, '..', 'setup/onos-config')
Chetan Gaonker8e25e1b2016-05-02 13:42:21 -070053 GATEWAY = '192.168.10.50'
Chetan Gaonkerfe551a22016-04-29 17:34:57 -070054 INGRESS_PORT = 1
55 EGRESS_PORT = 2
Chetan Gaonker3533faa2016-04-25 17:50:14 -070056 MAX_PORTS = 100
Chetan Gaonker8e25e1b2016-05-02 13:42:21 -070057 peer_list = [ ('192.168.10.1', '00:00:00:00:00:01'), ('192.168.11.1', '00:00:00:00:02:01'), ]
Chetan Gaonkerfe551a22016-04-29 17:34:57 -070058 network_list = []
Chetan Gaonker3533faa2016-04-25 17:50:14 -070059
60 @classmethod
61 def setUpClass(cls):
62 ''' Activate the vrouter apps'''
63 cls.olt = OltConfig()
64 cls.port_map = cls.olt.olt_port_map()
65 if not cls.port_map:
66 cls.port_map = g_subscriber_port_map
Chetan Gaonkerfe551a22016-04-29 17:34:57 -070067 #cls.vrouter_host_load(host = cls.GATEWAY)
Chetan Gaonker3533faa2016-04-25 17:50:14 -070068 time.sleep(3)
69
70 @classmethod
71 def tearDownClass(cls):
72 '''Deactivate the vrouter apps'''
Chetan Gaonkerfe551a22016-04-29 17:34:57 -070073 #cls.vrouter_host_unload()
Chetan Gaonker3533faa2016-04-25 17:50:14 -070074
75 def cliEnter(self):
76 retries = 0
77 while retries < 3:
78 self.cli = OnosCliDriver(connect = True)
79 if self.cli.handle:
80 break
81 else:
82 retries += 1
83 time.sleep(2)
84
85 def cliExit(self):
86 self.cli.disconnect()
87
88 @classmethod
89 def onos_load_config(cls, config):
90 status, code = OnosCtrl.config(config)
91 if status is False:
92 log.info('JSON request returned status %d' %code)
93 assert_equal(status, True)
94
95 @classmethod
Chetan Gaonkerfe551a22016-04-29 17:34:57 -070096 def vrouter_config_get(cls, networks = 4, peers = 1):
97 vrouter_configs = cls.generate_vrouter_conf(networks = networks, peers = peers)
Chetan Gaonker3533faa2016-04-25 17:50:14 -070098 return vrouter_configs
99 ##ONOS router does not support dynamic reconfigurations
100 #for config in vrouter_configs:
101 # cls.onos_load_config(config)
102 # time.sleep(5)
103
104 @classmethod
Chetan Gaonkerfe551a22016-04-29 17:34:57 -0700105 def vrouter_host_load(cls):
106 index = 1
Chetan Gaonker8e25e1b2016-05-02 13:42:21 -0700107 for host,_ in cls.peer_list:
Chetan Gaonkerfe551a22016-04-29 17:34:57 -0700108 iface = cls.port_map[index]
109 index += 1
110 config_cmds = ( 'ifconfig {0} {1}'.format(iface, host),
111 'arping -I {0} {1} -c 2'.format(iface, host),
112 )
113 for cmd in config_cmds:
114 os.system(cmd)
Chetan Gaonker3533faa2016-04-25 17:50:14 -0700115
116 @classmethod
Chetan Gaonkerfe551a22016-04-29 17:34:57 -0700117 def vrouter_host_unload(cls):
118 index = 1
Chetan Gaonker8e25e1b2016-05-02 13:42:21 -0700119 for host,_ in cls.peer_list:
Chetan Gaonkerfe551a22016-04-29 17:34:57 -0700120 iface = cls.port_map[index]
121 index += 1
122 config_cmds = ('ifconfig {} 0'.format(iface), )
123 for cmd in config_cmds:
124 os.system(cmd)
Chetan Gaonker3533faa2016-04-25 17:50:14 -0700125
126 @classmethod
127 def start_onos(cls, network_cfg = None):
128 if type(network_cfg) is tuple:
129 res = []
130 for v in network_cfg:
131 res += v.items()
132 config = dict(res)
133 else:
134 config = network_cfg
135 log.info('Restarting ONOS with new network configuration')
136 cfg = json.dumps(config)
137 with open('{}/network-cfg.json'.format(cls.onos_config_path), 'w') as f:
138 f.write(cfg)
139
140 return cord_test_onos_restart()
141
142 @classmethod
Chetan Gaonkerfe551a22016-04-29 17:34:57 -0700143 def start_quagga(cls, networks = 4):
Chetan Gaonker6cf6e472016-04-26 14:41:51 -0700144 log.info('Restarting Quagga container with configuration for %d networks' %(networks))
Chetan Gaonkerfe551a22016-04-29 17:34:57 -0700145 config = cls.generate_conf(networks = networks)
Chetan Gaonker6cf6e472016-04-26 14:41:51 -0700146 host_config_file = '{}/testrib_gen.conf'.format(Quagga.host_quagga_config)
147 guest_config_file = os.path.join(Quagga.guest_quagga_config, 'testrib_gen.conf')
148 with open(host_config_file, 'w') as f:
Chetan Gaonker3533faa2016-04-25 17:50:14 -0700149 f.write(config)
Chetan Gaonkerfd3d6502016-05-03 13:23:07 -0700150 if networks <= 10000:
151 boot_delay = 25
152 else:
Chetan Gaonker88355c62016-05-03 17:16:05 -0700153 if networks < 500000:
154 boot_delay = 75
155 else:
156 boot_delay = 300
Chetan Gaonkerfd3d6502016-05-03 13:23:07 -0700157 cord_test_quagga_restart(config_file = guest_config_file, boot_delay = boot_delay)
Chetan Gaonker3533faa2016-04-25 17:50:14 -0700158
159 @classmethod
Chetan Gaonkerfe551a22016-04-29 17:34:57 -0700160 def zgenerate_vrouter_conf(cls, networks = 4):
Chetan Gaonker3533faa2016-04-25 17:50:14 -0700161 num = 0
162 start_network = ( 11 << 24) | ( 0 << 16) | ( 0 << 8) | 0
163 end_network = ( 200 << 24 ) | ( 0 << 16) | (0 << 8) | 0
164 ports_dict = { 'ports' : {} }
165 interface_list = []
166 for n in xrange(start_network, end_network):
167 if n & 255 == 0:
168 port_map = ports_dict['ports']
169 port = num + 1 if num < cls.MAX_PORTS - 1 else cls.MAX_PORTS - 1
170 device_port_key = '{0}/{1}'.format(cls.device_id, port)
171 try:
172 interfaces = port_map[device_port_key]['interfaces']
173 except:
174 port_map[device_port_key] = { 'interfaces' : [] }
175 interfaces = port_map[device_port_key]['interfaces']
176
177 ips = '%d.%d.%d.2/24'%( (n >> 24) & 0xff, ( ( n >> 16) & 0xff ), ( (n >> 8 ) & 0xff ) )
178 if num < cls.MAX_PORTS - 1:
179 interface_dict = { 'name' : 'b1-{}'.format(port), 'ips': [ips], 'mac' : '00:00:00:00:00:01' }
180 interfaces.append(interface_dict)
181 interface_list.append(interface_dict['name'])
182 else:
183 interfaces[0]['ips'].append(ips)
184 num += 1
185 if num == networks:
186 break
187 quagga_dict = { 'apps': { 'org.onosproject.router' : { 'router' : {} } } }
188 quagga_router_dict = quagga_dict['apps']['org.onosproject.router']['router']
189 quagga_router_dict['ospfEnabled'] = True
190 quagga_router_dict['interfaces'] = interface_list
191 quagga_router_dict['controlPlaneConnectPoint'] = '{0}/{1}'.format(cls.device_id,
192 networks + 1 if networks < cls.MAX_PORTS else cls.MAX_PORTS )
193 return (cls.vrouter_device_dict, ports_dict, quagga_dict)
194
195 @classmethod
Chetan Gaonkerfe551a22016-04-29 17:34:57 -0700196 def generate_vrouter_conf(cls, networks = 4, peers = 1):
Chetan Gaonker3533faa2016-04-25 17:50:14 -0700197 num = 0
Chetan Gaonker8e25e1b2016-05-02 13:42:21 -0700198 start_peer = ( 192 << 24) | ( 168 << 16) | (10 << 8) | 0
199 end_peer = ( 200 << 24 ) | (168 << 16) | (10 << 8) | 0
Chetan Gaonkerfe551a22016-04-29 17:34:57 -0700200 local_network = end_peer + 1
201 ports_dict = { 'ports' : {} }
202 interface_list = []
203 peer_list = []
Chetan Gaonker8e25e1b2016-05-02 13:42:21 -0700204 for n in xrange(start_peer, end_peer, 256):
Chetan Gaonkerfe551a22016-04-29 17:34:57 -0700205 port_map = ports_dict['ports']
206 port = num + 1 if num < cls.MAX_PORTS - 1 else cls.MAX_PORTS - 1
207 device_port_key = '{0}/{1}'.format(cls.device_id, port)
208 try:
209 interfaces = port_map[device_port_key]['interfaces']
210 except:
211 port_map[device_port_key] = { 'interfaces' : [] }
212 interfaces = port_map[device_port_key]['interfaces']
Chetan Gaonker8e25e1b2016-05-02 13:42:21 -0700213 ip = n + 2
214 peer_ip = n + 1
Chetan Gaonkerfe551a22016-04-29 17:34:57 -0700215 ips = '%d.%d.%d.%d/24'%( (ip >> 24) & 0xff, ( (ip >> 16) & 0xff ), ( (ip >> 8 ) & 0xff ), ip & 0xff)
Chetan Gaonker8e25e1b2016-05-02 13:42:21 -0700216 peer = '%d.%d.%d.%d' % ( (peer_ip >> 24) & 0xff, ( ( peer_ip >> 16) & 0xff ), ( (peer_ip >> 8 ) & 0xff ), peer_ip & 0xff )
217 mac = RandMAC()._fix()
218 peer_list.append((peer, mac))
Chetan Gaonkerfe551a22016-04-29 17:34:57 -0700219 if num < cls.MAX_PORTS - 1:
Chetan Gaonker8e25e1b2016-05-02 13:42:21 -0700220 interface_dict = { 'name' : 'b1-{}'.format(port), 'ips': [ips], 'mac' : mac }
Chetan Gaonkerfe551a22016-04-29 17:34:57 -0700221 interfaces.append(interface_dict)
222 interface_list.append(interface_dict['name'])
223 else:
224 interfaces[0]['ips'].append(ips)
225 num += 1
226 if num == peers:
227 break
228 quagga_dict = { 'apps': { 'org.onosproject.router' : { 'router' : {}, 'bgp' : { 'bgpSpeakers' : [] } } } }
229 quagga_router_dict = quagga_dict['apps']['org.onosproject.router']['router']
230 quagga_router_dict['ospfEnabled'] = True
231 quagga_router_dict['interfaces'] = interface_list
232 quagga_router_dict['controlPlaneConnectPoint'] = '{0}/{1}'.format(cls.device_id, peers + 1)
233
234 #bgp_speaker_dict = { 'apps': { 'org.onosproject.router' : { 'bgp' : { 'bgpSpeakers' : [] } } } }
235 bgp_speakers_list = quagga_dict['apps']['org.onosproject.router']['bgp']['bgpSpeakers']
236 speaker_dict = {}
237 speaker_dict['name'] = 'bgp{}'.format(peers+1)
238 speaker_dict['connectPoint'] = '{0}/{1}'.format(cls.device_id, peers + 1)
239 speaker_dict['peers'] = peer_list
240 bgp_speakers_list.append(speaker_dict)
241 cls.peer_list = peer_list
242 return (cls.vrouter_device_dict, ports_dict, quagga_dict)
243
244 @classmethod
245 def generate_conf(cls, networks = 4):
246 num = 0
247 start_network = ( 11 << 24) | ( 10 << 16) | ( 10 << 8) | 0
248 end_network = ( 172 << 24 ) | ( 0 << 16) | (0 << 8) | 0
Chetan Gaonker3533faa2016-04-25 17:50:14 -0700249 net_list = []
Chetan Gaonkerfe551a22016-04-29 17:34:57 -0700250 peer_list = cls.peer_list
251 network_list = []
Chetan Gaonker8e25e1b2016-05-02 13:42:21 -0700252 for n in xrange(start_network, end_network, 256):
253 net = '%d.%d.%d.0'%( (n >> 24) & 0xff, ( ( n >> 16) & 0xff ), ( (n >> 8 ) & 0xff ) )
254 network_list.append(net)
255 gateway = peer_list[num % len(peer_list)][0]
256 net_route = 'ip route {0}/24 {1}'.format(net, gateway)
257 net_list.append(net_route)
258 num += 1
Chetan Gaonker3533faa2016-04-25 17:50:14 -0700259 if num == networks:
260 break
Chetan Gaonkerfe551a22016-04-29 17:34:57 -0700261 cls.network_list = network_list
Chetan Gaonker3533faa2016-04-25 17:50:14 -0700262 zebra_routes = '\n'.join(net_list)
Chetan Gaonker68d95172016-05-03 11:16:59 -0700263 #log.info('Zebra routes: \n:%s\n' %cls.zebra_conf + zebra_routes)
Chetan Gaonker3533faa2016-04-25 17:50:14 -0700264 return cls.zebra_conf + zebra_routes
265
266 @classmethod
267 def vrouter_activate(cls, deactivate = False):
268 app = 'org.onosproject.vrouter'
269 onos_ctrl = OnosCtrl(app)
270 if deactivate is True:
271 onos_ctrl.deactivate()
272 else:
273 onos_ctrl.activate()
274 time.sleep(3)
275
276 @classmethod
Chetan Gaonkerfe551a22016-04-29 17:34:57 -0700277 def vrouter_configure(cls, networks = 4, peers = 1):
Chetan Gaonker3533faa2016-04-25 17:50:14 -0700278 ##Deactivate vrouter
Chetan Gaonkerfe551a22016-04-29 17:34:57 -0700279 vrouter_configs = cls.vrouter_config_get(networks = networks, peers = peers)
Chetan Gaonker46b62d52016-04-26 10:08:42 -0700280 cls.start_onos(network_cfg = vrouter_configs)
Chetan Gaonkerfe551a22016-04-29 17:34:57 -0700281 cls.vrouter_host_load()
Chetan Gaonker02236ba2016-04-26 11:24:34 -0700282 ##Start quagga
Chetan Gaonkerfe551a22016-04-29 17:34:57 -0700283 cls.start_quagga(networks = networks)
Chetan Gaonker3533faa2016-04-25 17:50:14 -0700284 return vrouter_configs
285
Chetan Gaonkerb6064fa2016-05-02 16:29:57 -0700286 def vrouter_port_send_recv(self, ingress, egress, dst_mac, dst_ip, positive_test = True):
Chetan Gaonker3533faa2016-04-25 17:50:14 -0700287 src_mac = '00:00:00:00:00:02'
Chetan Gaonkerfe551a22016-04-29 17:34:57 -0700288 src_ip = '1.1.1.1'
Chetan Gaonkerb6064fa2016-05-02 16:29:57 -0700289 self.success = False if positive_test else True
Chetan Gaonker68d95172016-05-03 11:16:59 -0700290 timeout = 10 if positive_test else 1
Chetan Gaonkerb6064fa2016-05-02 16:29:57 -0700291 count = 2 if positive_test else 1
Chetan Gaonker68d95172016-05-03 11:16:59 -0700292 self.start_sending = True
Chetan Gaonker3533faa2016-04-25 17:50:14 -0700293 def recv_task():
294 def recv_cb(pkt):
295 log.info('Pkt seen with ingress ip %s, egress ip %s' %(pkt[IP].src, pkt[IP].dst))
Chetan Gaonkerb6064fa2016-05-02 16:29:57 -0700296 self.success = True if positive_test else False
297 sniff(count=count, timeout=timeout,
Chetan Gaonker3533faa2016-04-25 17:50:14 -0700298 lfilter = lambda p: IP in p and p[IP].dst == dst_ip and p[IP].src == src_ip,
Chetan Gaonkerfe551a22016-04-29 17:34:57 -0700299 prn = recv_cb, iface = self.port_map[ingress])
Chetan Gaonker68d95172016-05-03 11:16:59 -0700300 self.start_sending = False
Chetan Gaonker3533faa2016-04-25 17:50:14 -0700301
302 t = threading.Thread(target = recv_task)
303 t.start()
304 L2 = Ether(src = src_mac, dst = dst_mac)
305 L3 = IP(src = src_ip, dst = dst_ip)
306 pkt = L2/L3
307 log.info('Sending a packet with dst ip %s, dst mac %s on port %s to verify if flows are correct' %
Chetan Gaonkerfe551a22016-04-29 17:34:57 -0700308 (dst_ip, dst_mac, self.port_map[egress]))
Chetan Gaonker68d95172016-05-03 11:16:59 -0700309 while self.start_sending is True:
310 sendp(pkt, count=50, iface = self.port_map[egress])
Chetan Gaonker3533faa2016-04-25 17:50:14 -0700311 t.join()
312 assert_equal(self.success, True)
313
Chetan Gaonkerb6064fa2016-05-02 16:29:57 -0700314 def vrouter_traffic_verify(self, positive_test = True):
Chetan Gaonkerfe551a22016-04-29 17:34:57 -0700315 peers = len(self.peer_list)
316 egress = peers + 1
317 num = 0
Chetan Gaonkerb6064fa2016-05-02 16:29:57 -0700318 num_hosts = 5 if positive_test else 1
Chetan Gaonkerfe551a22016-04-29 17:34:57 -0700319 for network in self.network_list:
Chetan Gaonkerb6064fa2016-05-02 16:29:57 -0700320 num_ips = num_hosts
Chetan Gaonkerfe551a22016-04-29 17:34:57 -0700321 octets = network.split('.')
322 for i in xrange(num_ips):
323 octets[-1] = str(int(octets[-1]) + 1)
324 dst_ip = '.'.join(octets)
Chetan Gaonkerb6064fa2016-05-02 16:29:57 -0700325 dst_mac = self.peer_list[ num % peers ] [1]
Chetan Gaonkerfe551a22016-04-29 17:34:57 -0700326 port = (num % peers)
327 ingress = port + 1
328 #Since peers are on the same network
329 ##Verify if flows are setup by sending traffic across
Chetan Gaonkerb6064fa2016-05-02 16:29:57 -0700330 self.vrouter_port_send_recv(ingress, egress, dst_mac, dst_ip, positive_test = positive_test)
Chetan Gaonkerfe551a22016-04-29 17:34:57 -0700331 num += 1
332
Chetan Gaonkerb6064fa2016-05-02 16:29:57 -0700333 def __vrouter_network_verify(self, networks, peers = 1, positive_test = True):
Chetan Gaonkerfe551a22016-04-29 17:34:57 -0700334 _, ports_map, egress_map = self.vrouter_configure(networks = networks, peers = peers)
Chetan Gaonker3533faa2016-04-25 17:50:14 -0700335 self.cliEnter()
336 ##Now verify
337 hosts = json.loads(self.cli.hosts(jsonFormat = True))
338 log.info('Discovered hosts: %s' %hosts)
Chetan Gaonker68d95172016-05-03 11:16:59 -0700339 ##We read from cli if we expect less number of routes to avoid cli timeouts
340 if networks <= 10000:
341 routes = json.loads(self.cli.routes(jsonFormat = True))
342 #log.info('Routes: %s' %routes)
343 assert_equal(len(routes['routes4']), networks)
344 flows = json.loads(self.cli.flows(jsonFormat = True))
345 flows = filter(lambda f: f['flows'], flows)
346 #log.info('Flows: %s' %flows)
347 assert_not_equal(len(flows), 0)
Chetan Gaonkerfe551a22016-04-29 17:34:57 -0700348 self.vrouter_traffic_verify()
Chetan Gaonkerb6064fa2016-05-02 16:29:57 -0700349 if positive_test is False:
350 self.__vrouter_network_verify_negative(networks, peers = peers)
Chetan Gaonker3533faa2016-04-25 17:50:14 -0700351 self.cliExit()
Chetan Gaonkerfe551a22016-04-29 17:34:57 -0700352 self.vrouter_host_unload()
Chetan Gaonker3533faa2016-04-25 17:50:14 -0700353 return True
354
Chetan Gaonkerb6064fa2016-05-02 16:29:57 -0700355 def __vrouter_network_verify_negative(self, networks, peers = 1):
356 ##Stop quagga. Test traffic again to see if flows were removed
357 log.info('Stopping Quagga container')
358 quaggaStop = QuaggaStopWrapper()
359 time.sleep(2)
Chetan Gaonker68d95172016-05-03 11:16:59 -0700360 if networks <= 10000:
361 routes = json.loads(self.cli.routes(jsonFormat = True))
362 #Verify routes have been removed
363 if routes and routes.has_key('routes4'):
364 assert_equal(len(routes['routes4']), 0)
Chetan Gaonkerb6064fa2016-05-02 16:29:57 -0700365 self.vrouter_traffic_verify(positive_test = False)
366 log.info('OVS flows have been removed successfully after Quagga was stopped')
367 self.start_quagga(networks = networks)
368 ##Verify the flows again after restarting quagga back
Chetan Gaonker68d95172016-05-03 11:16:59 -0700369 if networks <= 10000:
370 routes = json.loads(self.cli.routes(jsonFormat = True))
371 assert_equal(len(routes['routes4']), networks)
Chetan Gaonkerb6064fa2016-05-02 16:29:57 -0700372 self.vrouter_traffic_verify()
373 log.info('OVS flows have been successfully reinstalled after Quagga was restarted')
374
Chetan Gaonker3533faa2016-04-25 17:50:14 -0700375 def test_vrouter_1(self):
376 '''Test vrouter with 5 routes'''
Chetan Gaonker8e25e1b2016-05-02 13:42:21 -0700377 res = self.__vrouter_network_verify(5, peers = 1)
Chetan Gaonker3533faa2016-04-25 17:50:14 -0700378 assert_equal(res, True)
379
380 def test_vrouter_2(self):
Chetan Gaonker8e25e1b2016-05-02 13:42:21 -0700381 '''Test vrouter with 5 routes with 2 peers'''
382 res = self.__vrouter_network_verify(5, peers = 2)
Chetan Gaonker3533faa2016-04-25 17:50:14 -0700383 assert_equal(res, True)
384
385 def test_vrouter_3(self):
Chetan Gaonker8e25e1b2016-05-02 13:42:21 -0700386 '''Test vrouter with 6 routes with 3 peers'''
387 res = self.__vrouter_network_verify(6, peers = 3)
Chetan Gaonker3533faa2016-04-25 17:50:14 -0700388 assert_equal(res, True)
389
390 def test_vrouter_4(self):
Chetan Gaonker8e25e1b2016-05-02 13:42:21 -0700391 '''Test vrouter with 50 routes'''
392 res = self.__vrouter_network_verify(50, peers = 1)
Chetan Gaonker3533faa2016-04-25 17:50:14 -0700393 assert_equal(res, True)
Chetan Gaonker6cf6e472016-04-26 14:41:51 -0700394
Chetan Gaonker6cf6e472016-04-26 14:41:51 -0700395 def test_vrouter_5(self):
Chetan Gaonker8e25e1b2016-05-02 13:42:21 -0700396 '''Test vrouter with 50 routes and 5 peers'''
397 res = self.__vrouter_network_verify(50, peers = 5)
398 assert_equal(res, True)
399
400 def test_vrouter_6(self):
401 '''Test vrouter with 100 routes'''
402 res = self.__vrouter_network_verify(100, peers = 1)
403 assert_equal(res, True)
404
405 def test_vrouter_7(self):
406 '''Test vrouter with 100 routes and 10 peers'''
407 res = self.__vrouter_network_verify(100, peers = 10)
408 assert_equal(res, True)
409
410 def test_vrouter_8(self):
411 '''Test vrouter with 300 routes'''
412 res = self.__vrouter_network_verify(300, peers = 1)
413 assert_equal(res, True)
414
415 def test_vrouter_9(self):
Chetan Gaonker6cf6e472016-04-26 14:41:51 -0700416 '''Test vrouter with 1000 routes'''
Chetan Gaonker8e25e1b2016-05-02 13:42:21 -0700417 res = self.__vrouter_network_verify(1000, peers = 1)
Chetan Gaonker6cf6e472016-04-26 14:41:51 -0700418 assert_equal(res, True)
419
Chetan Gaonker8e25e1b2016-05-02 13:42:21 -0700420 def test_vrouter_10(self):
Chetan Gaonker6cf6e472016-04-26 14:41:51 -0700421 '''Test vrouter with 10000 routes'''
Chetan Gaonker8e25e1b2016-05-02 13:42:21 -0700422 res = self.__vrouter_network_verify(10000, peers = 1)
Chetan Gaonker6cf6e472016-04-26 14:41:51 -0700423 assert_equal(res, True)
Chetan Gaonkerfe551a22016-04-29 17:34:57 -0700424
Chetan Gaonker6cf6e472016-04-26 14:41:51 -0700425 @nottest
Chetan Gaonker8e25e1b2016-05-02 13:42:21 -0700426 def test_vrouter_11(self):
Chetan Gaonker6cf6e472016-04-26 14:41:51 -0700427 '''Test vrouter with 100000 routes'''
Chetan Gaonker8e25e1b2016-05-02 13:42:21 -0700428 res = self.__vrouter_network_verify(100000, peers = 1)
Chetan Gaonker6cf6e472016-04-26 14:41:51 -0700429 assert_equal(res, True)
430
431 @nottest
Chetan Gaonker8e25e1b2016-05-02 13:42:21 -0700432 def test_vrouter_12(self):
Chetan Gaonker6cf6e472016-04-26 14:41:51 -0700433 '''Test vrouter with 1000000 routes'''
Chetan Gaonker8e25e1b2016-05-02 13:42:21 -0700434 res = self.__vrouter_network_verify(1000000, peers = 1)
Chetan Gaonker6cf6e472016-04-26 14:41:51 -0700435 assert_equal(res, True)
Chetan Gaonkerb6064fa2016-05-02 16:29:57 -0700436
437 def test_vrouter_13(self):
438 '''Test vrouter by installing 5 routes, removing Quagga and re-starting Quagga back'''
439 res = self.__vrouter_network_verify(5, peers = 1, positive_test = False)
440
441 def test_vrouter_14(self):
442 '''Test vrouter by installing 50 routes, removing Quagga and re-starting Quagga back'''
443 res = self.__vrouter_network_verify(50, peers = 1, positive_test = False)