process_errors handle both schemas

Now the schema has been split into two, we need to modify the
process_errors function to accomodate.

Previously if an error.path was empty then it meant they were root
errors. Now that service_schema checks after the service has been
resolved, our service name is a key within the dictionary and
so our root error logic check is no longer true.

Signed-off-by: Mazz Mosley <mazz@houseofmnowster.com>
This commit is contained in:
Mazz Mosley 2015-08-31 17:52:00 +01:00
parent 950577d60f
commit 9fa6e42f55
1 changed files with 8 additions and 6 deletions

View File

@ -125,7 +125,7 @@ def process_errors(errors):
for error in errors: for error in errors:
# handle root level errors # handle root level errors
if len(error.path) == 0: if len(error.path) == 0 and not error.instance.get('name'):
if error.validator == 'type': if error.validator == 'type':
msg = "Top level object needs to be a dictionary. Check your .yml file that you have defined a service at the top level." msg = "Top level object needs to be a dictionary. Check your .yml file that you have defined a service at the top level."
root_msgs.append(msg) root_msgs.append(msg)
@ -137,11 +137,13 @@ def process_errors(errors):
root_msgs.append(_clean_error_message(error.message)) root_msgs.append(_clean_error_message(error.message))
else: else:
# handle service level errors try:
# field_schema errors will have service name on the path
service_name = error.path[0] service_name = error.path[0]
# pop the service name off our path
error.path.popleft() error.path.popleft()
except IndexError:
# service_schema errors will have the name in the instance
service_name = error.instance.get('name')
if error.validator == 'additionalProperties': if error.validator == 'additionalProperties':
invalid_config_key = _parse_key_from_error_msg(error) invalid_config_key = _parse_key_from_error_msg(error)