blob: 10616eb6caa160ff42236b7bd260c3eaf9474303 [file] [log] [blame]
A R Karthick41adfce2016-06-10 09:51:25 -07001#
Chetan Gaonkercfcce782016-05-10 10:10:42 -07002# Copyright 2016-present Ciena Corporation
3#
4# Licensed under the Apache License, Version 2.0 (the "License");
5# you may not use this file except in compliance with the License.
6# You may obtain a copy of the License at
A R Karthick41adfce2016-06-10 09:51:25 -07007#
Chetan Gaonkercfcce782016-05-10 10:10:42 -07008# http://www.apache.org/licenses/LICENSE-2.0
A R Karthick41adfce2016-06-10 09:51:25 -07009#
Chetan Gaonkercfcce782016-05-10 10:10:42 -070010# Unless required by applicable law or agreed to in writing, software
11# distributed under the License is distributed on an "AS IS" BASIS,
12# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13# See the License for the specific language governing permissions and
14# limitations under the License.
15#
Chetan Gaonker3533faa2016-04-25 17:50:14 -070016import os,time
17import io
18import json
A R Karthickd44cea12016-07-20 12:16:41 -070019import yaml
A.R Karthickc4e474d2016-12-12 15:24:57 -080020import errno
A R Karthickaa54a1c2016-12-15 11:42:08 -080021import copy
Chetan Gaonker3533faa2016-04-25 17:50:14 -070022from pyroute2 import IPRoute
A.R Karthickc4e474d2016-12-12 15:24:57 -080023from pyroute2.netlink import NetlinkError
Chetan Gaonker3533faa2016-04-25 17:50:14 -070024from itertools import chain
25from nsenter import Namespace
26from docker import Client
A R Karthick85eb1862017-01-23 16:10:57 -080027from docker import utils as dockerutils
A.R Karthickf184b342017-01-27 19:30:50 -080028import shutil
A.R Karthick95d044e2016-06-10 18:44:36 -070029from OnosCtrl import OnosCtrl
A R Karthick19aaf5c2016-11-09 17:47:57 -080030from OnosLog import OnosLog
A R Karthick03bd2812017-03-03 17:49:17 -080031from onosclidriver import OnosCliDriver
A.R Karthickc4e474d2016-12-12 15:24:57 -080032from threadPool import ThreadPool
A R Karthickaa54a1c2016-12-15 11:42:08 -080033from threading import Lock
Chetan Gaonker3533faa2016-04-25 17:50:14 -070034
35class docker_netns(object):
36
37 dckr = Client()
38 def __init__(self, name):
39 pid = int(self.dckr.inspect_container(name)['State']['Pid'])
40 if pid == 0:
41 raise Exception('no container named {0}'.format(name))
42 self.pid = pid
43
44 def __enter__(self):
45 pid = self.pid
46 if not os.path.exists('/var/run/netns'):
47 os.mkdir('/var/run/netns')
48 os.symlink('/proc/{0}/ns/net'.format(pid), '/var/run/netns/{0}'.format(pid))
49 return str(pid)
50
51 def __exit__(self, type, value, traceback):
52 pid = self.pid
53 os.unlink('/var/run/netns/{0}'.format(pid))
54
55flatten = lambda l: chain.from_iterable(l)
56
57class Container(object):
58 dckr = Client()
A R Karthick07608ef2016-08-23 16:51:19 -070059 IMAGE_PREFIX = '' ##for saving global prefix for all test classes
A R Karthickaa54a1c2016-12-15 11:42:08 -080060 CONFIG_LOCK = Lock()
A R Karthick07608ef2016-08-23 16:51:19 -070061
62 def __init__(self, name, image, prefix='', tag = 'candidate', command = 'bash', quagga_config = None):
Chetan Gaonker3533faa2016-04-25 17:50:14 -070063 self.name = name
A R Karthick07608ef2016-08-23 16:51:19 -070064 self.prefix = prefix
65 if prefix:
66 self.prefix += '/'
67 image = '{}{}'.format(self.prefix, image)
Chetan Gaonker3533faa2016-04-25 17:50:14 -070068 self.image = image
69 self.tag = tag
A R Karthickd44cea12016-07-20 12:16:41 -070070 if tag:
71 self.image_name = image + ':' + tag
72 else:
73 self.image_name = image
Chetan Gaonker3533faa2016-04-25 17:50:14 -070074 self.id = None
75 self.command = command
Chetan Gaonker8e25e1b2016-05-02 13:42:21 -070076 self.quagga_config = quagga_config
Chetan Gaonker3533faa2016-04-25 17:50:14 -070077
78 @classmethod
79 def build_image(cls, dockerfile, tag, force=True, nocache=False):
80 f = io.BytesIO(dockerfile.encode('utf-8'))
81 if force or not cls.image_exists(tag):
82 print('Build {0}...'.format(tag))
83 for line in cls.dckr.build(fileobj=f, rm=True, tag=tag, decode=True, nocache=nocache):
84 if 'stream' in line:
85 print(line['stream'].strip())
86
87 @classmethod
88 def image_exists(cls, name):
A R Karthicke07fc3a2017-02-27 10:49:29 -080089 #return name in [ctn['RepoTags'][0] for ctn in cls.dckr.images()]
90 return name in list( flatten(ctn['RepoTags'] if ctn['RepoTags'] else '' for ctn in cls.dckr.images()) )
Chetan Gaonker3533faa2016-04-25 17:50:14 -070091
92 @classmethod
93 def create_host_config(cls, port_list = None, host_guest_map = None, privileged = False):
94 port_bindings = None
95 binds = None
96 if port_list:
97 port_bindings = {}
98 for p in port_list:
99 port_bindings[str(p)] = str(p)
100
101 if host_guest_map:
102 binds = []
103 for h, g in host_guest_map:
104 binds.append('{0}:{1}'.format(h, g))
105
106 return cls.dckr.create_host_config(binds = binds, port_bindings = port_bindings, privileged = privileged)
107
108 @classmethod
A R Karthick85eb1862017-01-23 16:10:57 -0800109 def connect_to_network(cls, name, network):
110 try:
111 cls.dckr.connect_container_to_network(name, network)
112 return True
113 except:
114 return False
115
116 @classmethod
117 def create_network(cls, network, subnet = None, gateway = None):
118 ipam_config = None
119 if subnet is not None and gateway is not None:
120 ipam_pool = dockerutils.create_ipam_pool(subnet = subnet, gateway = gateway)
121 ipam_config = dockerutils.create_ipam_config(pool_configs = [ipam_pool])
122 cls.dckr.create_network(network, driver='bridge', ipam = ipam_config)
123
124 @classmethod
Chetan Gaonker3533faa2016-04-25 17:50:14 -0700125 def cleanup(cls, image):
A R Karthick09b1f4e2016-05-12 14:31:50 -0700126 cnt_list = filter(lambda c: c['Image'] == image, cls.dckr.containers(all=True))
Chetan Gaonker3533faa2016-04-25 17:50:14 -0700127 for cnt in cnt_list:
128 print('Cleaning container %s' %cnt['Id'])
A.R Karthick95d044e2016-06-10 18:44:36 -0700129 if cnt.has_key('State') and cnt['State'] == 'running':
A R Karthick09b1f4e2016-05-12 14:31:50 -0700130 cls.dckr.kill(cnt['Id'])
Chetan Gaonker3533faa2016-04-25 17:50:14 -0700131 cls.dckr.remove_container(cnt['Id'], force=True)
132
133 @classmethod
134 def remove_container(cls, name, force=True):
135 try:
136 cls.dckr.remove_container(name, force = force)
137 except: pass
138
139 def exists(self):
140 return '/{0}'.format(self.name) in list(flatten(n['Names'] for n in self.dckr.containers()))
141
142 def img_exists(self):
A R Karthicke07fc3a2017-02-27 10:49:29 -0800143 #return self.image_name in [ctn['RepoTags'][0] if ctn['RepoTags'] else '' for ctn in self.dckr.images()]
144 return self.image_name in list( flatten(ctn['RepoTags'] if ctn['RepoTags'] else '' for ctn in self.dckr.images()) )
Chetan Gaonker3533faa2016-04-25 17:50:14 -0700145
A R Karthick75844572017-01-23 16:57:44 -0800146 def ip(self, network = None):
A R Karthick2b93d6a2016-09-06 15:19:09 -0700147 cnt_list = filter(lambda c: c['Names'][0] == '/{}'.format(self.name), self.dckr.containers())
148 #if not cnt_list:
149 # cnt_list = filter(lambda c: c['Image'] == self.image_name, self.dckr.containers())
Chetan Gaonker3533faa2016-04-25 17:50:14 -0700150 cnt_settings = cnt_list.pop()
A R Karthick75844572017-01-23 16:57:44 -0800151 if network is not None and cnt_settings['NetworkSettings']['Networks'].has_key(network):
152 return cnt_settings['NetworkSettings']['Networks'][network]['IPAddress']
Chetan Gaonker3533faa2016-04-25 17:50:14 -0700153 return cnt_settings['NetworkSettings']['Networks']['bridge']['IPAddress']
154
A R Karthick2b93d6a2016-09-06 15:19:09 -0700155 @classmethod
156 def ips(cls, image_name):
157 cnt_list = filter(lambda c: c['Image'] == image_name, cls.dckr.containers())
158 ips = [ cnt['NetworkSettings']['Networks']['bridge']['IPAddress'] for cnt in cnt_list ]
159 return ips
160
Chetan Gaonker3533faa2016-04-25 17:50:14 -0700161 def kill(self, remove = True):
162 self.dckr.kill(self.name)
163 self.dckr.remove_container(self.name, force=True)
164
A R Karthick41adfce2016-06-10 09:51:25 -0700165 def start(self, rm = True, ports = None, volumes = None, host_config = None,
Chetan Gaonker3533faa2016-04-25 17:50:14 -0700166 environment = None, tty = False, stdin_open = True):
167
168 if rm and self.exists():
169 print('Removing container:', self.name)
170 self.dckr.remove_container(self.name, force=True)
171
A R Karthick41adfce2016-06-10 09:51:25 -0700172 ctn = self.dckr.create_container(image=self.image_name, ports = ports, command=self.command,
Chetan Gaonker3533faa2016-04-25 17:50:14 -0700173 detach=True, name=self.name,
A R Karthick41adfce2016-06-10 09:51:25 -0700174 environment = environment,
175 volumes = volumes,
Chetan Gaonker3533faa2016-04-25 17:50:14 -0700176 host_config = host_config, stdin_open=stdin_open, tty = tty)
177 self.dckr.start(container=self.name)
Chetan Gaonker8e25e1b2016-05-02 13:42:21 -0700178 if self.quagga_config:
Chetan Gaonker3533faa2016-04-25 17:50:14 -0700179 self.connect_to_br()
180 self.id = ctn['Id']
181 return ctn
182
Thangavelu K Sef6f0a52016-12-14 19:57:05 +0000183 @classmethod
184 def pause_container(cls, image, delay):
185 cnt_list = filter(lambda c: c['Image'] == image, cls.dckr.containers(all=True))
186 for cnt in cnt_list:
187 print('Pause the container %s' %cnt['Id'])
188 if cnt.has_key('State') and cnt['State'] == 'running':
189 cls.dckr.pause(cnt['Id'])
190 if delay != 0:
191 time.sleep(delay)
192 for cnt in cnt_list:
193 print('Unpause the container %s' %cnt['Id'])
194 cls.dckr.unpause(cnt['Id'])
195 else:
196 print('Infinity time pause the container %s' %cnt['Id'])
197 return 'success'
198
A R Karthick52414732017-01-31 09:59:47 -0800199 def connect_to_br(self, index = 0):
A R Karthickaa54a1c2016-12-15 11:42:08 -0800200 self.CONFIG_LOCK.acquire()
201 try:
202 with docker_netns(self.name) as pid:
203 for quagga_config in self.quagga_config:
Chetan Gaonker8e25e1b2016-05-02 13:42:21 -0700204 ip = IPRoute()
A R Karthickaa54a1c2016-12-15 11:42:08 -0800205 br = ip.link_lookup(ifname=quagga_config['bridge'])
206 if len(br) == 0:
207 try:
208 ip.link_create(ifname=quagga_config['bridge'], kind='bridge')
209 except NetlinkError as e:
210 err, _ = e.args
211 if err == errno.EEXIST:
212 pass
213 else:
214 raise NetlinkError(*e.args)
215 br = ip.link_lookup(ifname=quagga_config['bridge'])
216 br = br[0]
217 ip.link('set', index=br, state='up')
A R Karthick52414732017-01-31 09:59:47 -0800218 ifname = '{0}-{1}'.format(self.name[:12], index)
A R Karthickaa54a1c2016-12-15 11:42:08 -0800219 ifs = ip.link_lookup(ifname=ifname)
220 if len(ifs) > 0:
221 ip.link_remove(ifs[0])
222 peer_ifname = '{0}-{1}'.format(pid, index)
223 ip.link_create(ifname=ifname, kind='veth', peer=peer_ifname)
224 host = ip.link_lookup(ifname=ifname)[0]
225 ip.link('set', index=host, master=br)
226 ip.link('set', index=host, state='up')
227 guest = ip.link_lookup(ifname=peer_ifname)[0]
228 ip.link('set', index=guest, net_ns_fd=pid)
229 with Namespace(pid, 'net'):
230 ip = IPRoute()
231 ip.link('set', index=guest, ifname='eth{}'.format(index+1))
232 ip.addr('add', index=guest, address=quagga_config['ip'], mask=quagga_config['mask'])
233 ip.link('set', index=guest, state='up')
234 index += 1
235 finally:
236 self.CONFIG_LOCK.release()
Chetan Gaonker3533faa2016-04-25 17:50:14 -0700237
Thangavelu K Sef6f0a52016-12-14 19:57:05 +0000238 def execute(self, cmd, tty = True, stream = False, shell = False, detach = True):
Chetan Gaonker3533faa2016-04-25 17:50:14 -0700239 res = 0
240 if type(cmd) == str:
241 cmds = (cmd,)
242 else:
243 cmds = cmd
244 if shell:
245 for c in cmds:
246 res += os.system('docker exec {0} {1}'.format(self.name, c))
247 return res
248 for c in cmds:
249 i = self.dckr.exec_create(container=self.name, cmd=c, tty = tty, privileged = True)
A R Karthickd6dd9b22017-02-24 15:17:22 -0800250 s = self.dckr.exec_start(i['Id'], stream = stream, detach=detach, socket=True)
251 try:
252 s.close()
253 except: pass
Chetan Gaonker3533faa2016-04-25 17:50:14 -0700254 result = self.dckr.exec_inspect(i['Id'])
255 res += 0 if result['ExitCode'] == None else result['ExitCode']
256 return res
257
ChetanGaonker6138fcd2016-08-18 17:56:39 -0700258 def restart(self, timeout =10):
259 return self.dckr.restart(self.name, timeout)
260
A R Karthickc69d73e2017-01-20 11:44:34 -0800261def get_mem(jvm_heap_size = None, instances = 1):
A R Karthick1f908202016-11-16 17:32:20 -0800262 if instances <= 0:
263 instances = 1
A R Karthickc69d73e2017-01-20 11:44:34 -0800264 heap_size = jvm_heap_size
265 heap_size_i = 0
266 #sanitize the heap size config
267 if heap_size is not None:
268 if not heap_size.isdigit():
269 try:
270 heap_size_i = int(heap_size[:-1])
271 suffix = heap_size[-1]
272 if suffix == 'M':
273 heap_size_i /= 1024 #convert to gigs
A.R Karthick99044822017-02-09 14:04:20 -0800274 #allow to specific minimum heap size
275 if heap_size_i == 0:
276 return heap_size
A R Karthickc69d73e2017-01-20 11:44:34 -0800277 except:
278 ##invalid suffix length probably. Fall back to default
279 heap_size = None
280 else:
281 heap_size_i = int(heap_size)
282
Chetan Gaonker462d9fa2016-05-03 16:39:10 -0700283 with open('/proc/meminfo', 'r') as fd:
284 meminfo = fd.readlines()
285 mem = 0
286 for m in meminfo:
287 if m.startswith('MemTotal:') or m.startswith('SwapTotal:'):
288 mem += int(m.split(':')[1].strip().split()[0])
289
A R Karthick1f908202016-11-16 17:32:20 -0800290 mem = max(mem/1024/1024/2/instances, 1)
Chetan Gaonker6d0a7b02016-05-03 16:57:28 -0700291 mem = min(mem, 16)
A R Karthickc69d73e2017-01-20 11:44:34 -0800292
293 if heap_size_i:
294 #we take the minimum of the provided heap size and max allowed heap size
295 heap_size_i = min(heap_size_i, mem)
296 else:
297 heap_size_i = mem
298
299 return '{}G'.format(heap_size_i)
Chetan Gaonker462d9fa2016-05-03 16:39:10 -0700300
A R Karthickd44cea12016-07-20 12:16:41 -0700301class OnosCord(Container):
302 """Use this when running the cord tester agent on the onos compute node"""
A R Karthickd44cea12016-07-20 12:16:41 -0700303 onos_config_dir_guest = '/root/onos/config'
A R Karthick03bd2812017-03-03 17:49:17 -0800304 synchronizer_map = { 'vtn' : { 'install':
305 ('http://mavenrepo:8080/repository/org/opencord/cord-config/1.2-SNAPSHOT/cord-config-1.2-SNAPSHOT.oar',
306 'http://mavenrepo:8080/repository/org/opencord/vtn/1.2-SNAPSHOT/vtn-1.2-SNAPSHOT.oar',),
307 'activate':
308 ('org.onosproject.ovsdb-base', 'org.onosproject.drivers.ovsdb',
309 'org.onosproject.dhcp', 'org.onosproject.optical-model',
310 'org.onosproject.openflow-base', 'org.onosproject.proxyarp',
311 'org.onosproject.hostprovider'),
312 },
313 'fabric' : { 'activate':
314 ('org.onosproject.hostprovider', 'org.onosproject.optical-model',
315 'org.onosproject.openflow-base', 'org.onosproject.vrouter',
316 'org.onosproject.netcfghostprovider', 'org.onosproject.netcfglinksprovider',
317 'org.onosproject.segmentrouting', 'org.onosproject.proxyarp'),
318 }
319 }
320 tester_apps = ('http://mavenrepo:8080/repository/org/opencord/aaa/1.2-SNAPSHOT/aaa-1.2-SNAPSHOT.oar',
321 'http://mavenrepo:8080/repository/org/opencord/igmp/1.2-SNAPSHOT/igmp-1.2-SNAPSHOT.oar',)
A R Karthickd44cea12016-07-20 12:16:41 -0700322
A R Karthick03bd2812017-03-03 17:49:17 -0800323 def __init__(self, onos_ip, conf, service_profile, synchronizer, start = True, boot_delay = 5):
A.R Karthickf184b342017-01-27 19:30:50 -0800324 if not os.access(conf, os.F_OK):
325 raise Exception('ONOS cord configuration location %s is invalid' %conf)
A R Karthickbd9b8a32016-07-21 09:56:45 -0700326 self.onos_ip = onos_ip
A.R Karthickf184b342017-01-27 19:30:50 -0800327 self.onos_cord_dir = conf
A R Karthickbd9b8a32016-07-21 09:56:45 -0700328 self.boot_delay = boot_delay
A.R Karthickf184b342017-01-27 19:30:50 -0800329 self.synchronizer = synchronizer
330 self.service_profile = service_profile
331 self.docker_yaml = os.path.join(conf, 'docker-compose.yml')
332 self.docker_yaml_saved = os.path.join(conf, 'docker-compose.yml.saved')
333 self.onos_config_dir = os.path.join(conf, 'config')
334 self.onos_cfg_save_loc = os.path.join(conf, 'network-cfg.json.saved')
335 instance_active = False
336 #if we have a wrapper onos instance already active, back out
337 if os.access(self.onos_config_dir, os.F_OK) or os.access(self.docker_yaml_saved, os.F_OK):
338 instance_active = True
339 else:
340 if start is True:
341 os.mkdir(self.onos_config_dir)
342 shutil.copy(self.docker_yaml, self.docker_yaml_saved)
A R Karthickd44cea12016-07-20 12:16:41 -0700343
A.R Karthickf184b342017-01-27 19:30:50 -0800344 self.start_wrapper = instance_active is False and start is True
A R Karthickd44cea12016-07-20 12:16:41 -0700345 ##update the docker yaml with the config volume
346 with open(self.docker_yaml, 'r') as f:
347 yaml_config = yaml.load(f)
348 image = yaml_config['services'].keys()[0]
A.R Karthickf184b342017-01-27 19:30:50 -0800349 cord_conf_dir_basename = os.path.basename(self.onos_cord_dir.replace('-', ''))
350 xos_onos_name = '{}_{}_1'.format(cord_conf_dir_basename, image)
A R Karthick5778a792017-01-31 13:47:16 -0800351 if not yaml_config['services'][image].has_key('volumes'):
352 yaml_config['services'][image]['volumes'] = []
A R Karthickd44cea12016-07-20 12:16:41 -0700353 volumes = yaml_config['services'][image]['volumes']
354 config_volumes = filter(lambda e: e.find(self.onos_config_dir_guest) >= 0, volumes)
355 if not config_volumes:
356 config_volume = '{}:{}'.format(self.onos_config_dir, self.onos_config_dir_guest)
357 volumes.append(config_volume)
A.R Karthickf184b342017-01-27 19:30:50 -0800358 if self.start_wrapper:
359 docker_yaml_changed = '{}-changed'.format(self.docker_yaml)
360 with open(docker_yaml_changed, 'w') as wf:
361 yaml.dump(yaml_config, wf)
362 os.rename(docker_yaml_changed, self.docker_yaml)
A R Karthickd44cea12016-07-20 12:16:41 -0700363 self.volumes = volumes
364
A R Karthickd44cea12016-07-20 12:16:41 -0700365 ##Create an container instance of xos onos
A R Karthick52414732017-01-31 09:59:47 -0800366 super(OnosCord, self).__init__(xos_onos_name, image, tag = '', quagga_config = Onos.QUAGGA_CONFIG)
A.R Karthickf184b342017-01-27 19:30:50 -0800367 self.last_cfg = None
368 if self.start_wrapper:
369 #fetch the current config of onos cord instance and save it
370 try:
371 self.last_cfg = OnosCtrl.get_config(controller = onos_ip)
372 json_data = json.dumps(self.last_cfg, indent=4)
373 with open(self.onos_cfg_save_loc, 'w') as f:
374 f.write(json_data)
375 except:
376 pass
377 #start the container back with the shared onos config volume
378 self.start()
A R Karthickd44cea12016-07-20 12:16:41 -0700379
A R Karthick03bd2812017-03-03 17:49:17 -0800380 def cliEnter(self):
381 retries = 0
382 while retries < 30:
383 cli = OnosCliDriver(controller = self.onos_ip, connect = True)
384 if cli.handle:
385 return cli
386 else:
387 retries += 1
A R Karthick72fcbc52017-03-06 12:35:17 -0800388 time.sleep(3)
A R Karthick03bd2812017-03-03 17:49:17 -0800389
390 return None
391
392 def cliExit(self, cli):
393 if cli:
394 cli.disconnect()
395
396 def synchronize_vtn(self, cfg = None):
397 if cfg is None:
398 return
399 if not cfg.has_key('apps'):
400 return
401 if not cfg['apps'].has_key('org.opencord.vtn'):
402 return
403 vtn_neutron_cfg = cfg['apps']['org.opencord.vtn']['cordvtn']['openstack']
404 password = vtn_neutron_cfg['password']
405 endpoint = vtn_neutron_cfg['endpoint']
406 user = vtn_neutron_cfg['user']
407 tenant = vtn_neutron_cfg['tenant']
408 vtn_host = cfg['apps']['org.opencord.vtn']['cordvtn']['nodes'][0]['hostname']
409 cli = self.cliEnter()
410 if cli is None:
411 return
412 cli.cordVtnSyncNeutronStates(endpoint, password, tenant = tenant, user = user)
413 time.sleep(2)
414 cli.cordVtnNodeInit(vtn_host)
415 self.cliExit(cli)
416
417 def synchronize(self, cfg_unlink = False):
A R Karthick03bd2812017-03-03 17:49:17 -0800418
419 if not self.synchronizer_map.has_key(self.synchronizer):
420 return
421
422 install_list = ()
423 if self.synchronizer_map[self.synchronizer].has_key('install'):
424 install_list = self.synchronizer_map[self.synchronizer]['install']
425
426 activate_list = ()
427 if self.synchronizer_map[self.synchronizer].has_key('activate'):
428 activate_list = self.synchronizer_map[self.synchronizer]['activate']
429
430 for app_url in install_list:
431 print('Installing app from url: %s' %app_url)
432 OnosCtrl.install_app_from_url(None, None, app_url = app_url, onos_ip = self.onos_ip)
433
434 for app in activate_list:
435 print('Activating app %s' %app)
436 OnosCtrl(app, controller = self.onos_ip).activate()
437 time.sleep(2)
438
439 for app_url in self.tester_apps:
440 print('Installing tester app from url: %s' %app_url)
441 OnosCtrl.install_app_from_url(None, None, app_url = app_url, onos_ip = self.onos_ip)
442
A R Karthick72fcbc52017-03-06 12:35:17 -0800443 cfg = None
444 #restore the saved config after applications are activated
445 if os.access(self.onos_cfg_save_loc, os.F_OK):
446 with open(self.onos_cfg_save_loc, 'r') as f:
447 cfg = json.load(f)
448 try:
449 OnosCtrl.config(cfg, controller = self.onos_ip)
450 if cfg_unlink is True:
451 os.unlink(self.onos_cfg_save_loc)
452 except:
453 pass
454
455 if hasattr(self, 'synchronize_{}'.format(self.synchronizer)):
456 getattr(self, 'synchronize_{}'.format(self.synchronizer))(cfg = cfg)
457
458 #now restart the xos synchronizer container
A R Karthick03bd2812017-03-03 17:49:17 -0800459 cmd = 'cd /opt/cord_profile/onboarding-docker-compose && \
460 docker-compose -p {} restart xos_synchronizer_{}'.format(self.service_profile, self.synchronizer)
461 try:
462 print(cmd)
463 os.system(cmd)
464 except: pass
465
A R Karthickd44cea12016-07-20 12:16:41 -0700466 def start(self, restart = False, network_cfg = None):
A R Karthick928ad622017-01-30 12:18:32 -0800467 if network_cfg is not None:
A R Karthickd44cea12016-07-20 12:16:41 -0700468 json_data = json.dumps(network_cfg, indent=4)
469 with open('{}/network-cfg.json'.format(self.onos_config_dir), 'w') as f:
470 f.write(json_data)
A R Karthick52414732017-01-31 09:59:47 -0800471
472 #we avoid using docker-compose restart for now.
473 #since we don't want to retain the metadata across restarts
A R Karthick03bd2812017-03-03 17:49:17 -0800474 #stop and start and synchronize the services before installing tester cord apps
475 cmds = [ 'cd {} && docker-compose down'.format(self.onos_cord_dir),
476 'cd {} && docker-compose up -d'.format(self.onos_cord_dir),
A R Karthick72fcbc52017-03-06 12:35:17 -0800477 'sleep 60',
A R Karthick03bd2812017-03-03 17:49:17 -0800478 ]
479 for cmd in cmds:
A.R Karthickf184b342017-01-27 19:30:50 -0800480 try:
A R Karthick03bd2812017-03-03 17:49:17 -0800481 print(cmd)
A.R Karthickf184b342017-01-27 19:30:50 -0800482 os.system(cmd)
A R Karthick03bd2812017-03-03 17:49:17 -0800483 except:pass
A R Karthick52414732017-01-31 09:59:47 -0800484
A R Karthick03bd2812017-03-03 17:49:17 -0800485 self.synchronize()
A R Karthick52414732017-01-31 09:59:47 -0800486 ##we could also connect container to default docker network but disabled for now
487 #Container.connect_to_network(self.name, 'bridge')
A R Karthick52414732017-01-31 09:59:47 -0800488 #connect container to the quagga bridge
489 self.connect_to_br(index = 0)
A.R Karthickf184b342017-01-27 19:30:50 -0800490 print('Waiting %d seconds for ONOS instance to start' %self.boot_delay)
A R Karthickbd9b8a32016-07-21 09:56:45 -0700491 time.sleep(self.boot_delay)
A R Karthickd44cea12016-07-20 12:16:41 -0700492
493 def build_image(self):
494 build_cmd = 'cd {} && docker-compose build'.format(self.onos_cord_dir)
495 os.system(build_cmd)
496
A.R Karthickf184b342017-01-27 19:30:50 -0800497 def restore(self, force = False):
498 restore = self.start_wrapper is True or force is True
499 if not restore:
A.R Karthick263d3fc2017-01-27 12:52:53 -0800500 return
A R Karthick394976f2017-01-31 14:25:16 -0800501 #nothing to restore
502 if not os.access(self.docker_yaml_saved, os.F_OK):
503 return
A R Karthick03bd2812017-03-03 17:49:17 -0800504
A.R Karthickf184b342017-01-27 19:30:50 -0800505 #restore the config files back. The synchronizer restore should bring the last config back
506 cmds = ['cd {} && docker-compose down'.format(self.onos_cord_dir),
507 'rm -rf {}'.format(self.onos_config_dir),
508 'mv {} {}'.format(self.docker_yaml_saved, self.docker_yaml),
509 'cd {} && docker-compose up -d'.format(self.onos_cord_dir),
A R Karthick72fcbc52017-03-06 12:35:17 -0800510 'sleep 60',
A.R Karthickf184b342017-01-27 19:30:50 -0800511 ]
512 for cmd in cmds:
A.R Karthickb17e2022017-01-27 11:29:26 -0800513 try:
A.R Karthickf184b342017-01-27 19:30:50 -0800514 print(cmd)
515 os.system(cmd)
A.R Karthickb17e2022017-01-27 11:29:26 -0800516 except: pass
517
A R Karthick03bd2812017-03-03 17:49:17 -0800518 self.synchronize(cfg_unlink = True)
A.R Karthickb17e2022017-01-27 11:29:26 -0800519
A.R Karthick1700e0e2016-10-06 18:16:57 -0700520class OnosCordStopWrapper(Container):
521 onos_cord_dir = os.path.join(os.getenv('HOME'), 'cord-tester-cord')
522 docker_yaml = os.path.join(onos_cord_dir, 'docker-compose.yml')
523
524 def __init__(self):
525 if os.access(self.docker_yaml, os.F_OK):
526 with open(self.docker_yaml, 'r') as f:
527 yaml_config = yaml.load(f)
528 image = yaml_config['services'].keys()[0]
529 name = 'cordtestercord_{}_1'.format(image)
530 super(OnosCordStopWrapper, self).__init__(name, image, tag = '')
531 if self.exists():
532 print('Killing container %s' %self.name)
533 self.kill()
534
Chetan Gaonker3533faa2016-04-25 17:50:14 -0700535class Onos(Container):
A R Karthickaa54a1c2016-12-15 11:42:08 -0800536 QUAGGA_CONFIG = [ { 'bridge' : 'quagga-br', 'ip': '10.10.0.4', 'mask' : 16 }, ]
A R Karthicka2492c12016-12-16 10:31:51 -0800537 MAX_INSTANCES = 3
A R Karthickc69d73e2017-01-20 11:44:34 -0800538 JVM_HEAP_SIZE = None
Chetan Gaonker462d9fa2016-05-03 16:39:10 -0700539 SYSTEM_MEMORY = (get_mem(),) * 2
A R Karthicka2492c12016-12-16 10:31:51 -0800540 INSTANCE_MEMORY = (get_mem(instances=MAX_INSTANCES),) * 2
A R Karthickc69d73e2017-01-20 11:44:34 -0800541 JAVA_OPTS_FORMAT = '-Xms{} -Xmx{} -XX:+UseConcMarkSweepGC -XX:+CMSIncrementalMode'
542 JAVA_OPTS_DEFAULT = JAVA_OPTS_FORMAT.format(*SYSTEM_MEMORY) #-XX:+PrintGCDetails -XX:+PrintGCTimeStamps'
543 JAVA_OPTS_CLUSTER_DEFAULT = JAVA_OPTS_FORMAT.format(*INSTANCE_MEMORY)
544 env = { 'ONOS_APPS' : 'drivers,openflow,proxyarp,vrouter', 'JAVA_OPTS' : JAVA_OPTS_DEFAULT }
A.R Karthickdfeadb02016-11-30 17:55:51 -0800545 onos_cord_apps = ( ('cord-config', '1.1-SNAPSHOT'),
A R Karthicka652c4a2017-03-10 17:47:08 -0800546 ('aaa', '1.2-SNAPSHOT'),
A.R Karthickdfeadb02016-11-30 17:55:51 -0800547 ('igmp', '1.1-SNAPSHOT'),
548 #('vtn', '1.1-SNAPSHOT'),
A.R Karthick95d044e2016-06-10 18:44:36 -0700549 )
A.R Karthickdda22062017-02-09 14:39:20 -0800550 ports = [] #[ 8181, 8101, 9876, 6653, 6633, 2000, 2620, 5005 ]
A R Karthickf2f4ca62016-08-17 10:34:08 -0700551 setup_dir = os.path.join(os.path.dirname(os.path.realpath(__file__)), '..', 'setup')
552 host_config_dir = os.path.join(setup_dir, 'onos-config')
Chetan Gaonker3533faa2016-04-25 17:50:14 -0700553 guest_config_dir = '/root/onos/config'
A.R Karthickdda22062017-02-09 14:39:20 -0800554 guest_data_dir = '/root/onos/apache-karaf-3.0.8/data'
555 guest_log_file = '/root/onos/apache-karaf-3.0.8/data/log/karaf.log'
A R Karthickf2f4ca62016-08-17 10:34:08 -0700556 onos_gen_partitions = os.path.join(setup_dir, 'onos-gen-partitions')
A R Karthick2b93d6a2016-09-06 15:19:09 -0700557 onos_form_cluster = os.path.join(setup_dir, 'onos-form-cluster')
A.R Karthick95d044e2016-06-10 18:44:36 -0700558 cord_apps_dir = os.path.join(os.path.dirname(os.path.realpath(__file__)), '..', 'apps')
Chetan Gaonker3533faa2016-04-25 17:50:14 -0700559 host_guest_map = ( (host_config_dir, guest_config_dir), )
A R Karthick2b93d6a2016-09-06 15:19:09 -0700560 cluster_cfg = os.path.join(host_config_dir, 'cluster.json')
561 cluster_mode = False
562 cluster_instances = []
Chetan Gaonker503032a2016-05-12 12:06:29 -0700563 NAME = 'cord-onos'
A R Karthickf2f4ca62016-08-17 10:34:08 -0700564 ##the ip of ONOS in default cluster.json in setup/onos-config
565 CLUSTER_CFG_IP = '172.17.0.2'
A R Karthick07608ef2016-08-23 16:51:19 -0700566 IMAGE = 'onosproject/onos'
567 TAG = 'latest'
568 PREFIX = ''
A R Karthickf2f4ca62016-08-17 10:34:08 -0700569
570 @classmethod
A R Karthick2b93d6a2016-09-06 15:19:09 -0700571 def generate_cluster_cfg(cls, ip):
572 if type(ip) in [ list, tuple ]:
573 ips = ' '.join(ip)
574 else:
575 ips = ip
A R Karthickf2f4ca62016-08-17 10:34:08 -0700576 try:
A R Karthick2b93d6a2016-09-06 15:19:09 -0700577 cmd = '{} {} {}'.format(cls.onos_gen_partitions, cls.cluster_cfg, ips)
578 os.system(cmd)
579 except: pass
580
581 @classmethod
582 def form_cluster(cls, ips):
583 nodes = ' '.join(ips)
584 try:
585 cmd = '{} {}'.format(cls.onos_form_cluster, nodes)
A R Karthickf2f4ca62016-08-17 10:34:08 -0700586 os.system(cmd)
587 except: pass
Chetan Gaonker3533faa2016-04-25 17:50:14 -0700588
A R Karthick9d48c652016-09-15 09:16:36 -0700589 @classmethod
590 def cleanup_runtime(cls):
591 '''Cleanup ONOS runtime generated files'''
592 files = ( Onos.cluster_cfg, os.path.join(Onos.host_config_dir, 'network-cfg.json') )
593 for f in files:
594 if os.access(f, os.F_OK):
595 try:
596 os.unlink(f)
597 except: pass
598
A R Karthickec2db322016-11-17 15:06:01 -0800599 @classmethod
600 def get_data_map(cls, host_volume, guest_volume_dir):
601 host_volume_dir = os.path.join(cls.setup_dir, os.path.basename(host_volume))
602 if not os.path.exists(host_volume_dir):
603 os.mkdir(host_volume_dir)
604 return ( (host_volume_dir, guest_volume_dir), )
605
606 @classmethod
607 def remove_data_map(cls, host_volume, guest_volume_dir):
608 host_volume_dir = os.path.join(cls.setup_dir, os.path.basename(host_volume))
609 if os.path.exists(host_volume_dir):
A.R Karthickf184b342017-01-27 19:30:50 -0800610 shutil.rmtree(host_volume_dir)
A R Karthickec2db322016-11-17 15:06:01 -0800611
A R Karthick973010f2017-02-06 16:41:51 -0800612 @classmethod
613 def update_data_dir(cls, karaf):
614 Onos.guest_data_dir = '/root/onos/apache-karaf-{}/data'.format(karaf)
615 Onos.guest_log_file = '/root/onos/apache-karaf-{}/data/log/karaf.log'.format(karaf)
616
A R Karthickec2db322016-11-17 15:06:01 -0800617 def remove_data_volume(self):
618 if self.data_map is not None:
619 self.remove_data_map(*self.data_map)
620
A.R Karthick1700e0e2016-10-06 18:16:57 -0700621 def __init__(self, name = NAME, image = IMAGE, prefix = PREFIX, tag = TAG,
A R Karthickec2db322016-11-17 15:06:01 -0800622 boot_delay = 20, restart = False, network_cfg = None,
A R Karthick85eb1862017-01-23 16:10:57 -0800623 cluster = False, data_volume = None, async = False, quagga_config = None,
624 network = None):
Chetan Gaonker3533faa2016-04-25 17:50:14 -0700625 if restart is True:
626 ##Find the right image to restart
627 running_image = filter(lambda c: c['Names'][0] == '/{}'.format(name), self.dckr.containers())
628 if running_image:
629 image_name = running_image[0]['Image']
630 try:
631 image = image_name.split(':')[0]
632 tag = image_name.split(':')[1]
633 except: pass
634
A R Karthickaa54a1c2016-12-15 11:42:08 -0800635 if quagga_config is None:
636 quagga_config = Onos.QUAGGA_CONFIG
637 super(Onos, self).__init__(name, image, prefix = prefix, tag = tag, quagga_config = quagga_config)
A R Karthick2b93d6a2016-09-06 15:19:09 -0700638 self.boot_delay = boot_delay
A R Karthickec2db322016-11-17 15:06:01 -0800639 self.data_map = None
A R Karthickc69d73e2017-01-20 11:44:34 -0800640 instance_memory = (get_mem(jvm_heap_size = Onos.JVM_HEAP_SIZE, instances = Onos.MAX_INSTANCES),) * 2
641 self.env['JAVA_OPTS'] = self.JAVA_OPTS_FORMAT.format(*instance_memory)
A R Karthick2b93d6a2016-09-06 15:19:09 -0700642 if cluster is True:
643 self.ports = []
A R Karthickec2db322016-11-17 15:06:01 -0800644 if data_volume is not None:
645 self.data_map = self.get_data_map(data_volume, self.guest_data_dir)
646 self.host_guest_map = self.host_guest_map + self.data_map
A R Karthick2b93d6a2016-09-06 15:19:09 -0700647 if os.access(self.cluster_cfg, os.F_OK):
648 try:
649 os.unlink(self.cluster_cfg)
650 except: pass
651
652 self.host_config = self.create_host_config(port_list = self.ports,
653 host_guest_map = self.host_guest_map)
654 self.volumes = []
655 for _,g in self.host_guest_map:
656 self.volumes.append(g)
657
Chetan Gaonker3533faa2016-04-25 17:50:14 -0700658 if restart is True and self.exists():
659 self.kill()
A R Karthick2b93d6a2016-09-06 15:19:09 -0700660
Chetan Gaonker3533faa2016-04-25 17:50:14 -0700661 if not self.exists():
662 self.remove_container(name, force=True)
ChetanGaonker2c0e9bb2016-09-21 13:38:37 -0700663 host_config = self.create_host_config(port_list = self.ports,
664 host_guest_map = self.host_guest_map)
665 volumes = []
666 for _,g in self.host_guest_map:
667 volumes.append(g)
Chetan Gaonker3533faa2016-04-25 17:50:14 -0700668 if network_cfg is not None:
A R Karthick81acbff2016-06-17 14:45:16 -0700669 json_data = json.dumps(network_cfg, indent=4)
Chetan Gaonker3533faa2016-04-25 17:50:14 -0700670 with open('{}/network-cfg.json'.format(self.host_config_dir), 'w') as f:
671 f.write(json_data)
A.R Karthickc4e474d2016-12-12 15:24:57 -0800672 if cluster is False or async is False:
673 print('Starting ONOS container %s' %self.name)
674 self.start(ports = self.ports, environment = self.env,
675 host_config = self.host_config, volumes = self.volumes, tty = True)
676 if not restart:
677 ##wait a bit before fetching IP to regenerate cluster cfg
678 time.sleep(5)
679 ip = self.ip()
680 ##Just a quick hack/check to ensure we don't regenerate in the common case.
681 ##As ONOS is usually the first test container that is started
682 if cluster is False:
683 if ip != self.CLUSTER_CFG_IP or not os.access(self.cluster_cfg, os.F_OK):
684 print('Regenerating ONOS cluster cfg for ip %s' %ip)
685 self.generate_cluster_cfg(ip)
686 self.kill()
687 self.remove_container(self.name, force=True)
688 print('Restarting ONOS container %s' %self.name)
689 self.start(ports = self.ports, environment = self.env,
690 host_config = self.host_config, volumes = self.volumes, tty = True)
691 print('Waiting for ONOS to boot')
692 time.sleep(boot_delay)
693 self.wait_for_onos_start(self.ip())
694 self.running = True
695 else:
696 self.running = False
697 else:
698 self.running = True
699 if self.running:
700 self.ipaddr = self.ip()
701 if cluster is False:
702 self.install_cord_apps(self.ipaddr)
A R Karthick19aaf5c2016-11-09 17:47:57 -0800703
A.R Karthickc4e474d2016-12-12 15:24:57 -0800704 @classmethod
705 def get_quagga_config(cls, instance = 0):
A R Karthickaa54a1c2016-12-15 11:42:08 -0800706 quagga_config = copy.deepcopy(cls.QUAGGA_CONFIG)
A.R Karthickc4e474d2016-12-12 15:24:57 -0800707 if instance == 0:
708 return quagga_config
709 ip = quagga_config[0]['ip']
710 octets = ip.split('.')
A R Karthickaa54a1c2016-12-15 11:42:08 -0800711 octets[3] = str((int(octets[3]) + instance) & 255)
A.R Karthickc4e474d2016-12-12 15:24:57 -0800712 ip = '.'.join(octets)
713 quagga_config[0]['ip'] = ip
714 return quagga_config
715
716 @classmethod
717 def start_cluster_async(cls, onos_instances):
718 instances = filter(lambda o: o.running == False, onos_instances)
719 if not instances:
720 return
721 tpool = ThreadPool(len(instances), queue_size = 1, wait_timeout = 1)
722 for onos in instances:
723 tpool.addTask(onos.start_async)
724 tpool.cleanUpThreads()
725
726 def start_async(self):
727 print('Starting ONOS container %s' %self.name)
728 self.start(ports = self.ports, environment = self.env,
729 host_config = self.host_config, volumes = self.volumes, tty = True)
730 time.sleep(3)
A R Karthick2b93d6a2016-09-06 15:19:09 -0700731 self.ipaddr = self.ip()
A.R Karthickc4e474d2016-12-12 15:24:57 -0800732 print('Waiting for ONOS container %s to start' %self.name)
733 self.wait_for_onos_start(self.ipaddr)
734 self.running = True
735 print('ONOS container %s started' %self.name)
Chetan Gaonker3533faa2016-04-25 17:50:14 -0700736
A R Karthick2b93d6a2016-09-06 15:19:09 -0700737 @classmethod
A R Karthick19aaf5c2016-11-09 17:47:57 -0800738 def wait_for_onos_start(cls, ip, tries = 30):
A R Karthick973010f2017-02-06 16:41:51 -0800739 onos_log = OnosLog(host = ip, log_file = Onos.guest_log_file)
A R Karthick19aaf5c2016-11-09 17:47:57 -0800740 num_tries = 0
741 started = None
742 while not started and num_tries < tries:
743 time.sleep(3)
744 started = onos_log.search_log_pattern('ApplicationManager .* Started')
745 num_tries += 1
746
A R Karthick19aaf5c2016-11-09 17:47:57 -0800747 if not started:
748 print('ONOS did not start')
749 else:
750 print('ONOS started')
751 return started
752
753 @classmethod
A R Karthick2b93d6a2016-09-06 15:19:09 -0700754 def setup_cluster_deprecated(cls, onos_instances, image_name = None):
755 if not onos_instances or len(onos_instances) < 2:
756 return
757 ips = []
758 if image_name is not None:
759 ips = Container.ips(image_name)
760 else:
761 for onos in onos_instances:
762 ips.append(onos.ipaddr)
763 Onos.cluster_instances = onos_instances
764 Onos.cluster_mode = True
765 ##regenerate the cluster json with the 3 instance ips before restarting them back
766 print('Generating cluster cfg for ONOS instances with ips %s' %ips)
767 Onos.generate_cluster_cfg(ips)
768 for onos in onos_instances:
769 onos.kill()
770 onos.remove_container(onos.name, force=True)
771 print('Restarting ONOS container %s for forming cluster' %onos.name)
772 onos.start(ports = onos.ports, environment = onos.env,
773 host_config = onos.host_config, volumes = onos.volumes, tty = True)
774 print('Waiting %d seconds for ONOS %s to boot' %(onos.boot_delay, onos.name))
775 time.sleep(onos.boot_delay)
776 onos.ipaddr = onos.ip()
777 onos.install_cord_apps(onos.ipaddr)
778
779 @classmethod
780 def setup_cluster(cls, onos_instances, image_name = None):
781 if not onos_instances or len(onos_instances) < 2:
782 return
783 ips = []
784 if image_name is not None:
785 ips = Container.ips(image_name)
786 else:
787 for onos in onos_instances:
788 ips.append(onos.ipaddr)
789 Onos.cluster_instances = onos_instances
790 Onos.cluster_mode = True
791 ##regenerate the cluster json with the 3 instance ips before restarting them back
792 print('Forming cluster for ONOS instances with ips %s' %ips)
793 Onos.form_cluster(ips)
794 ##wait for the cluster to be formed
795 print('Waiting for the cluster to be formed')
796 time.sleep(60)
797 for onos in onos_instances:
798 onos.install_cord_apps(onos.ipaddr)
799
800 @classmethod
A R Karthicke2c24bd2016-10-07 14:51:38 -0700801 def add_cluster(cls, count = 1, network_cfg = None):
802 if not cls.cluster_instances or Onos.cluster_mode is False:
803 return
804 for i in range(count):
805 name = '{}-{}'.format(Onos.NAME, len(cls.cluster_instances)+1)
806 onos = cls(name = name, image = Onos.IMAGE, tag = Onos.TAG, prefix = Container.IMAGE_PREFIX,
807 cluster = True, network_cfg = network_cfg)
808 cls.cluster_instances.append(onos)
809
810 cls.setup_cluster(cls.cluster_instances)
811
812 @classmethod
A.R Karthick2560f042016-11-30 14:38:52 -0800813 def restart_cluster(cls, network_cfg = None, timeout = 10, setup = False):
A R Karthick2b93d6a2016-09-06 15:19:09 -0700814 if cls.cluster_mode is False:
815 return
816 if not cls.cluster_instances:
817 return
818
819 if network_cfg is not None:
820 json_data = json.dumps(network_cfg, indent=4)
821 with open('{}/network-cfg.json'.format(cls.host_config_dir), 'w') as f:
822 f.write(json_data)
823
A.R Karthick2560f042016-11-30 14:38:52 -0800824 cls.cleanup_cluster()
825 if timeout > 0:
826 time.sleep(timeout)
827
A R Karthickaa54a1c2016-12-15 11:42:08 -0800828 #start the instances asynchronously
829 cls.start_cluster_async(cls.cluster_instances)
830 time.sleep(5)
A.R Karthick2560f042016-11-30 14:38:52 -0800831 ##form the cluster as appropriate
832 if setup is True:
833 cls.setup_cluster(cls.cluster_instances)
A R Karthickaa54a1c2016-12-15 11:42:08 -0800834 else:
835 for onos in cls.cluster_instances:
836 onos.install_cord_apps(onos.ipaddr)
A R Karthick2b93d6a2016-09-06 15:19:09 -0700837
838 @classmethod
839 def cluster_ips(cls):
840 if cls.cluster_mode is False:
841 return []
842 if not cls.cluster_instances:
843 return []
844 ips = [ onos.ipaddr for onos in cls.cluster_instances ]
845 return ips
846
847 @classmethod
848 def cleanup_cluster(cls):
849 if cls.cluster_mode is False:
850 return
851 if not cls.cluster_instances:
852 return
853 for onos in cls.cluster_instances:
854 if onos.exists():
855 onos.kill()
A R Karthickaa54a1c2016-12-15 11:42:08 -0800856 onos.running = False
A R Karthick2b93d6a2016-09-06 15:19:09 -0700857 onos.remove_container(onos.name, force=True)
A R Karthickd44cea12016-07-20 12:16:41 -0700858
A.R Karthick95d044e2016-06-10 18:44:36 -0700859 @classmethod
A R Karthickde6b9dc2016-11-29 17:46:16 -0800860 def restart_node(cls, node = None, network_cfg = None, timeout = 10):
A R Karthick889d9652016-10-03 14:13:45 -0700861 if node is None:
862 cls(restart = True, network_cfg = network_cfg, image = cls.IMAGE, tag = cls.TAG)
863 else:
864 #Restarts a node in the cluster
865 valid_node = filter(lambda onos: node in [ onos.ipaddr, onos.name ], cls.cluster_instances)
866 if valid_node:
867 onos = valid_node.pop()
868 if onos.exists():
869 onos.kill()
870 onos.remove_container(onos.name, force=True)
A R Karthickde6b9dc2016-11-29 17:46:16 -0800871 if timeout > 0:
872 time.sleep(timeout)
A R Karthick889d9652016-10-03 14:13:45 -0700873 print('Restarting ONOS container %s' %onos.name)
874 onos.start(ports = onos.ports, environment = onos.env,
875 host_config = onos.host_config, volumes = onos.volumes, tty = True)
A R Karthick889d9652016-10-03 14:13:45 -0700876 onos.ipaddr = onos.ip()
A.R Karthick2560f042016-11-30 14:38:52 -0800877 onos.wait_for_onos_start(onos.ipaddr)
878 onos.install_cord_apps(onos.ipaddr)
A R Karthick889d9652016-10-03 14:13:45 -0700879
880 @classmethod
A R Karthickeaf1c4e2016-07-19 12:22:35 -0700881 def install_cord_apps(cls, onos_ip = None):
A.R Karthick95d044e2016-06-10 18:44:36 -0700882 for app, version in cls.onos_cord_apps:
883 app_file = '{}/{}-{}.oar'.format(cls.cord_apps_dir, app, version)
A R Karthickeaf1c4e2016-07-19 12:22:35 -0700884 ok, code = OnosCtrl.install_app(app_file, onos_ip = onos_ip)
A.R Karthick95d044e2016-06-10 18:44:36 -0700885 ##app already installed (conflicts)
886 if code in [ 409 ]:
887 ok = True
888 print('ONOS app %s, version %s %s' %(app, version, 'installed' if ok else 'failed to install'))
889 time.sleep(2)
890
A.R Karthick1700e0e2016-10-06 18:16:57 -0700891class OnosStopWrapper(Container):
892 def __init__(self, name):
893 super(OnosStopWrapper, self).__init__(name, Onos.IMAGE, tag = Onos.TAG, prefix = Container.IMAGE_PREFIX)
894 if self.exists():
895 self.kill()
A R Karthickaa54a1c2016-12-15 11:42:08 -0800896 self.running = False
A.R Karthick1700e0e2016-10-06 18:16:57 -0700897 else:
898 if Onos.cluster_mode is True:
899 valid_node = filter(lambda onos: name in [ onos.ipaddr, onos.name ], Onos.cluster_instances)
900 if valid_node:
901 onos = valid_node.pop()
902 if onos.exists():
903 onos.kill()
A R Karthickaa54a1c2016-12-15 11:42:08 -0800904 onos.running = False
A.R Karthick1700e0e2016-10-06 18:16:57 -0700905
Chetan Gaonker3533faa2016-04-25 17:50:14 -0700906class Radius(Container):
907 ports = [ 1812, 1813 ]
A R Karthick41adfce2016-06-10 09:51:25 -0700908 env = {'TIMEZONE':'America/Los_Angeles',
Chetan Gaonker3533faa2016-04-25 17:50:14 -0700909 'DEBUG': 'true', 'cert_password':'whatever', 'primary_shared_secret':'radius_password'
910 }
Chetan Gaonker7f4bf742016-05-04 15:56:08 -0700911 host_db_dir = os.path.join(os.path.dirname(os.path.realpath(__file__)), '..', 'setup/radius-config/db')
Chetan Gaonker3533faa2016-04-25 17:50:14 -0700912 guest_db_dir = os.path.join(os.path.sep, 'opt', 'db')
Chetan Gaonker7f4bf742016-05-04 15:56:08 -0700913 host_config_dir = os.path.join(os.path.dirname(os.path.realpath(__file__)), '..', 'setup/radius-config/freeradius')
Chetan Gaonker3533faa2016-04-25 17:50:14 -0700914 guest_config_dir = os.path.join(os.path.sep, 'etc', 'freeradius')
Chetan Gaonker7f4bf742016-05-04 15:56:08 -0700915 start_command = os.path.join(guest_config_dir, 'start-radius.py')
Chetan Gaonker3533faa2016-04-25 17:50:14 -0700916 host_guest_map = ( (host_db_dir, guest_db_dir),
917 (host_config_dir, guest_config_dir)
918 )
A R Karthickf7a613b2017-02-24 09:36:44 -0800919 IMAGE = 'cordtest/radius'
Chetan Gaonker503032a2016-05-12 12:06:29 -0700920 NAME = 'cord-radius'
921
A R Karthick07608ef2016-08-23 16:51:19 -0700922 def __init__(self, name = NAME, image = IMAGE, prefix = '', tag = 'candidate',
A R Karthick85eb1862017-01-23 16:10:57 -0800923 boot_delay = 10, restart = False, update = False, network = None):
A R Karthick07608ef2016-08-23 16:51:19 -0700924 super(Radius, self).__init__(name, image, prefix = prefix, tag = tag, command = self.start_command)
Chetan Gaonker503032a2016-05-12 12:06:29 -0700925 if update is True or not self.img_exists():
A R Karthick07608ef2016-08-23 16:51:19 -0700926 self.build_image(self.image_name)
Chetan Gaonker7f4bf742016-05-04 15:56:08 -0700927 if restart is True and self.exists():
928 self.kill()
Chetan Gaonker3533faa2016-04-25 17:50:14 -0700929 if not self.exists():
930 self.remove_container(name, force=True)
931 host_config = self.create_host_config(port_list = self.ports,
932 host_guest_map = self.host_guest_map)
933 volumes = []
934 for _,g in self.host_guest_map:
935 volumes.append(g)
A R Karthick41adfce2016-06-10 09:51:25 -0700936 self.start(ports = self.ports, environment = self.env,
937 volumes = volumes,
Chetan Gaonker3533faa2016-04-25 17:50:14 -0700938 host_config = host_config, tty = True)
A R Karthick85eb1862017-01-23 16:10:57 -0800939 if network is not None:
940 Container.connect_to_network(self.name, network)
Chetan Gaonker7f4bf742016-05-04 15:56:08 -0700941 time.sleep(boot_delay)
942
943 @classmethod
944 def build_image(cls, image):
945 print('Building Radius image %s' %image)
946 dockerfile = '''
947FROM hbouvier/docker-radius
948MAINTAINER chetan@ciena.com
949LABEL RUN docker pull hbouvier/docker-radius
950LABEL RUN docker run -it --name cord-radius hbouvier/docker-radius
A R Karthickc762df42016-05-25 10:09:21 -0700951RUN apt-get update && \
952 apt-get -y install python python-pexpect strace
Chetan Gaonker7f4bf742016-05-04 15:56:08 -0700953WORKDIR /root
954CMD ["/etc/freeradius/start-radius.py"]
955'''
956 super(Radius, cls).build_image(dockerfile, image)
957 print('Done building image %s' %image)
Chetan Gaonker3533faa2016-04-25 17:50:14 -0700958
Chetan Gaonker6cf6e472016-04-26 14:41:51 -0700959class Quagga(Container):
A R Karthickaa54a1c2016-12-15 11:42:08 -0800960 QUAGGA_CONFIG = ( { 'bridge' : 'quagga-br', 'ip': '10.10.0.3', 'mask' : 16 },
Chetan Gaonker8e25e1b2016-05-02 13:42:21 -0700961 { 'bridge' : 'quagga-br', 'ip': '192.168.10.3', 'mask': 16 },
962 )
Chetan Gaonker6cf6e472016-04-26 14:41:51 -0700963 ports = [ 179, 2601, 2602, 2603, 2604, 2605, 2606 ]
964 host_quagga_config = os.path.join(os.path.dirname(os.path.realpath(__file__)), '..', 'setup/quagga-config')
965 guest_quagga_config = '/root/config'
966 quagga_config_file = os.path.join(guest_quagga_config, 'testrib.conf')
967 host_guest_map = ( (host_quagga_config, guest_quagga_config), )
A R Karthickf7a613b2017-02-24 09:36:44 -0800968 IMAGE = 'cordtest/quagga'
Chetan Gaonker503032a2016-05-12 12:06:29 -0700969 NAME = 'cord-quagga'
970
A R Karthick07608ef2016-08-23 16:51:19 -0700971 def __init__(self, name = NAME, image = IMAGE, prefix = '', tag = 'candidate',
A R Karthick85eb1862017-01-23 16:10:57 -0800972 boot_delay = 15, restart = False, config_file = quagga_config_file, update = False,
973 network = None):
A R Karthickaa54a1c2016-12-15 11:42:08 -0800974 super(Quagga, self).__init__(name, image, prefix = prefix, tag = tag, quagga_config = self.QUAGGA_CONFIG)
Chetan Gaonker503032a2016-05-12 12:06:29 -0700975 if update is True or not self.img_exists():
A R Karthick07608ef2016-08-23 16:51:19 -0700976 self.build_image(self.image_name)
Chetan Gaonker6cf6e472016-04-26 14:41:51 -0700977 if restart is True and self.exists():
978 self.kill()
979 if not self.exists():
980 self.remove_container(name, force=True)
A R Karthick41adfce2016-06-10 09:51:25 -0700981 host_config = self.create_host_config(port_list = self.ports,
982 host_guest_map = self.host_guest_map,
Chetan Gaonker6cf6e472016-04-26 14:41:51 -0700983 privileged = True)
984 volumes = []
985 for _,g in self.host_guest_map:
986 volumes.append(g)
987 self.start(ports = self.ports,
A R Karthick41adfce2016-06-10 09:51:25 -0700988 host_config = host_config,
Chetan Gaonker6cf6e472016-04-26 14:41:51 -0700989 volumes = volumes, tty = True)
A R Karthick85eb1862017-01-23 16:10:57 -0800990 if network is not None:
991 Container.connect_to_network(self.name, network)
Chetan Gaonker6cf6e472016-04-26 14:41:51 -0700992 print('Starting Quagga on container %s' %self.name)
993 self.execute('{0}/start.sh {1}'.format(self.guest_quagga_config, config_file))
994 time.sleep(boot_delay)
995
996 @classmethod
997 def build_image(cls, image):
A R Karthickaa54a1c2016-12-15 11:42:08 -0800998 onos_quagga_ip = Onos.QUAGGA_CONFIG[0]['ip']
Chetan Gaonker6cf6e472016-04-26 14:41:51 -0700999 print('Building Quagga image %s' %image)
1000 dockerfile = '''
A R Karthick41adfce2016-06-10 09:51:25 -07001001FROM ubuntu:14.04
1002MAINTAINER chetan@ciena.com
Chetan Gaonker6cf6e472016-04-26 14:41:51 -07001003WORKDIR /root
1004RUN useradd -M quagga
1005RUN mkdir /var/log/quagga && chown quagga:quagga /var/log/quagga
1006RUN mkdir /var/run/quagga && chown quagga:quagga /var/run/quagga
A R Karthick973ea692016-10-17 12:23:02 -07001007RUN apt-get update && apt-get install -qy git autoconf libtool gawk make telnet libreadline6-dev pkg-config protobuf-c-compiler
ChetanGaonkerb5b46c62016-08-16 12:02:53 -07001008RUN git clone git://git.savannah.nongnu.org/quagga.git quagga && \
A R Karthick8f69c2c2016-10-21 11:43:26 -07001009(cd quagga && git checkout quagga-1.0.20160315 && ./bootstrap.sh && \
Chetan Gaonker6cf6e472016-04-26 14:41:51 -07001010sed -i -r 's,htonl.*?\(INADDR_LOOPBACK\),inet_addr\("{0}"\),g' zebra/zebra_fpm.c && \
1011./configure --enable-fpm --disable-doc --localstatedir=/var/run/quagga && make && make install)
1012RUN ldconfig
1013'''.format(onos_quagga_ip)
1014 super(Quagga, cls).build_image(dockerfile, image)
1015 print('Done building image %s' %image)
A R Karthick81acbff2016-06-17 14:45:16 -07001016
A.R Karthick1700e0e2016-10-06 18:16:57 -07001017class QuaggaStopWrapper(Container):
1018 def __init__(self, name = Quagga.NAME, image = Quagga.IMAGE, tag = 'candidate'):
1019 super(QuaggaStopWrapper, self).__init__(name, image, prefix = Container.IMAGE_PREFIX, tag = tag)
1020 if self.exists():
1021 self.kill()
1022
1023
A R Karthick81acbff2016-06-17 14:45:16 -07001024def reinitContainerClients():
1025 docker_netns.dckr = Client()
1026 Container.dckr = Client()
ChetanGaonker2c0e9bb2016-09-21 13:38:37 -07001027
1028class Xos(Container):
1029 setup_dir = os.path.join(os.path.dirname(os.path.realpath(__file__)), '..', 'setup')
1030 TAG = 'latest'
1031 PREFIX = ''
A R Karthicke3bde962016-09-27 15:06:35 -07001032 host_guest_map = None
1033 env = None
1034 ports = None
1035 volumes = None
ChetanGaonker2c0e9bb2016-09-21 13:38:37 -07001036
A R Karthick6e80afd2016-10-10 16:03:12 -07001037 @classmethod
1038 def get_cmd(cls, img_name):
1039 cmd = cls.dckr.inspect_image(img_name)['Config']['Cmd']
1040 return ' '.join(cmd)
1041
A R Karthicke3bde962016-09-27 15:06:35 -07001042 def __init__(self, name, image, prefix = PREFIX, tag = TAG,
A R Karthick6e80afd2016-10-10 16:03:12 -07001043 boot_delay = 20, restart = False, network_cfg = None, update = False):
ChetanGaonker2c0e9bb2016-09-21 13:38:37 -07001044 if restart is True:
1045 ##Find the right image to restart
1046 running_image = filter(lambda c: c['Names'][0] == '/{}'.format(name), self.dckr.containers())
1047 if running_image:
1048 image_name = running_image[0]['Image']
1049 try:
1050 image = image_name.split(':')[0]
1051 tag = image_name.split(':')[1]
1052 except: pass
ChetanGaonker2c0e9bb2016-09-21 13:38:37 -07001053 super(Xos, self).__init__(name, image, prefix = prefix, tag = tag)
1054 if update is True or not self.img_exists():
1055 self.build_image(self.image_name)
A R Karthick6e80afd2016-10-10 16:03:12 -07001056 self.command = self.get_cmd(self.image_name).strip() or None
ChetanGaonker2c0e9bb2016-09-21 13:38:37 -07001057 if restart is True and self.exists():
1058 self.kill()
1059 if not self.exists():
1060 self.remove_container(name, force=True)
A R Karthicke3bde962016-09-27 15:06:35 -07001061 host_config = self.create_host_config(port_list = self.ports,
1062 host_guest_map = self.host_guest_map,
1063 privileged = True)
1064 print('Starting XOS container %s' %self.name)
1065 self.start(ports = self.ports, environment = self.env, host_config = host_config,
1066 volumes = self.volumes, tty = True)
1067 print('Waiting %d seconds for XOS Base Container to boot' %(boot_delay))
ChetanGaonker2c0e9bb2016-09-21 13:38:37 -07001068 time.sleep(boot_delay)
1069
1070 @classmethod
A R Karthicke3bde962016-09-27 15:06:35 -07001071 def build_image(cls, image, dockerfile_path, image_target = 'build'):
1072 cmd = 'cd {} && make {}'.format(dockerfile_path, image_target)
1073 print('Building XOS %s' %image)
1074 res = os.system(cmd)
1075 print('Done building image %s. Image build %s' %(image, 'successful' if res == 0 else 'failed'))
1076 return res
ChetanGaonker2c0e9bb2016-09-21 13:38:37 -07001077
A R Karthicke3bde962016-09-27 15:06:35 -07001078class XosServer(Xos):
1079 ports = [8000,9998,9999]
1080 NAME = 'xos-server'
ChetanGaonker2c0e9bb2016-09-21 13:38:37 -07001081 IMAGE = 'xosproject/xos'
A R Karthicke3bde962016-09-27 15:06:35 -07001082 BASE_IMAGE = 'xosproject/xos-base'
ChetanGaonker2c0e9bb2016-09-21 13:38:37 -07001083 TAG = 'latest'
1084 PREFIX = ''
A R Karthicke3bde962016-09-27 15:06:35 -07001085 dockerfile_path = os.path.join(Xos.setup_dir, 'xos')
ChetanGaonker2c0e9bb2016-09-21 13:38:37 -07001086
A R Karthicke3bde962016-09-27 15:06:35 -07001087 def __init__(self, name = NAME, image = IMAGE, prefix = PREFIX, tag = TAG,
A R Karthick6e80afd2016-10-10 16:03:12 -07001088 boot_delay = 10, restart = False, network_cfg = None, update = False):
A R Karthicke3bde962016-09-27 15:06:35 -07001089 Xos.__init__(self, name, image, prefix, tag, boot_delay, restart, network_cfg, update)
ChetanGaonker2c0e9bb2016-09-21 13:38:37 -07001090
1091 @classmethod
A R Karthicke3bde962016-09-27 15:06:35 -07001092 def build_image(cls, image = IMAGE):
1093 ##build the base image and then build the server image
1094 Xos.build_image(cls.BASE_IMAGE, cls.dockerfile_path, image_target = 'base')
1095 Xos.build_image(image, cls.dockerfile_path)
ChetanGaonker2c0e9bb2016-09-21 13:38:37 -07001096
A R Karthicke3bde962016-09-27 15:06:35 -07001097class XosSynchronizerOpenstack(Xos):
1098 ports = [2375,]
1099 dockerfile_path = os.path.join(Xos.setup_dir, 'synchronizer')
1100 NAME = 'xos-synchronizer'
1101 IMAGE = 'xosproject/xos-synchronizer-openstack'
ChetanGaonker2c0e9bb2016-09-21 13:38:37 -07001102 TAG = 'latest'
1103 PREFIX = ''
A R Karthicke3bde962016-09-27 15:06:35 -07001104 host_guest_map = ( ('/usr/local/share/ca-certificates', '/usr/local/share/ca-certificates'),)
ChetanGaonker2c0e9bb2016-09-21 13:38:37 -07001105
A R Karthicke3bde962016-09-27 15:06:35 -07001106 def __init__(self, name = NAME, image = IMAGE, prefix = PREFIX,
A R Karthick6e80afd2016-10-10 16:03:12 -07001107 tag = TAG, boot_delay = 20, restart = False, network_cfg = None, update = False):
A R Karthicke3bde962016-09-27 15:06:35 -07001108 Xos.__init__(self, name, image, prefix, tag, boot_delay, restart, network_cfg, update)
ChetanGaonker2c0e9bb2016-09-21 13:38:37 -07001109
1110 @classmethod
A R Karthicke3bde962016-09-27 15:06:35 -07001111 def build_image(cls, image = IMAGE):
1112 XosServer.build_image()
1113 Xos.build_image(image, cls.dockerfile_path)
ChetanGaonker2c0e9bb2016-09-21 13:38:37 -07001114
A R Karthicke3bde962016-09-27 15:06:35 -07001115class XosSynchronizerOnboarding(Xos):
ChetanGaonker2c0e9bb2016-09-21 13:38:37 -07001116 NAME = 'xos-synchronizer-onboarding'
1117 IMAGE = 'xosproject/xos-synchronizer-onboarding'
1118 TAG = 'latest'
1119 PREFIX = ''
A R Karthicke3bde962016-09-27 15:06:35 -07001120 dockerfile_path = os.path.join(Xos.setup_dir, 'onboarding_synchronizer')
1121 host_guest_map = ( ('/usr/local/share/ca-certificates', '/usr/local/share/ca-certificates'),)
ChetanGaonker2c0e9bb2016-09-21 13:38:37 -07001122
A R Karthicke3bde962016-09-27 15:06:35 -07001123 def __init__(self, name = NAME, image = IMAGE, prefix = PREFIX,
A R Karthick6e80afd2016-10-10 16:03:12 -07001124 tag = TAG, boot_delay = 10, restart = False, network_cfg = None, update = False):
A R Karthicke3bde962016-09-27 15:06:35 -07001125 Xos.__init__(self, name, image, prefix, tag, boot_delay, restart, network_cfg, update)
ChetanGaonker2c0e9bb2016-09-21 13:38:37 -07001126
1127 @classmethod
A R Karthicke3bde962016-09-27 15:06:35 -07001128 def build_image(cls, image = IMAGE):
1129 XosSynchronizerOpenstack.build_image()
1130 Xos.build_image(image, cls.dockerfile_path)
ChetanGaonker2c0e9bb2016-09-21 13:38:37 -07001131
A R Karthicke3bde962016-09-27 15:06:35 -07001132class XosSynchronizerOpenvpn(Xos):
1133 NAME = 'xos-synchronizer-openvpn'
1134 IMAGE = 'xosproject/xos-openvpn'
1135 TAG = 'latest'
1136 PREFIX = ''
1137 dockerfile_path = os.path.join(Xos.setup_dir, 'openvpn')
1138 host_guest_map = ( ('/usr/local/share/ca-certificates', '/usr/local/share/ca-certificates'),)
ChetanGaonker2c0e9bb2016-09-21 13:38:37 -07001139
A R Karthicke3bde962016-09-27 15:06:35 -07001140 def __init__(self, name = NAME, image = IMAGE, prefix = PREFIX,
A R Karthick6e80afd2016-10-10 16:03:12 -07001141 tag = TAG, boot_delay = 10, restart = False, network_cfg = None, update = False):
A R Karthicke3bde962016-09-27 15:06:35 -07001142 Xos.__init__(self, name, image, prefix, tag, boot_delay, restart, network_cfg, update)
1143
1144 @classmethod
1145 def build_image(cls, image = IMAGE):
1146 XosSynchronizerOpenstack.build_image()
1147 Xos.build_image(image, cls.dockerfile_path)
1148
1149class XosPostgresql(Xos):
1150 ports = [5432,]
1151 NAME = 'xos-db-postgres'
1152 IMAGE = 'xosproject/xos-postgres'
1153 TAG = 'latest'
1154 PREFIX = ''
1155 volumes = ["/etc/postgresql", "/var/log/postgresql", "/var/lib/postgresql"]
1156 dockerfile_path = os.path.join(Xos.setup_dir, 'postgresql')
1157
1158 def __init__(self, name = NAME, image = IMAGE, prefix = PREFIX,
A R Karthick6e80afd2016-10-10 16:03:12 -07001159 tag = TAG, boot_delay = 10, restart = False, network_cfg = None, update = False):
A R Karthicke3bde962016-09-27 15:06:35 -07001160 Xos.__init__(self, name, image, prefix, tag, boot_delay, restart, network_cfg, update)
1161
1162 @classmethod
1163 def build_image(cls, image = IMAGE):
1164 Xos.build_image(image, cls.dockerfile_path)
1165
1166class XosSyndicateMs(Xos):
1167 ports = [8080,]
1168 env = None
1169 NAME = 'xos-syndicate-ms'
1170 IMAGE = 'xosproject/syndicate-ms'
1171 TAG = 'latest'
1172 PREFIX = ''
1173 dockerfile_path = os.path.join(Xos.setup_dir, 'syndicate-ms')
1174
1175 def __init__(self, name = NAME, image = IMAGE, prefix = '', tag = TAG,
A R Karthick6e80afd2016-10-10 16:03:12 -07001176 boot_delay = 10, restart = False, network_cfg = None, update = False):
A R Karthicke3bde962016-09-27 15:06:35 -07001177 Xos.__init__(self, name, image, prefix, tag, boot_delay, restart, network_cfg, update)
1178
1179 @classmethod
1180 def build_image(cls, image = IMAGE):
1181 Xos.build_image(image, cls.dockerfile_path)
ChetanGaonker2c0e9bb2016-09-21 13:38:37 -07001182
ChetanGaonkerc220e0d2016-10-05 05:06:25 -07001183class XosSyncVtn(Xos):
1184 ports = [8080,]
1185 env = None
1186 NAME = 'xos-synchronizer-vtn'
1187 IMAGE = 'xosproject/xos-synchronizer-vtn'
1188 TAG = 'latest'
1189 PREFIX = ''
1190 dockerfile_path = os.path.join(Xos.setup_dir, 'synchronizer-vtn')
1191
1192 def __init__(self, name = NAME, image = IMAGE, prefix = '', tag = TAG,
A R Karthick6e80afd2016-10-10 16:03:12 -07001193 boot_delay = 10, restart = False, network_cfg = None, update = False):
ChetanGaonkerc220e0d2016-10-05 05:06:25 -07001194 Xos.__init__(self, name, image, prefix, tag, boot_delay, restart, network_cfg, update)
1195
1196 @classmethod
1197 def build_image(cls, image = IMAGE):
1198 Xos.build_image(image, cls.dockerfile_path)
1199
1200class XosSyncVtr(Xos):
1201 ports = [8080,]
1202 env = None
1203 NAME = 'xos-synchronizer-vtr'
1204 IMAGE = 'xosproject/xos-synchronizer-vtr'
1205 TAG = 'latest'
1206 PREFIX = ''
1207 dockerfile_path = os.path.join(Xos.setup_dir, 'synchronizer-vtr')
1208
1209 def __init__(self, name = NAME, image = IMAGE, prefix = '', tag = TAG,
A R Karthick6e80afd2016-10-10 16:03:12 -07001210 boot_delay = 10, restart = False, network_cfg = None, update = False):
ChetanGaonkerc220e0d2016-10-05 05:06:25 -07001211 Xos.__init__(self, name, image, prefix, tag, boot_delay, restart, network_cfg, update)
1212
1213 @classmethod
1214 def build_image(cls, image = IMAGE):
1215 Xos.build_image(image, cls.dockerfile_path)
1216
1217class XosSyncVsg(Xos):
1218 ports = [8080,]
1219 env = None
1220 NAME = 'xos-synchronizer-vsg'
1221 IMAGE = 'xosproject/xos-synchronizer-vsg'
1222 TAG = 'latest'
1223 PREFIX = ''
1224 dockerfile_path = os.path.join(Xos.setup_dir, 'synchronizer-vsg')
1225
1226 def __init__(self, name = NAME, image = IMAGE, prefix = '', tag = TAG,
A R Karthick6e80afd2016-10-10 16:03:12 -07001227 boot_delay = 10, restart = False, network_cfg = None, update = False):
ChetanGaonkerc220e0d2016-10-05 05:06:25 -07001228 Xos.__init__(self, name, image, prefix, tag, boot_delay, restart, network_cfg, update)
1229
1230 @classmethod
1231 def build_image(cls, image = IMAGE):
1232 Xos.build_image(image, cls.dockerfile_path)
1233
1234
1235class XosSyncOnos(Xos):
1236 ports = [8080,]
1237 env = None
1238 NAME = 'xos-synchronizer-onos'
1239 IMAGE = 'xosproject/xos-synchronizer-onos'
1240 TAG = 'latest'
1241 PREFIX = ''
1242 dockerfile_path = os.path.join(Xos.setup_dir, 'synchronizer-onos')
1243
1244 def __init__(self, name = NAME, image = IMAGE, prefix = '', tag = TAG,
A R Karthick6e80afd2016-10-10 16:03:12 -07001245 boot_delay = 30, restart = False, network_cfg = None, update = False):
ChetanGaonkerc220e0d2016-10-05 05:06:25 -07001246 Xos.__init__(self, name, image, prefix, tag, boot_delay, restart, network_cfg, update)
1247
1248 @classmethod
1249 def build_image(cls, image = IMAGE):
1250 Xos.build_image(image, cls.dockerfile_path)
1251
1252class XosSyncFabric(Xos):
1253 ports = [8080,]
1254 env = None
1255 NAME = 'xos-synchronizer-fabric'
1256 IMAGE = 'xosproject/xos-synchronizer-fabric'
1257 TAG = 'latest'
1258 PREFIX = ''
1259 dockerfile_path = os.path.join(Xos.setup_dir, 'synchronizer-fabric')
1260
1261 def __init__(self, name = NAME, image = IMAGE, prefix = '', tag = TAG,
A R Karthick6e80afd2016-10-10 16:03:12 -07001262 boot_delay = 30, restart = False, network_cfg = None, update = False):
ChetanGaonkerc220e0d2016-10-05 05:06:25 -07001263 Xos.__init__(self, name, image, prefix, tag, boot_delay, restart, network_cfg, update)
1264
1265 @classmethod
1266 def build_image(cls, image = IMAGE):
1267 Xos.build_image(image, cls.dockerfile_path)
A R Karthick19aaf5c2016-11-09 17:47:57 -08001268
1269if __name__ == '__main__':
1270 onos = Onos(boot_delay = 10, restart = True)