|
@@ -260,7 +260,8 @@ class Yedit(object):
|
|
|
continue
|
|
|
|
|
|
elif data and not isinstance(data, dict):
|
|
|
- return None
|
|
|
+ raise YeditException("Unexpected item type found while going through key " +
|
|
|
+ "path: {} (at key: {})".format(key, dict_key))
|
|
|
|
|
|
data[dict_key] = {}
|
|
|
data = data[dict_key]
|
|
@@ -269,7 +270,7 @@ class Yedit(object):
|
|
|
int(arr_ind) <= len(data) - 1):
|
|
|
data = data[int(arr_ind)]
|
|
|
else:
|
|
|
- return None
|
|
|
+ raise YeditException("Unexpected item type found while going through key path: {}".format(key))
|
|
|
|
|
|
if key == '':
|
|
|
data = item
|
|
@@ -283,6 +284,12 @@ class Yedit(object):
|
|
|
elif key_indexes[-1][1] and isinstance(data, dict):
|
|
|
data[key_indexes[-1][1]] = item
|
|
|
|
|
|
+ # didn't add/update to an existing list, nor add/update key to a dict
|
|
|
+ # so we must have been provided some syntax like a.b.c[<int>] = "data" for a
|
|
|
+ # non-existent array
|
|
|
+ else:
|
|
|
+ raise YeditException("Error adding to object at path: {}".format(key))
|
|
|
+
|
|
|
return data
|
|
|
|
|
|
@staticmethod
|
|
@@ -1276,8 +1283,8 @@ class Utils(object):
|
|
|
elif value != user_def[key]:
|
|
|
if debug:
|
|
|
print('value should be identical')
|
|
|
- print(value)
|
|
|
print(user_def[key])
|
|
|
+ print(value)
|
|
|
return False
|
|
|
|
|
|
# recurse on a dictionary
|
|
@@ -1297,8 +1304,8 @@ class Utils(object):
|
|
|
if api_values != user_values:
|
|
|
if debug:
|
|
|
print("keys are not equal in dict")
|
|
|
- print(api_values)
|
|
|
print(user_values)
|
|
|
+ print(api_values)
|
|
|
return False
|
|
|
|
|
|
result = Utils.check_def_equal(user_def[key], value, skip_keys=skip_keys, debug=debug)
|