Allow to extend service using shorthand notation. Closes #1989

Signed-off-by: Karol Duleba <mr.fuxi@gmail.com>
This commit is contained in:
Karol Duleba 2015-09-09 22:30:36 +01:00
parent 03ae2462d4
commit 91b227d133
4 changed files with 56 additions and 10 deletions

View File

@ -275,15 +275,19 @@ class ServiceLoader(object):
self.service_dict['environment'] = env
def validate_and_construct_extends(self):
extends = self.service_dict['extends']
if not isinstance(extends, dict):
extends = {'service': extends}
validate_extends_file_path(
self.service_name,
self.service_dict['extends'],
extends,
self.filename
)
self.extended_config_path = self.get_extended_config_path(
self.service_dict['extends']
extends
)
self.extended_service_name = self.service_dict['extends']['service']
self.extended_service_name = extends['service']
full_extended_config = pre_process_config(
load_yaml(self.extended_config_path)

View File

@ -57,14 +57,21 @@
},
"extends": {
"type": "object",
"oneOf": [
{
"type": "string"
},
{
"type": "object",
"properties": {
"service": {"type": "string"},
"file": {"type": "string"}
},
"required": ["service"],
"additionalProperties": false
"properties": {
"service": {"type": "string"},
"file": {"type": "string"}
},
"required": ["service"],
"additionalProperties": false
}
]
},
"extra_hosts": {"$ref": "#/definitions/list_or_dict"},

View File

@ -0,0 +1,15 @@
base:
image: busybox
environment:
- "BAR=1"
verbose:
extends:
service: base
environment:
- "FOO=1"
shorthand:
extends: base
environment:
- "FOO=2"

View File

@ -1115,6 +1115,26 @@ class ExtendsTest(unittest.TestCase):
dicts = load_from_filename('tests/fixtures/extends/valid-common-config.yml')
self.assertEqual(dicts[0]['environment'], {'FOO': '1'})
def test_extended_service_with_verbose_and_shorthand_way(self):
services = load_from_filename('tests/fixtures/extends/verbose-and-shorthand.yml')
self.assertEqual(service_sort(services), service_sort([
{
'name': 'base',
'image': 'busybox',
'environment': {'BAR': '1'},
},
{
'name': 'verbose',
'image': 'busybox',
'environment': {'BAR': '1', 'FOO': '1'},
},
{
'name': 'shorthand',
'image': 'busybox',
'environment': {'BAR': '1', 'FOO': '2'},
},
]))
@pytest.mark.xfail(IS_WINDOWS_PLATFORM, reason='paths use slash')
class ExpandPathTest(unittest.TestCase):