123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198 |
- from __future__ import absolute_import
- from __future__ import unicode_literals
- import os
- import docker
- from .. import mock
- from .. import unittest
- from compose.cli.docopt_command import NoSuchCommand
- from compose.cli.errors import UserError
- from compose.cli.main import TopLevelCommand
- from compose.service import Service
- class CLITestCase(unittest.TestCase):
- def test_default_project_name(self):
- cwd = os.getcwd()
- try:
- os.chdir('tests/fixtures/simple-composefile')
- command = TopLevelCommand()
- project_name = command.get_project_name('.')
- self.assertEquals('simplecomposefile', project_name)
- finally:
- os.chdir(cwd)
- def test_project_name_with_explicit_base_dir(self):
- command = TopLevelCommand()
- command.base_dir = 'tests/fixtures/simple-composefile'
- project_name = command.get_project_name(command.base_dir)
- self.assertEquals('simplecomposefile', project_name)
- def test_project_name_with_explicit_uppercase_base_dir(self):
- command = TopLevelCommand()
- command.base_dir = 'tests/fixtures/UpperCaseDir'
- project_name = command.get_project_name(command.base_dir)
- self.assertEquals('uppercasedir', project_name)
- def test_project_name_with_explicit_project_name(self):
- command = TopLevelCommand()
- name = 'explicit-project-name'
- project_name = command.get_project_name(None, project_name=name)
- self.assertEquals('explicitprojectname', project_name)
- def test_project_name_from_environment_old_var(self):
- command = TopLevelCommand()
- name = 'namefromenv'
- with mock.patch.dict(os.environ):
- os.environ['FIG_PROJECT_NAME'] = name
- project_name = command.get_project_name(None)
- self.assertEquals(project_name, name)
- def test_project_name_from_environment_new_var(self):
- command = TopLevelCommand()
- name = 'namefromenv'
- with mock.patch.dict(os.environ):
- os.environ['COMPOSE_PROJECT_NAME'] = name
- project_name = command.get_project_name(None)
- self.assertEquals(project_name, name)
- def test_get_project(self):
- command = TopLevelCommand()
- command.base_dir = 'tests/fixtures/longer-filename-composefile'
- project = command.get_project()
- self.assertEqual(project.name, 'longerfilenamecomposefile')
- self.assertTrue(project.client)
- self.assertTrue(project.services)
- def test_help(self):
- command = TopLevelCommand()
- with self.assertRaises(SystemExit):
- command.dispatch(['-h'], None)
- def test_command_help(self):
- with self.assertRaises(SystemExit) as ctx:
- TopLevelCommand().dispatch(['help', 'up'], None)
- self.assertIn('Usage: up', str(ctx.exception))
- def test_command_help_dashes(self):
- with self.assertRaises(SystemExit) as ctx:
- TopLevelCommand().dispatch(['help', 'migrate-to-labels'], None)
- self.assertIn('Usage: migrate-to-labels', str(ctx.exception))
- def test_command_help_nonexistent(self):
- with self.assertRaises(NoSuchCommand):
- TopLevelCommand().dispatch(['help', 'nonexistent'], None)
- @mock.patch('compose.cli.main.dockerpty', autospec=True)
- def test_run_with_environment_merged_with_options_list(self, mock_dockerpty):
- command = TopLevelCommand()
- mock_client = mock.create_autospec(docker.Client)
- mock_project = mock.Mock(client=mock_client)
- mock_project.get_service.return_value = Service(
- 'service',
- client=mock_client,
- environment=['FOO=ONE', 'BAR=TWO'],
- image='someimage')
- command.run(mock_project, {
- 'SERVICE': 'service',
- 'COMMAND': None,
- '-e': ['BAR=NEW', 'OTHER=THREE'],
- '--user': None,
- '--no-deps': None,
- '--allow-insecure-ssl': None,
- '-d': True,
- '-T': None,
- '--entrypoint': None,
- '--service-ports': None,
- '--publish': [],
- '--rm': None,
- })
- _, _, call_kwargs = mock_client.create_container.mock_calls[0]
- self.assertEqual(
- call_kwargs['environment'],
- {'FOO': 'ONE', 'BAR': 'NEW', 'OTHER': 'THREE'})
- def test_run_service_with_restart_always(self):
- command = TopLevelCommand()
- mock_client = mock.create_autospec(docker.Client)
- mock_project = mock.Mock(client=mock_client)
- mock_project.get_service.return_value = Service(
- 'service',
- client=mock_client,
- restart='always',
- image='someimage')
- command.run(mock_project, {
- 'SERVICE': 'service',
- 'COMMAND': None,
- '-e': [],
- '--user': None,
- '--no-deps': None,
- '--allow-insecure-ssl': None,
- '-d': True,
- '-T': None,
- '--entrypoint': None,
- '--service-ports': None,
- '--publish': [],
- '--rm': None,
- })
- _, _, call_kwargs = mock_client.create_container.mock_calls[0]
- self.assertEquals(call_kwargs['host_config']['RestartPolicy']['Name'], 'always')
- command = TopLevelCommand()
- mock_client = mock.create_autospec(docker.Client)
- mock_project = mock.Mock(client=mock_client)
- mock_project.get_service.return_value = Service(
- 'service',
- client=mock_client,
- restart='always',
- image='someimage')
- command.run(mock_project, {
- 'SERVICE': 'service',
- 'COMMAND': None,
- '-e': [],
- '--user': None,
- '--no-deps': None,
- '--allow-insecure-ssl': None,
- '-d': True,
- '-T': None,
- '--entrypoint': None,
- '--service-ports': None,
- '--publish': [],
- '--rm': True,
- })
- _, _, call_kwargs = mock_client.create_container.mock_calls[0]
- self.assertFalse('RestartPolicy' in call_kwargs['host_config'])
- def test_command_manula_and_service_ports_together(self):
- command = TopLevelCommand()
- mock_client = mock.create_autospec(docker.Client)
- mock_project = mock.Mock(client=mock_client)
- mock_project.get_service.return_value = Service(
- 'service',
- client=mock_client,
- restart='always',
- image='someimage',
- )
- with self.assertRaises(UserError):
- command.run(mock_project, {
- 'SERVICE': 'service',
- 'COMMAND': None,
- '-e': [],
- '--user': None,
- '--no-deps': None,
- '--allow-insecure-ssl': None,
- '-d': True,
- '-T': None,
- '--entrypoint': None,
- '--service-ports': True,
- '--publish': ['80:80'],
- '--rm': None,
- })
|