Fix --exit-code-from to reflect exit code after termination by Compose

Signed-off-by: Joffrey F <joffrey@docker.com>
This commit is contained in:
Joffrey F 2018-07-10 15:28:55 -04:00
parent 8c4fc4bc2e
commit e6d18b1881
2 changed files with 37 additions and 25 deletions

View File

@ -1085,6 +1085,9 @@ class TopLevelCommand(object):
) )
self.project.stop(service_names=service_names, timeout=timeout) self.project.stop(service_names=service_names, timeout=timeout)
if exit_value_from:
exit_code = compute_service_exit_code(exit_value_from, attached_containers)
sys.exit(exit_code) sys.exit(exit_code)
@classmethod @classmethod
@ -1103,33 +1106,33 @@ class TopLevelCommand(object):
print(get_version_info('full')) print(get_version_info('full'))
def compute_service_exit_code(exit_value_from, attached_containers):
candidates = list(filter(
lambda c: c.service == exit_value_from,
attached_containers))
if not candidates:
log.error(
'No containers matching the spec "{0}" '
'were run.'.format(exit_value_from)
)
return 2
if len(candidates) > 1:
exit_values = filter(
lambda e: e != 0,
[c.inspect()['State']['ExitCode'] for c in candidates]
)
return exit_values[0]
return candidates[0].inspect()['State']['ExitCode']
def compute_exit_code(exit_value_from, attached_containers, cascade_starter, all_containers): def compute_exit_code(exit_value_from, attached_containers, cascade_starter, all_containers):
exit_code = 0 exit_code = 0
if exit_value_from: for e in all_containers:
candidates = list(filter( if (not e.is_running and cascade_starter == e.name):
lambda c: c.service == exit_value_from, if not e.exit_code == 0:
attached_containers)) exit_code = e.exit_code
if not candidates: break
log.error(
'No containers matching the spec "{0}" '
'were run.'.format(exit_value_from)
)
exit_code = 2
elif len(candidates) > 1:
exit_values = filter(
lambda e: e != 0,
[c.inspect()['State']['ExitCode'] for c in candidates]
)
exit_code = exit_values[0]
else:
exit_code = candidates[0].inspect()['State']['ExitCode']
else:
for e in all_containers:
if (not e.is_running and cascade_starter == e.name):
if not e.exit_code == 0:
exit_code = e.exit_code
break
return exit_code return exit_code

View File

@ -2620,6 +2620,15 @@ class CLITestCase(DockerClientTestCase):
assert 'exit-code-from_another_1 exited with code 1' in result.stdout assert 'exit-code-from_another_1 exited with code 1' in result.stdout
def test_exit_code_from_signal_stop(self):
self.base_dir = 'tests/fixtures/exit-code-from'
proc = start_process(
self.base_dir,
['up', '--abort-on-container-exit', '--exit-code-from', 'simple']
)
result = wait_on_process(proc, returncode=137) # SIGKILL
assert 'exit-code-from_another_1 exited with code 1' in result.stdout
def test_images(self): def test_images(self):
self.project.get_service('simple').create_container() self.project.get_service('simple').create_container()
result = self.dispatch(['images']) result = self.dispatch(['images'])