mirror of https://github.com/docker/compose.git
Print build output
This commit is contained in:
parent
cb366eed7a
commit
3458dd2fad
|
@ -4,6 +4,11 @@ import re
|
||||||
|
|
||||||
log = logging.getLogger(__name__)
|
log = logging.getLogger(__name__)
|
||||||
|
|
||||||
|
|
||||||
|
class BuildError(Exception):
|
||||||
|
pass
|
||||||
|
|
||||||
|
|
||||||
class Service(object):
|
class Service(object):
|
||||||
def __init__(self, name, client=None, links=[], **options):
|
def __init__(self, name, client=None, links=[], **options):
|
||||||
if not re.match('^[a-zA-Z0-9_]+$', name):
|
if not re.match('^[a-zA-Z0-9_]+$', name):
|
||||||
|
@ -50,7 +55,6 @@ class Service(object):
|
||||||
raise
|
raise
|
||||||
|
|
||||||
def start_container(self, container=None, **override_options):
|
def start_container(self, container=None, **override_options):
|
||||||
container_options = self._get_container_options(override_options)
|
|
||||||
if container is None:
|
if container is None:
|
||||||
container = self.create_container(**override_options)
|
container = self.create_container(**override_options)
|
||||||
port_bindings = {}
|
port_bindings = {}
|
||||||
|
@ -61,7 +65,7 @@ class Service(object):
|
||||||
port_bindings[int(internal_port)] = int(external_port)
|
port_bindings[int(internal_port)] = int(external_port)
|
||||||
else:
|
else:
|
||||||
port_bindings[int(port)] = None
|
port_bindings[int(port)] = None
|
||||||
log.info("Starting %s..." % container_options['name'])
|
log.info("Starting %s..." % container['Id'])
|
||||||
self.client.start(
|
self.client.start(
|
||||||
container['Id'],
|
container['Id'],
|
||||||
links=self._get_links(),
|
links=self._get_links(),
|
||||||
|
@ -108,11 +112,29 @@ class Service(object):
|
||||||
container_options['ports'] = [unicode(p).split(':')[0] for p in container_options['ports']]
|
container_options['ports'] = [unicode(p).split(':')[0] for p in container_options['ports']]
|
||||||
|
|
||||||
if 'build' in self.options:
|
if 'build' in self.options:
|
||||||
log.info('Building %s from %s...' % (self.name, self.options['build']))
|
container_options['image'] = self.build()
|
||||||
container_options['image'] = self.client.build(self.options['build'])[0]
|
|
||||||
|
|
||||||
return container_options
|
return container_options
|
||||||
|
|
||||||
|
def build(self):
|
||||||
|
log.info('Building %s from %s...' % (self.name, self.options['build']))
|
||||||
|
|
||||||
|
build_output = self.client.build(self.options['build'], stream=True)
|
||||||
|
|
||||||
|
image_id = None
|
||||||
|
|
||||||
|
for line in build_output:
|
||||||
|
if line:
|
||||||
|
match = re.search(r'Successfully built ([0-9a-f]+)', line)
|
||||||
|
if match:
|
||||||
|
image_id = match.group(1)
|
||||||
|
print line
|
||||||
|
|
||||||
|
if image_id is None:
|
||||||
|
raise BuildError()
|
||||||
|
|
||||||
|
return image_id
|
||||||
|
|
||||||
|
|
||||||
def make_name(prefix, number):
|
def make_name(prefix, number):
|
||||||
return '%s_%s' % (prefix, number)
|
return '%s_%s' % (prefix, number)
|
||||||
|
@ -130,6 +152,10 @@ def parse_name(name):
|
||||||
|
|
||||||
|
|
||||||
def get_container_name(container):
|
def get_container_name(container):
|
||||||
|
# inspect
|
||||||
|
if 'Name' in container:
|
||||||
|
return container['Name']
|
||||||
|
# ps
|
||||||
for name in container['Names']:
|
for name in container['Names']:
|
||||||
if len(name.split('/')) == 2:
|
if len(name.split('/')) == 2:
|
||||||
return name[1:]
|
return name[1:]
|
||||||
|
|
Loading…
Reference in New Issue