mirror of https://github.com/docker/compose.git
Move extends validation into ServiceLoader class
This refactoring allows us to raise an error when there is no 'file' key specified in the .yml and no self.filename set. This error was specific to the tests, as the tests are the only place that constructs service dicts without sometimes setting a filename. Moving the function within the class as well as it is code that is exclusively for the use of validating properties for the ServiceLoader class. Signed-off-by: Mazz Mosley <mazz@houseofmnowster.com>
This commit is contained in:
parent
24c1d95869
commit
254bc4908c
|
@ -158,7 +158,7 @@ class ServiceLoader(object):
|
||||||
if 'extends' not in service_dict:
|
if 'extends' not in service_dict:
|
||||||
return service_dict
|
return service_dict
|
||||||
|
|
||||||
extends_options = validate_extends_options(service_dict['name'], service_dict['extends'])
|
extends_options = self.validate_extends_options(service_dict['name'], service_dict['extends'])
|
||||||
|
|
||||||
if self.working_dir is None:
|
if self.working_dir is None:
|
||||||
raise Exception("No working_dir passed to ServiceLoader()")
|
raise Exception("No working_dir passed to ServiceLoader()")
|
||||||
|
@ -194,8 +194,7 @@ class ServiceLoader(object):
|
||||||
def signature(self, name):
|
def signature(self, name):
|
||||||
return (self.filename, name)
|
return (self.filename, name)
|
||||||
|
|
||||||
|
def validate_extends_options(self, service_name, extends_options):
|
||||||
def validate_extends_options(service_name, extends_options):
|
|
||||||
error_prefix = "Invalid 'extends' configuration for %s:" % service_name
|
error_prefix = "Invalid 'extends' configuration for %s:" % service_name
|
||||||
|
|
||||||
if not isinstance(extends_options, dict):
|
if not isinstance(extends_options, dict):
|
||||||
|
@ -206,6 +205,11 @@ def validate_extends_options(service_name, extends_options):
|
||||||
"%s you need to specify a service, e.g. 'service: web'" % error_prefix
|
"%s you need to specify a service, e.g. 'service: web'" % error_prefix
|
||||||
)
|
)
|
||||||
|
|
||||||
|
if 'file' not in extends_options and self.filename is None:
|
||||||
|
raise ConfigurationError(
|
||||||
|
"%s you need to specify a 'file', e.g. 'file: something.yml'" % error_prefix
|
||||||
|
)
|
||||||
|
|
||||||
for k, _ in extends_options.items():
|
for k, _ in extends_options.items():
|
||||||
if k not in ['file', 'service']:
|
if k not in ['file', 'service']:
|
||||||
raise ConfigurationError(
|
raise ConfigurationError(
|
||||||
|
|
|
@ -459,6 +459,14 @@ class ExtendsTest(unittest.TestCase):
|
||||||
|
|
||||||
self.assertRaisesRegexp(config.ConfigurationError, 'what', load_config)
|
self.assertRaisesRegexp(config.ConfigurationError, 'what', load_config)
|
||||||
|
|
||||||
|
def test_extends_validation_no_file_key_no_filename_set(self):
|
||||||
|
dictionary = {'extends': {'service': 'web'}}
|
||||||
|
|
||||||
|
def load_config():
|
||||||
|
return config.make_service_dict('myweb', dictionary, working_dir='tests/fixtures/extends')
|
||||||
|
|
||||||
|
self.assertRaisesRegexp(config.ConfigurationError, 'file', load_config)
|
||||||
|
|
||||||
def test_extends_validation_valid_config(self):
|
def test_extends_validation_valid_config(self):
|
||||||
dictionary = {'extends': {'service': 'web', 'file': 'common.yml'}}
|
dictionary = {'extends': {'service': 'web', 'file': 'common.yml'}}
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue