Merge pull request #6738 from Inconnu08/set-optimization

Replace sets with set literal syntax for efficiency
This commit is contained in:
Djordje Lukic 2019-07-15 15:23:24 +02:00 committed by GitHub
commit c8279bc4db
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
5 changed files with 32 additions and 44 deletions

View File

@ -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={}):

View File

@ -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):

View File

@ -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

View File

@ -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):

View File

@ -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(