Improve error reporting on frontend.

This commit is contained in:
Andrey Antukh 2020-10-20 17:31:25 +02:00 committed by Hirunatan
parent 046ee7e475
commit 6448592929
2 changed files with 71 additions and 25 deletions

View file

@ -20,20 +20,24 @@
(http/success? response) (http/success? response)
(rx/of (:body response)) (rx/of (:body response))
(or (http/client-error? response) (= (:status response) 400)
(= 500 (:status response)))
(rx/throw (:body response)) (rx/throw (:body response))
(= 502 (:status response)) (= (:status response) 401)
(rx/throw {:type :bad-gateway (rx/throw {:type :authentication
:body (:body response)}) :code :not-authenticated})
(= (:status response) 403)
(rx/throw {:type :authorization
:code :not-authorized})
(= 0 (:status response)) (= 0 (:status response))
(rx/throw {:type :offline}) (rx/throw {:type :offline})
:else :else
(rx/throw {:type :unexpected (rx/throw {:type :internal-error
:response response}))) :status (:status response)
:body (:body response)})))
(defn send-query! (defn send-query!
[id params] [id params]

View file

@ -9,6 +9,7 @@
(ns app.main.ui (ns app.main.ui
(:require (:require
[app.config :as cfg]
[app.common.data :as d] [app.common.data :as d]
[app.common.exceptions :as ex] [app.common.exceptions :as ex]
[app.common.uuid :as uuid] [app.common.uuid :as uuid]
@ -29,6 +30,8 @@
[app.main.ui.workspace :as workspace] [app.main.ui.workspace :as workspace]
[app.util.i18n :as i18n :refer [tr t]] [app.util.i18n :as i18n :refer [tr t]]
[app.util.timers :as ts] [app.util.timers :as ts]
[cuerdas.core :as str]
[cljs.spec.alpha :as s]
[expound.alpha :as expound] [expound.alpha :as expound]
[potok.core :as ptk] [potok.core :as ptk]
[rumext.alpha :as mf])) [rumext.alpha :as mf]))
@ -162,35 +165,74 @@
(defmethod ptk/handle-error :validation (defmethod ptk/handle-error :validation
[error] [error]
(js/console.error "handle-error(validation):" (if (map? error) (pr-str error) error)) (ts/schedule
(st/emitf (dm/show {:content "Unexpected validation error."
:type :error
:timeout 5000})))
(when-let [explain (:explain error)] (when-let [explain (:explain error)]
(println "============ SERVER RESPONSE ERROR ================") (js/console.group "Server Error")
(println explain) (js/console.error (if (map? error) (pr-str error) error))
(println "============ END SERVER RESPONSE ERROR ================"))) (js/console.error explain)
(js/console.endGroup "Server Error")))
(defmethod ptk/handle-error :authentication (defmethod ptk/handle-error :authentication
[error] [error]
(ts/schedule 0 #(st/emit! logout))) (ts/schedule 0 #(st/emit! logout)))
(defmethod ptk/handle-error :authorization
[error]
(ts/schedule 0 #(st/emit! logout)))
(defmethod ptk/handle-error :assertion (defmethod ptk/handle-error :assertion
[{:keys [data stack] :as error}] [{:keys [data stack message context] :as error}]
(js/console.error stack) (js/console.group message)
(js/console.error (with-out-str (js/console.info (str/format "ns: '%s'\nname: '%s'\nfile: '%s:%s'"
(expound/printer data)))) (:ns context)
(:name context)
(str cfg/public-uri "/js/cljs-runtime/" (:file context))
(:line context)))
(js/console.groupCollapsed "Stack Trace")
(js/console.info stack)
(js/console.groupEnd "Stack Trace")
(js/console.error (with-out-str (expound/printer data)))
(js/console.groupEnd message))
(defmethod ptk/handle-error :default (defmethod ptk/handle-error :default
[error] [error]
(js/console.log error)
(if (instance? ExceptionInfo error) (if (instance? ExceptionInfo error)
(ptk/handle-error (ex-data error)) (ptk/handle-error (ex-data error))
(do (do
(js/console.error "handle-error(default):" (js/console.group "Generic Error:")
(if (map? error) (pr-str error) error)) (ex/ignoring
(ts/schedule 100 #(st/emit! (dm/show {:content "Something wrong has happened." (js/console.error (pr-str error))
:type :error (js/console.error (.-stack error)))
:timeout 5000})))))) (js/console.groupEnd "Generic error")
(ts/schedule (st/emitf (dm/show
{:content "Something wrong has happened."
:type :error
:timeout 5000}))))))
;; (defonce foo (defmethod ptk/handle-error :internal-error
;; (do [{:keys [status] :as error}]
;; (prn "attach listener") (cond
;; (.addEventListener js/window "error" (fn [err] (ptk/handle-error (unchecked-get err "error")))) (= status 429)
;; 1)) (ts/schedule
(st/emitf (dm/show {:content "Too many requests, wait a little bit and retry."
:type :error
:timeout 5000})))
:else
(ts/schedule
(st/emitf (dm/show {:content "Unable to connect to backend, wait a little bit and refresh."
:type :error})))))
(defonce uncaught-error-handler
(letfn [(on-error [event]
(ptk/handle-error (unchecked-get event "error"))
(.preventDefault ^js event))]
(.addEventListener js/window "error" on-error)
(fn []
(.removeEventListener js/window "error" on-error))))