From 01949d52277d09928d5b09f93e52d554af07e220 Mon Sep 17 00:00:00 2001 From: Markku Laine Date: Mon, 25 Apr 2022 17:04:45 +0300 Subject: [PATCH] refactor(errorhandling): improve UX in error handling --- backend/aim/handlers.py | 29 ++++++++++++++++++++++++++--- frontend/src/components/AIMForm.vue | 12 +++++++++++- 2 files changed, 37 insertions(+), 4 deletions(-) diff --git a/backend/aim/handlers.py b/backend/aim/handlers.py index b13b72e..5b654a0 100644 --- a/backend/aim/handlers.py +++ b/backend/aim/handlers.py @@ -27,7 +27,6 @@ import tornado.websocket from loguru import logger from motor.motor_tornado import MotorDatabase -from pydantic.error_wrappers import ValidationError from selenium.webdriver.chrome.webdriver import WebDriver as ChromeWebDriver from tornado.options import options @@ -40,6 +39,7 @@ METRICS_DIR, METRICS_FILE_PATTERN, ) +from aim.exceptions import ValidationError from aim.models import MessageBase, MessageImage, MessageInput, MessageURL from aim.tools import Screenshot @@ -246,7 +246,30 @@ def on_message(self, message: Union[str, bytes]): "session": session_id, "datetime": utils.custom_isoformat(datetime.utcnow()), "type": "ValidationError", - "message": e.errors(), + "message": str(e), + }, + ) + + # Push error + self.write_message( + { + "type": "error", + "action": "pushValidationError", + "message": str(e), + } + ) + except ValueError as e: + logger.error("ValueError", e) + + # Save error data + self._save_data( + "errors", + { + "server": server_name, + "session": session_id, + "datetime": utils.custom_isoformat(datetime.utcnow()), + "type": "ValueError", + "message": e.errors()[0]["msg"], # type: ignore }, ) @@ -255,7 +278,7 @@ def on_message(self, message: Union[str, bytes]): { "type": "error", "action": "pushValidationError", - "message": e.errors(), + "message": e.errors()[0]["msg"], # type: ignore } ) except NotImplementedError as e: diff --git a/frontend/src/components/AIMForm.vue b/frontend/src/components/AIMForm.vue index 1297142..f643436 100644 --- a/frontend/src/components/AIMForm.vue +++ b/frontend/src/components/AIMForm.vue @@ -30,7 +30,7 @@

Validation Error


- Whoops! We are having some problems with your input, please try again with a different URL or image. + Whoops! We are having some problems with your input. Please refresh the page and try again with a different URL or image.

@@ -66,6 +66,9 @@
File is too large (max 5 MB).
+
+ Minimum size is 1280 x 800 pixels. +
@@ -748,6 +751,13 @@ header{ .input-group.is-invalid ~ .invalid-feedback { display: block; } +.image-min-size { + color: #999999; + display: block; + font-size: 80%; + margin-top: 0.25rem; + width: 100%; +} .custom-control { display: inline;