mirror of https://github.com/docker/compose.git
Merge pull request #6738 from Inconnu08/set-optimization
Replace sets with set literal syntax for efficiency
This commit is contained in:
commit
c8279bc4db
|
@ -21,7 +21,7 @@ from .utils import get_version_info
|
||||||
|
|
||||||
log = logging.getLogger(__name__)
|
log = logging.getLogger(__name__)
|
||||||
|
|
||||||
SILENT_COMMANDS = set((
|
SILENT_COMMANDS = {
|
||||||
'events',
|
'events',
|
||||||
'exec',
|
'exec',
|
||||||
'kill',
|
'kill',
|
||||||
|
@ -34,7 +34,7 @@ SILENT_COMMANDS = set((
|
||||||
'stop',
|
'stop',
|
||||||
'top',
|
'top',
|
||||||
'unpause',
|
'unpause',
|
||||||
))
|
}
|
||||||
|
|
||||||
|
|
||||||
def project_from_options(project_dir, options, additional_options={}):
|
def project_from_options(project_dir, options, additional_options={}):
|
||||||
|
|
|
@ -1446,7 +1446,7 @@ class CLITestCase(DockerClientTestCase):
|
||||||
if v['Name'].split('/')[-1].startswith('{}_'.format(self.project.name))
|
if v['Name'].split('/')[-1].startswith('{}_'.format(self.project.name))
|
||||||
]
|
]
|
||||||
|
|
||||||
assert set([v['Name'].split('/')[-1] for v in volumes]) == set([volume_with_label])
|
assert set([v['Name'].split('/')[-1] for v in volumes]) == {volume_with_label}
|
||||||
assert 'label_key' in volumes[0]['Labels']
|
assert 'label_key' in volumes[0]['Labels']
|
||||||
assert volumes[0]['Labels']['label_key'] == 'label_val'
|
assert volumes[0]['Labels']['label_key'] == 'label_val'
|
||||||
|
|
||||||
|
@ -2111,7 +2111,7 @@ class CLITestCase(DockerClientTestCase):
|
||||||
for _, config in networks.items():
|
for _, config in networks.items():
|
||||||
# TODO: once we drop support for API <1.24, this can be changed to:
|
# TODO: once we drop support for API <1.24, this can be changed to:
|
||||||
# assert config['Aliases'] == [container.short_id]
|
# assert config['Aliases'] == [container.short_id]
|
||||||
aliases = set(config['Aliases'] or []) - set([container.short_id])
|
aliases = set(config['Aliases'] or []) - {container.short_id}
|
||||||
assert not aliases
|
assert not aliases
|
||||||
|
|
||||||
@v2_only()
|
@v2_only()
|
||||||
|
@ -2131,7 +2131,7 @@ class CLITestCase(DockerClientTestCase):
|
||||||
for _, config in networks.items():
|
for _, config in networks.items():
|
||||||
# TODO: once we drop support for API <1.24, this can be changed to:
|
# TODO: once we drop support for API <1.24, this can be changed to:
|
||||||
# assert config['Aliases'] == [container.short_id]
|
# assert config['Aliases'] == [container.short_id]
|
||||||
aliases = set(config['Aliases'] or []) - set([container.short_id])
|
aliases = set(config['Aliases'] or []) - {container.short_id}
|
||||||
assert not aliases
|
assert not aliases
|
||||||
|
|
||||||
assert self.lookup(container, 'app')
|
assert self.lookup(container, 'app')
|
||||||
|
@ -2741,7 +2741,7 @@ class CLITestCase(DockerClientTestCase):
|
||||||
self.base_dir = 'tests/fixtures/extends'
|
self.base_dir = 'tests/fixtures/extends'
|
||||||
self.dispatch(['up', '-d'], None)
|
self.dispatch(['up', '-d'], None)
|
||||||
|
|
||||||
assert set([s.name for s in self.project.services]) == set(['mydb', 'myweb'])
|
assert set([s.name for s in self.project.services]) == {'mydb', 'myweb'}
|
||||||
|
|
||||||
# Sort by name so we get [db, web]
|
# Sort by name so we get [db, web]
|
||||||
containers = sorted(
|
containers = sorted(
|
||||||
|
@ -2753,15 +2753,9 @@ class CLITestCase(DockerClientTestCase):
|
||||||
web = containers[1]
|
web = containers[1]
|
||||||
db_name = containers[0].name_without_project
|
db_name = containers[0].name_without_project
|
||||||
|
|
||||||
assert set(get_links(web)) == set(
|
assert set(get_links(web)) == {'db', db_name, 'extends_{}'.format(db_name)}
|
||||||
['db', db_name, 'extends_{}'.format(db_name)]
|
|
||||||
)
|
|
||||||
|
|
||||||
expected_env = set([
|
expected_env = {"FOO=1", "BAR=2", "BAZ=2"}
|
||||||
"FOO=1",
|
|
||||||
"BAR=2",
|
|
||||||
"BAZ=2",
|
|
||||||
])
|
|
||||||
assert expected_env <= set(web.get('Config.Env'))
|
assert expected_env <= set(web.get('Config.Env'))
|
||||||
|
|
||||||
def test_top_services_not_running(self):
|
def test_top_services_not_running(self):
|
||||||
|
|
|
@ -104,7 +104,7 @@ class ProjectTest(DockerClientTestCase):
|
||||||
self.create_service('extra').create_container()
|
self.create_service('extra').create_container()
|
||||||
|
|
||||||
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)) == {web_1, db_1}
|
||||||
|
|
||||||
def test_parallel_pull_with_no_image(self):
|
def test_parallel_pull_with_no_image(self):
|
||||||
config_data = build_config(
|
config_data = build_config(
|
||||||
|
@ -305,24 +305,20 @@ class ProjectTest(DockerClientTestCase):
|
||||||
db_container = db.create_container()
|
db_container = db.create_container()
|
||||||
|
|
||||||
project.start(service_names=['web'])
|
project.start(service_names=['web'])
|
||||||
assert set(c.name for c in project.containers() if c.is_running) == set(
|
assert set(c.name for c in project.containers() if c.is_running) == {
|
||||||
[web_container_1.name, web_container_2.name]
|
web_container_1.name, web_container_2.name}
|
||||||
)
|
|
||||||
|
|
||||||
project.start()
|
project.start()
|
||||||
assert set(c.name for c in project.containers() if c.is_running) == set(
|
assert set(c.name for c in project.containers() if c.is_running) == {
|
||||||
[web_container_1.name, web_container_2.name, db_container.name]
|
web_container_1.name, web_container_2.name, db_container.name}
|
||||||
)
|
|
||||||
|
|
||||||
project.pause(service_names=['web'])
|
project.pause(service_names=['web'])
|
||||||
assert set([c.name for c in project.containers() if c.is_paused]) == set(
|
assert set([c.name for c in project.containers() if c.is_paused]) == {
|
||||||
[web_container_1.name, web_container_2.name]
|
web_container_1.name, web_container_2.name}
|
||||||
)
|
|
||||||
|
|
||||||
project.pause()
|
project.pause()
|
||||||
assert set([c.name for c in project.containers() if c.is_paused]) == set(
|
assert set([c.name for c in project.containers() if c.is_paused]) == {
|
||||||
[web_container_1.name, web_container_2.name, db_container.name]
|
web_container_1.name, web_container_2.name, db_container.name}
|
||||||
)
|
|
||||||
|
|
||||||
project.unpause(service_names=['db'])
|
project.unpause(service_names=['db'])
|
||||||
assert len([c.name for c in project.containers() if c.is_paused]) == 2
|
assert len([c.name for c in project.containers() if c.is_paused]) == 2
|
||||||
|
@ -331,7 +327,7 @@ class ProjectTest(DockerClientTestCase):
|
||||||
assert len([c.name for c in project.containers() if c.is_paused]) == 0
|
assert len([c.name for c in project.containers() if c.is_paused]) == 0
|
||||||
|
|
||||||
project.stop(service_names=['web'], timeout=1)
|
project.stop(service_names=['web'], timeout=1)
|
||||||
assert set(c.name for c in project.containers() if c.is_running) == set([db_container.name])
|
assert set(c.name for c in project.containers() if c.is_running) == {db_container.name}
|
||||||
|
|
||||||
project.kill(service_names=['db'])
|
project.kill(service_names=['db'])
|
||||||
assert len([c for c in project.containers() if c.is_running]) == 0
|
assert len([c for c in project.containers() if c.is_running]) == 0
|
||||||
|
|
|
@ -3821,35 +3821,35 @@ class MergePathMappingTest(object):
|
||||||
{self.config_name: ['/foo:/code', '/data']},
|
{self.config_name: ['/foo:/code', '/data']},
|
||||||
{},
|
{},
|
||||||
DEFAULT_VERSION)
|
DEFAULT_VERSION)
|
||||||
assert set(service_dict[self.config_name]) == set(['/foo:/code', '/data'])
|
assert set(service_dict[self.config_name]) == {'/foo:/code', '/data'}
|
||||||
|
|
||||||
def test_no_base(self):
|
def test_no_base(self):
|
||||||
service_dict = config.merge_service_dicts(
|
service_dict = config.merge_service_dicts(
|
||||||
{},
|
{},
|
||||||
{self.config_name: ['/bar:/code']},
|
{self.config_name: ['/bar:/code']},
|
||||||
DEFAULT_VERSION)
|
DEFAULT_VERSION)
|
||||||
assert set(service_dict[self.config_name]) == set(['/bar:/code'])
|
assert set(service_dict[self.config_name]) == {'/bar:/code'}
|
||||||
|
|
||||||
def test_override_explicit_path(self):
|
def test_override_explicit_path(self):
|
||||||
service_dict = config.merge_service_dicts(
|
service_dict = config.merge_service_dicts(
|
||||||
{self.config_name: ['/foo:/code', '/data']},
|
{self.config_name: ['/foo:/code', '/data']},
|
||||||
{self.config_name: ['/bar:/code']},
|
{self.config_name: ['/bar:/code']},
|
||||||
DEFAULT_VERSION)
|
DEFAULT_VERSION)
|
||||||
assert set(service_dict[self.config_name]) == set(['/bar:/code', '/data'])
|
assert set(service_dict[self.config_name]) == {'/bar:/code', '/data'}
|
||||||
|
|
||||||
def test_add_explicit_path(self):
|
def test_add_explicit_path(self):
|
||||||
service_dict = config.merge_service_dicts(
|
service_dict = config.merge_service_dicts(
|
||||||
{self.config_name: ['/foo:/code', '/data']},
|
{self.config_name: ['/foo:/code', '/data']},
|
||||||
{self.config_name: ['/bar:/code', '/quux:/data']},
|
{self.config_name: ['/bar:/code', '/quux:/data']},
|
||||||
DEFAULT_VERSION)
|
DEFAULT_VERSION)
|
||||||
assert set(service_dict[self.config_name]) == set(['/bar:/code', '/quux:/data'])
|
assert set(service_dict[self.config_name]) == {'/bar:/code', '/quux:/data'}
|
||||||
|
|
||||||
def test_remove_explicit_path(self):
|
def test_remove_explicit_path(self):
|
||||||
service_dict = config.merge_service_dicts(
|
service_dict = config.merge_service_dicts(
|
||||||
{self.config_name: ['/foo:/code', '/quux:/data']},
|
{self.config_name: ['/foo:/code', '/quux:/data']},
|
||||||
{self.config_name: ['/bar:/code', '/data']},
|
{self.config_name: ['/bar:/code', '/data']},
|
||||||
DEFAULT_VERSION)
|
DEFAULT_VERSION)
|
||||||
assert set(service_dict[self.config_name]) == set(['/bar:/code', '/data'])
|
assert set(service_dict[self.config_name]) == {'/bar:/code', '/data'}
|
||||||
|
|
||||||
|
|
||||||
class MergeVolumesTest(unittest.TestCase, MergePathMappingTest):
|
class MergeVolumesTest(unittest.TestCase, MergePathMappingTest):
|
||||||
|
@ -4053,28 +4053,28 @@ class MergeStringsOrListsTest(unittest.TestCase):
|
||||||
{'dns': '8.8.8.8'},
|
{'dns': '8.8.8.8'},
|
||||||
{},
|
{},
|
||||||
DEFAULT_VERSION)
|
DEFAULT_VERSION)
|
||||||
assert set(service_dict['dns']) == set(['8.8.8.8'])
|
assert set(service_dict['dns']) == {'8.8.8.8'}
|
||||||
|
|
||||||
def test_no_base(self):
|
def test_no_base(self):
|
||||||
service_dict = config.merge_service_dicts(
|
service_dict = config.merge_service_dicts(
|
||||||
{},
|
{},
|
||||||
{'dns': '8.8.8.8'},
|
{'dns': '8.8.8.8'},
|
||||||
DEFAULT_VERSION)
|
DEFAULT_VERSION)
|
||||||
assert set(service_dict['dns']) == set(['8.8.8.8'])
|
assert set(service_dict['dns']) == {'8.8.8.8'}
|
||||||
|
|
||||||
def test_add_string(self):
|
def test_add_string(self):
|
||||||
service_dict = config.merge_service_dicts(
|
service_dict = config.merge_service_dicts(
|
||||||
{'dns': ['8.8.8.8']},
|
{'dns': ['8.8.8.8']},
|
||||||
{'dns': '9.9.9.9'},
|
{'dns': '9.9.9.9'},
|
||||||
DEFAULT_VERSION)
|
DEFAULT_VERSION)
|
||||||
assert set(service_dict['dns']) == set(['8.8.8.8', '9.9.9.9'])
|
assert set(service_dict['dns']) == {'8.8.8.8', '9.9.9.9'}
|
||||||
|
|
||||||
def test_add_list(self):
|
def test_add_list(self):
|
||||||
service_dict = config.merge_service_dicts(
|
service_dict = config.merge_service_dicts(
|
||||||
{'dns': '8.8.8.8'},
|
{'dns': '8.8.8.8'},
|
||||||
{'dns': ['9.9.9.9']},
|
{'dns': ['9.9.9.9']},
|
||||||
DEFAULT_VERSION)
|
DEFAULT_VERSION)
|
||||||
assert set(service_dict['dns']) == set(['8.8.8.8', '9.9.9.9'])
|
assert set(service_dict['dns']) == {'8.8.8.8', '9.9.9.9'}
|
||||||
|
|
||||||
|
|
||||||
class MergeLabelsTest(unittest.TestCase):
|
class MergeLabelsTest(unittest.TestCase):
|
||||||
|
@ -4146,7 +4146,7 @@ class MergeBuildTest(unittest.TestCase):
|
||||||
assert result['context'] == override['context']
|
assert result['context'] == override['context']
|
||||||
assert result['dockerfile'] == override['dockerfile']
|
assert result['dockerfile'] == override['dockerfile']
|
||||||
assert result['args'] == {'x': '12', 'y': '2'}
|
assert result['args'] == {'x': '12', 'y': '2'}
|
||||||
assert set(result['cache_from']) == set(['ubuntu', 'debian'])
|
assert set(result['cache_from']) == {'ubuntu', 'debian'}
|
||||||
assert result['labels'] == override['labels']
|
assert result['labels'] == override['labels']
|
||||||
|
|
||||||
def test_empty_override(self):
|
def test_empty_override(self):
|
||||||
|
@ -4350,7 +4350,7 @@ class EnvTest(unittest.TestCase):
|
||||||
"tests/fixtures/env",
|
"tests/fixtures/env",
|
||||||
)
|
)
|
||||||
).services[0]
|
).services[0]
|
||||||
assert set(service_dict['volumes']) == set([VolumeSpec.parse('/tmp:/host/tmp')])
|
assert set(service_dict['volumes']) == {VolumeSpec.parse('/tmp:/host/tmp')}
|
||||||
|
|
||||||
service_dict = config.load(
|
service_dict = config.load(
|
||||||
build_config_details(
|
build_config_details(
|
||||||
|
@ -4358,7 +4358,7 @@ class EnvTest(unittest.TestCase):
|
||||||
"tests/fixtures/env",
|
"tests/fixtures/env",
|
||||||
)
|
)
|
||||||
).services[0]
|
).services[0]
|
||||||
assert set(service_dict['volumes']) == set([VolumeSpec.parse('/opt/tmp:/opt/host/tmp')])
|
assert set(service_dict['volumes']) == {VolumeSpec.parse('/opt/tmp:/opt/host/tmp')}
|
||||||
|
|
||||||
|
|
||||||
def load_from_filename(filename, override_dir=None):
|
def load_from_filename(filename, override_dir=None):
|
||||||
|
|
|
@ -1334,10 +1334,8 @@ class ServiceVolumesTest(unittest.TestCase):
|
||||||
number=1,
|
number=1,
|
||||||
)
|
)
|
||||||
|
|
||||||
assert set(self.mock_client.create_host_config.call_args[1]['binds']) == set([
|
assert set(self.mock_client.create_host_config.call_args[1]['binds']) == {'/host/path:/data1:rw',
|
||||||
'/host/path:/data1:rw',
|
'/host/path:/data2:rw'}
|
||||||
'/host/path:/data2:rw',
|
|
||||||
])
|
|
||||||
|
|
||||||
def test_get_container_create_options_with_different_host_path_in_container_json(self):
|
def test_get_container_create_options_with_different_host_path_in_container_json(self):
|
||||||
service = Service(
|
service = Service(
|
||||||
|
|
Loading…
Reference in New Issue