improve error messages

This commit is contained in:
Sina Atalay 2024-02-11 22:43:38 +01:00
parent ba683e861a
commit f6ed75ce84
1 changed files with 32 additions and 5 deletions

View File

@ -58,7 +58,7 @@ def warning(text):
def error(text, exception=None): def error(text, exception=None):
"""Print an error message to the terminal.""" """Print an error message to the terminal."""
if exception is not None: if exception is not None:
exception_messages = exception.args exception_messages = [str(arg) for arg in exception.args]
exception_message = "\n\n".join(exception_messages) exception_message = "\n\n".join(exception_messages)
print( print(
f"\n[bold red]{text}[/bold red]\n\n[orange4]{exception_message}[/orange4]" f"\n[bold red]{text}[/bold red]\n\n[orange4]{exception_message}[/orange4]"
@ -100,25 +100,52 @@ def handle_validation_error(exception: pydantic.ValidationError):
"URL scheme should be 'http' or 'https'": "This is not a valid URL!", "URL scheme should be 'http' or 'https'": "This is not a valid URL!",
"Field required": "This field is required!", "Field required": "This field is required!",
"value is not a valid phone number": "This is not a valid phone number!", "value is not a valid phone number": "This is not a valid phone number!",
"month must be in 1..12": "The month must be between 1 and 12!",
"Value error, day is out of range for month": (
"The day is out of range for the month!"
),
"Extra inputs are not permitted": (
"This field is unknown for this object. Are you sure you are following the"
" correct schema?"
),
} }
new_errors: list[dict[str, str]] = [] new_errors: list[dict[str, str]] = []
end_date_error_is_found = False
for error_object in exception.errors(): for error_object in exception.errors():
message = error_object["msg"] message = error_object["msg"]
location = ".".join([str(loc) for loc in error_object["loc"]]) location = ".".join([str(loc) for loc in error_object["loc"]])
input = error_object["input"] input = error_object["input"]
# remove `.entries.` because that location is not user's location but
# RenderCV's own data model's location
location = location.replace(".entries", "")
custom_error = get_error_message_and_location_and_value_from_a_custom_error( custom_error = get_error_message_and_location_and_value_from_a_custom_error(
message message
) )
if custom_error is None: if custom_error is not None:
if message in error_dictionary:
message = error_dictionary[message]
else:
message = custom_error[0] message = custom_error[0]
if custom_error[1] != "": if custom_error[1] != "":
location = f"{location}.{custom_error[1]}" location = f"{location}.{custom_error[1]}"
input = custom_error[2] input = custom_error[2]
if message in error_dictionary:
message = error_dictionary[message]
# Special case for end_date because Pydantic returns multiple end_date errors
# since it has multiple valid formats:
if "end_date." in location:
if end_date_error_is_found:
continue
end_date_error_is_found = True
# omit the next location after .end_date
# (e.g. avoid stuff like .end_date.literal['present'])
# location = re.sub(r"(\.end_date)\..*", r"\1", location)
message = (
"This is not a valid end date! Please use either YYYY-MM-DD, YYYY-MM,"
' or YYYY format or "present"!'
)
new_errors.append({ new_errors.append({
"loc": str(location), "loc": str(location),
"msg": message, "msg": message,