Merge pull request #6326 from docker/6325-fix-validation-error-parsing

Fix validation error parsing to not raise on non-string keys
This commit is contained in:
Joffrey F 2018-11-05 14:27:03 -08:00 committed by GitHub
commit 8edb0d872d
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 17 additions and 1 deletions

View File

@ -330,7 +330,10 @@ def handle_generic_error(error, path):
def parse_key_from_error_msg(error): def parse_key_from_error_msg(error):
try:
return error.message.split("'")[1] return error.message.split("'")[1]
except IndexError:
return error.message.split('(')[1].split(' ')[0].strip("'")
def path_string(path): def path_string(path):

View File

@ -613,6 +613,19 @@ class ConfigTest(unittest.TestCase):
excinfo.exconly() excinfo.exconly()
) )
def test_config_integer_service_property_raise_validation_error(self):
with pytest.raises(ConfigurationError) as excinfo:
config.load(
build_config_details({
'version': '2.1',
'services': {'foobar': {'image': 'busybox', 1234: 'hah'}}
}, 'working_dir', 'filename.yml')
)
assert (
"Unsupported config option for services.foobar: '1234'" in excinfo.exconly()
)
def test_config_invalid_service_name_raise_validation_error(self): def test_config_invalid_service_name_raise_validation_error(self):
with pytest.raises(ConfigurationError) as excinfo: with pytest.raises(ConfigurationError) as excinfo:
config.load( config.load(