mirror of
https://github.com/heyarne/airsonic-ui.git
synced 2026-05-06 18:33:38 +02:00
Add user notifications and display api errors (#10)
Closes #2 * Add user notifications * Update re-frame-10x config * Display api errors as notifications * Automatically hide notifications after a while
This commit is contained in:
parent
187f001414
commit
ab7519f289
12 changed files with 232 additions and 42 deletions
|
|
@ -1,6 +1,7 @@
|
|||
(ns airsonic-ui.events-test
|
||||
(:require [cljs.test :refer [deftest testing is]]
|
||||
[clojure.string :as str]
|
||||
[airsonic-ui.fixtures :refer [responses]]
|
||||
[airsonic-ui.events :as events]))
|
||||
|
||||
(enable-console-print!)
|
||||
|
|
@ -16,8 +17,14 @@
|
|||
(testing "saves the given server location"
|
||||
(is (= server (get-in fx [:db :credentials :server]))))
|
||||
(testing "invokes correct success callback"
|
||||
(is (= ::events/credentials-verified (first (:on-success request)))))))
|
||||
(testing "On succesfull response"
|
||||
(is (= ::events/verify-auth-response (first (:on-success request)))))))
|
||||
(testing "Auth response verification"
|
||||
(is (= :notification/show
|
||||
(first (:dispatch (events/verify-auth-response {} [:_ "user" "pass" (:error responses)]))))
|
||||
"shows an error when we have an error response")
|
||||
(let [event (:dispatch (events/verify-auth-response {} [:_ "username" "password" (:auth-success responses)]))]
|
||||
(is (= [::events/credentials-verified "username" "password"] event))))
|
||||
(testing "On succesful response"
|
||||
(let [creds-before {:server "https://localhost"}
|
||||
fx (events/credentials-verified {:db {:credentials creds-before}}
|
||||
[:_ "user" "pass"])
|
||||
|
|
@ -43,3 +50,34 @@
|
|||
(testing "When there's no previous login data"
|
||||
(testing "remembering has no effect"
|
||||
(is (nil? (events/try-remember-user {} [:_]))))))
|
||||
|
||||
(defn- first-notification [fx]
|
||||
(-> (get-in fx [:db :notifications]) vals first))
|
||||
|
||||
(deftest api-interaction
|
||||
(testing "Should show an error notification when airsonic responds with an error"
|
||||
(let [fx (events/good-api-response {} [:_ (:error responses)])]
|
||||
(is (= :error (-> fx :dispatch second))))))
|
||||
|
||||
(deftest user-notifications
|
||||
(testing "Should be able to display a message with an assigned level"
|
||||
(is (= :error (:level (first-notification (events/show-notification {} [:_ :error "foo"])))))
|
||||
(is (= :info (:level (first-notification (events/show-notification {} [:_ :info "some other message"]))))))
|
||||
(testing "Should default to level :info"
|
||||
(is (= :info (:level (first-notification (events/show-notification {} [:_ "and another one"]))))))
|
||||
(testing "Should create a unique id for each message"
|
||||
(let [state (->
|
||||
{}
|
||||
(events/show-notification [:_ :info "Something something"])
|
||||
(events/show-notification [:_ :error "Something important"]))
|
||||
ids (keys (:notifications state))]
|
||||
(is (= (count ids) (count (set ids))))))
|
||||
(testing "Should remove a message, given it's id"
|
||||
(let [state (events/show-notification {} [:_ "This is a notification"])
|
||||
id (-> (:notifications state)
|
||||
keys
|
||||
first)]
|
||||
(is (empty? (:notifications (events/hide-notification state [:_ id]))))))
|
||||
(testing "Should automatically remove a message after a while"
|
||||
(let [fx (events/show-notification {} [:_ :info "This is a notification"])]
|
||||
(is (= :notification/hide (-> (:dispatch-later fx) first :dispatch first))))))
|
||||
|
|
|
|||
14
test/cljs/airsonic_ui/fixtures.cljs
Normal file
14
test/cljs/airsonic_ui/fixtures.cljs
Normal file
|
|
@ -0,0 +1,14 @@
|
|||
(ns airsonic-ui.fixtures)
|
||||
|
||||
(def responses {:error {:subsonic-response
|
||||
{:error {:code 40
|
||||
:message "Wrong username or password"}
|
||||
:status "failed"
|
||||
:version "1.15.0"}}
|
||||
:ok {:subsonic-response
|
||||
{:scanStatus {:count 10326
|
||||
:scanning false}
|
||||
:status "ok"
|
||||
:version "1.15.0"}}
|
||||
:auth-success {:subsonic-response {:status "ok"
|
||||
:version "1.15.0"}}})
|
||||
|
|
@ -1,6 +1,7 @@
|
|||
(ns airsonic-ui.utils.api-test
|
||||
(:require [cljs.test :refer [deftest testing is]]
|
||||
[clojure.string :as str]
|
||||
[airsonic-ui.fixtures :refer [responses]]
|
||||
[airsonic-ui.utils.api :as api]))
|
||||
|
||||
(defn- url
|
||||
|
|
@ -30,3 +31,19 @@
|
|||
(is (true? (str/includes? (api/cover-url "http://server.tld" {} album -1) (str "id=" (:coverArt album))))))
|
||||
(testing "Should scale an image to a given size"
|
||||
(is (true? (str/includes? (api/cover-url "http://server.tld" {} album 48) "size=48"))))))
|
||||
|
||||
(deftest response-handling
|
||||
(testing "Should unwrap responses"
|
||||
(let [response (:ok responses)]
|
||||
(is (= (get-in response [:subsonic-response :scanStatus])
|
||||
(api/unwrap-response response)))))
|
||||
(testing "Should detect errors"
|
||||
(is (true? (api/is-error? (:error responses))))
|
||||
(is (false? (api/is-error? (:ok responses)))))
|
||||
(testing "Should throw an informative error when trying to unwrap an erroneous response"
|
||||
(let [error-response (:error responses)]
|
||||
(is (thrown? ExceptionInfo (api/unwrap-response error-response)))
|
||||
(try
|
||||
(api/unwrap-response error-response)
|
||||
(catch ExceptionInfo e
|
||||
(= (:error error-response) (ex-data e)))))))
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue