Improved build and pull error handling
This commit is contained in:
parent
f8d2be407d
commit
1e4b8c13a3
1 changed files with 36 additions and 17 deletions
|
@ -464,7 +464,7 @@ from ansible.module_utils.basic import *
|
||||||
try:
|
try:
|
||||||
from compose import __version__ as compose_version
|
from compose import __version__ as compose_version
|
||||||
from compose.cli.command import project_from_options
|
from compose.cli.command import project_from_options
|
||||||
from compose.service import ConvergenceStrategy
|
from compose.service import ConvergenceStrategy, NoSuchImageError
|
||||||
from compose.cli.main import convergence_strategy_from_opts, build_action_from_opts, image_type_from_opt
|
from compose.cli.main import convergence_strategy_from_opts, build_action_from_opts, image_type_from_opt
|
||||||
from compose.const import DEFAULT_TIMEOUT
|
from compose.const import DEFAULT_TIMEOUT
|
||||||
except ImportError as exc:
|
except ImportError as exc:
|
||||||
|
@ -736,19 +736,30 @@ class ContainerManager(DockerBaseClass):
|
||||||
for service in self.project.get_services(self.services, include_deps=False):
|
for service in self.project.get_services(self.services, include_deps=False):
|
||||||
self.log('Pulling image for service %s' % service.name)
|
self.log('Pulling image for service %s' % service.name)
|
||||||
# store the existing image ID
|
# store the existing image ID
|
||||||
image = service.image()
|
old_image_id = ''
|
||||||
old_image_id = None
|
try:
|
||||||
if image and image.get('Id'):
|
image = service.image()
|
||||||
old_image_id = image['Id']
|
if image and image.get('Id'):
|
||||||
|
old_image_id = image['Id']
|
||||||
|
except NoSuchImageError:
|
||||||
|
pass
|
||||||
|
except Exception as exc:
|
||||||
|
self.client.fail("Error: service image lookup failed - %s" % str(exc))
|
||||||
|
|
||||||
# pull the image
|
# pull the image
|
||||||
service.pull(ignore_pull_failures=False)
|
try:
|
||||||
|
service.pull(ignore_pull_failures=False)
|
||||||
|
except Exception as exc:
|
||||||
|
self.client.fail("Error: pull failed with %s" % str(exc))
|
||||||
|
|
||||||
# store the new image ID
|
# store the new image ID
|
||||||
image = service.image()
|
new_image_id = ''
|
||||||
new_image_id = None
|
try:
|
||||||
if image and image.get('Id'):
|
image = service.image()
|
||||||
new_image_id = image['Id']
|
if image and image.get('Id'):
|
||||||
|
new_image_id = image['Id']
|
||||||
|
except NoSuchImageError as exc:
|
||||||
|
self.client.fail("Error: service image lookup failed after pull - %s" % str(exc))
|
||||||
|
|
||||||
if new_image_id != old_image_id:
|
if new_image_id != old_image_id:
|
||||||
# if a new image was pulled
|
# if a new image was pulled
|
||||||
|
@ -756,7 +767,7 @@ class ContainerManager(DockerBaseClass):
|
||||||
result['actions'][service.name] = dict()
|
result['actions'][service.name] = dict()
|
||||||
result['actions'][service.name]['pulled_image'] = dict(
|
result['actions'][service.name]['pulled_image'] = dict(
|
||||||
name=service.image_name,
|
name=service.image_name,
|
||||||
id=service.image()['Id']
|
id=new_image_id
|
||||||
)
|
)
|
||||||
return result
|
return result
|
||||||
|
|
||||||
|
@ -770,13 +781,21 @@ class ContainerManager(DockerBaseClass):
|
||||||
self.log('Building image for service %s' % service.name)
|
self.log('Building image for service %s' % service.name)
|
||||||
if service.can_be_built():
|
if service.can_be_built():
|
||||||
# store the existing image ID
|
# store the existing image ID
|
||||||
image = service.image()
|
old_image_id = ''
|
||||||
old_image_id = None
|
try:
|
||||||
if image and image.get('Id'):
|
image = service.image()
|
||||||
old_image_id = image['Id']
|
if image and image.get('Id'):
|
||||||
|
old_image_id = image['Id']
|
||||||
|
except NoSuchImageError:
|
||||||
|
pass
|
||||||
|
except Exception as exc:
|
||||||
|
self.client.fail("Error: service image lookup failed - %s" % str(exc))
|
||||||
|
|
||||||
# build the image
|
# build the image
|
||||||
new_image_id = service.build(pull=True, no_cache=self.nocache)
|
try:
|
||||||
|
new_image_id = service.build(pull=True, no_cache=self.nocache)
|
||||||
|
except Exception as exc:
|
||||||
|
self.client.fail("Error: build failed with %s" % str(exc))
|
||||||
|
|
||||||
if new_image_id not in old_image_id:
|
if new_image_id not in old_image_id:
|
||||||
# if a new image was built
|
# if a new image was built
|
||||||
|
@ -784,7 +803,7 @@ class ContainerManager(DockerBaseClass):
|
||||||
result['actions'][service.name] = dict()
|
result['actions'][service.name] = dict()
|
||||||
result['actions'][service.name]['built_image'] = dict(
|
result['actions'][service.name]['built_image'] = dict(
|
||||||
name=service.image_name,
|
name=service.image_name,
|
||||||
id=service.image()['Id']
|
id=new_image_id
|
||||||
)
|
)
|
||||||
return result
|
return result
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue