mirror of https://github.com/docker/compose.git
3501 - Add a new command option (images)
Signed-off-by: Jesus Rodriguez Tinoco <jesus.rodriguez.tinoco@gmail.com>
This commit is contained in:
parent
31b2d9176b
commit
33f510b340
|
@ -175,6 +175,7 @@ class TopLevelCommand(object):
|
|||
events Receive real time events from containers
|
||||
exec Execute a command in a running container
|
||||
help Get help on a command
|
||||
images List images
|
||||
kill Kill containers
|
||||
logs View output from containers
|
||||
pause Pause services
|
||||
|
@ -481,6 +482,43 @@ class TopLevelCommand(object):
|
|||
|
||||
print(getdoc(subject))
|
||||
|
||||
def images(self, options):
|
||||
"""
|
||||
List images.
|
||||
Usage: images [options] [SERVICE...]
|
||||
|
||||
Options:
|
||||
-q Only display IDs
|
||||
"""
|
||||
containers = sorted(
|
||||
self.project.containers(service_names=options['SERVICE'], stopped=True) +
|
||||
self.project.containers(service_names=options['SERVICE'], one_off=OneOffFilter.only),
|
||||
key=attrgetter('name'))
|
||||
|
||||
if options['-q']:
|
||||
for container in containers:
|
||||
print(str.split(str(container.image), ':')[1])
|
||||
else:
|
||||
headers = [
|
||||
'Repository',
|
||||
'Tag',
|
||||
'Image Id',
|
||||
'Size'
|
||||
]
|
||||
rows = []
|
||||
for container in containers:
|
||||
image_config = container.image_config
|
||||
repo_tags = str.split(str(image_config['RepoTags'][0]), ':')
|
||||
image_id = str.split(str(container.image), ':')[1][0:12]
|
||||
size = round(int(image_config['Size'])/float(1 << 20), 1)
|
||||
rows.append([
|
||||
repo_tags[0],
|
||||
repo_tags[1],
|
||||
image_id,
|
||||
size
|
||||
])
|
||||
print(Formatter().table(headers, rows))
|
||||
|
||||
def kill(self, options):
|
||||
"""
|
||||
Force stop service containers.
|
||||
|
|
|
@ -220,6 +220,16 @@ _docker_compose_help() {
|
|||
COMPREPLY=( $( compgen -W "${commands[*]}" -- "$cur" ) )
|
||||
}
|
||||
|
||||
_docker_compose_images() {
|
||||
case "$cur" in
|
||||
-*)
|
||||
COMPREPLY=( $( compgen -W "--help -q" -- "$cur" ) )
|
||||
;;
|
||||
*)
|
||||
__docker_compose_services_all
|
||||
;;
|
||||
esac
|
||||
}
|
||||
|
||||
_docker_compose_kill() {
|
||||
case "$prev" in
|
||||
|
|
|
@ -1986,3 +1986,30 @@ class CLITestCase(DockerClientTestCase):
|
|||
result = wait_on_process(proc, returncode=1)
|
||||
|
||||
assert 'exitcodefrom_another_1 exited with code 1' in result.stdout
|
||||
|
||||
def test_images(self):
|
||||
self.project.get_service('simple').create_container()
|
||||
result = self.dispatch(['images'])
|
||||
assert 'simplecomposefile_simple' in result.stdout
|
||||
|
||||
def test_images_default_composefile(self):
|
||||
self.base_dir = 'tests/fixtures/multiple-composefiles'
|
||||
self.dispatch(['up', '-d'])
|
||||
result = self.dispatch(['images'])
|
||||
|
||||
self.assertIn('multiplecomposefiles_simple', result.stdout)
|
||||
self.assertIn('multiplecomposefiles_another', result.stdout)
|
||||
self.assertNotIn('multiplecomposefiles_yetanother', result.stdout)
|
||||
|
||||
def test_images_alternate_composefile(self):
|
||||
config_path = os.path.abspath(
|
||||
'tests/fixtures/multiple-composefiles/compose2.yml')
|
||||
self._project = get_project(self.base_dir, [config_path])
|
||||
|
||||
self.base_dir = 'tests/fixtures/multiple-composefiles'
|
||||
self.dispatch(['-f', 'compose2.yml', 'up', '-d'])
|
||||
result = self.dispatch(['-f', 'compose2.yml', 'images'])
|
||||
|
||||
self.assertNotIn('multiplecomposefiles_simple', result.stdout)
|
||||
self.assertNotIn('multiplecomposefiles_another', result.stdout)
|
||||
self.assertIn('multiplecomposefiles_yetanother', result.stdout)
|
||||
|
|
Loading…
Reference in New Issue