mirror of
https://github.com/heyarne/airsonic-ui.git
synced 2026-05-07 02:33:39 +02:00
Display api errors as notifications
This commit is contained in:
parent
7fd5e6189d
commit
aa04e68545
9 changed files with 118 additions and 61 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"])
|
||||
|
|
@ -47,6 +54,11 @@
|
|||
(defn- first-notification [db]
|
||||
(-> (:notifications db) 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"])))))
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue