Don't attempt iterating on None during parallel pull

Signed-off-by: Joffrey F <joffrey@docker.com>
This commit is contained in:
Joffrey F 2018-10-04 01:09:48 -07:00
parent 7208a50bdc
commit cc595a65f0
3 changed files with 28 additions and 6 deletions

View File

@ -34,6 +34,7 @@ from .service import Service
from .service import ServiceNetworkMode from .service import ServiceNetworkMode
from .service import ServicePidMode from .service import ServicePidMode
from .utils import microseconds_from_time_nano from .utils import microseconds_from_time_nano
from .utils import truncate_string
from .volume import ProjectVolumes from .volume import ProjectVolumes
@ -554,12 +555,10 @@ class Project(object):
if parallel_pull: if parallel_pull:
def pull_service(service): def pull_service(service):
strm = service.pull(ignore_pull_failures, True, stream=True) strm = service.pull(ignore_pull_failures, True, stream=True)
writer = parallel.get_stream_writer() if strm is None: # Attempting to pull service with no `image` key is a no-op
return
def trunc(s): writer = parallel.get_stream_writer()
if len(s) > 35:
return s[:33] + '...'
return s
for event in strm: for event in strm:
if 'status' not in event: if 'status' not in event:
@ -572,7 +571,7 @@ class Project(object):
status = '{} ({:.1%})'.format(status, percentage) status = '{} ({:.1%})'.format(status, percentage)
writer.write( writer.write(
msg, service.name, trunc(status), lambda s: s msg, service.name, truncate_string(status), lambda s: s
) )
_, errors = parallel.parallel_execute( _, errors = parallel.parallel_execute(

View File

@ -180,3 +180,9 @@ def unique_everseen(iterable, key=lambda x: x):
if unique_key not in seen: if unique_key not in seen:
seen.add(unique_key) seen.add(unique_key)
yield element yield element
def truncate_string(s, max_chars=35):
if len(s) > max_chars:
return s[:max_chars - 2] + '...'
return s

View File

@ -105,6 +105,23 @@ class ProjectTest(DockerClientTestCase):
project = Project('composetest', [web, db], self.client) project = Project('composetest', [web, db], self.client)
assert set(project.containers(stopped=True)) == set([web_1, db_1]) assert set(project.containers(stopped=True)) == set([web_1, db_1])
def test_parallel_pull_with_no_image(self):
config_data = build_config(
version=V2_3,
services=[{
'name': 'web',
'build': {'context': '.'},
}],
)
project = Project.from_config(
name='composetest',
config_data=config_data,
client=self.client
)
project.pull(parallel_pull=True)
def test_volumes_from_service(self): def test_volumes_from_service(self):
project = Project.from_config( project = Project.from_config(
name='composetest', name='composetest',