mirror of
https://github.com/heyarne/airsonic-ui.git
synced 2026-05-07 02:33:39 +02:00
Merge incomplete podcast support
commit 4ac35d6530f7770e7b80307321c72541a55e2c8e
Author: Arne Schlüter <arne@schlueter.is>
Date: Mon Oct 8 21:09:04 2018 +0200
Stub out podcast detail view
commit 60742a22e93bfe6f432e06d56d3e4da671184559
Author: Arne Schlüter <arne@schlueter.is>
Date: Tue Sep 18 23:02:39 2018 +0200
Simplify api helpers; closes #16
commit 8bbc79ebf4dbbe3dbfa08cb4c7c1edd341d507eb
Author: Arne Schlüter <arne@schlueter.is>
Date: Tue Sep 18 19:39:17 2018 +0200
Adjust `stream-url` to work with podcast episodes
commit 991ba5b65230a7429c160ca1b7968ecbb8595e0b
Author: Arne Schlüter <arne@schlueter.is>
Date: Tue Sep 18 19:14:08 2018 +0200
Fix breadcrumbs for podcasts
commit 37c3a894eded2fe37f9af031d3132c7175702266
Author: Arne Schlüter <arne@schlueter.is>
Date: Tue Sep 18 15:11:54 2018 +0200
Stub out overview for podcasts
This commit is contained in:
parent
38eea1c8c9
commit
fa485bbf42
19 changed files with 350 additions and 133 deletions
|
|
@ -10,12 +10,12 @@
|
|||
(api/url server endpoint {}))
|
||||
|
||||
(def fixtures
|
||||
{:default-url (url "http://localhost:8080" "ping")})
|
||||
{:default-url (url {:server "http://localhost:8080"} "ping")})
|
||||
|
||||
(deftest general-url-construction
|
||||
(testing "Handles missing slashes"
|
||||
(is (true? (str/starts-with? (fixtures :default-url) "http://localhost:8080/rest/ping")))
|
||||
(is (true? (str/starts-with? (url "http://localhost:8080/" "ping") "http://localhost:8080/rest/ping"))))
|
||||
(is (true? (str/starts-with? (url {:server "http://localhost:8080"} "ping") "http://localhost:8080/rest/ping")))
|
||||
(is (true? (str/starts-with? (url {:server "http://localhost:8080/"} "ping") "http://localhost:8080/rest/ping"))))
|
||||
(testing "Should set correct default parameters"
|
||||
(is (string? (re-find #"f=json" (fixtures :default-url))))
|
||||
(is (string? (re-find #"v=1\.15\.0" (fixtures :default-url))))))
|
||||
|
|
@ -24,19 +24,22 @@
|
|||
(testing "Should escape url parameters"
|
||||
(let [query "äöüß"
|
||||
encoded-str (js/encodeURIComponent query)]
|
||||
(is (str/includes? (api/url "http://localhost" "search3" {:query query}) encoded-str)))))
|
||||
(is (str/includes? (api/url {:server "http://localhost"} "search3" {:query query}) encoded-str)))))
|
||||
|
||||
(deftest song-urls
|
||||
(deftest stream-urls
|
||||
(testing "Should construct the url based on a song's id"
|
||||
(let [song {:id 1234}]
|
||||
(is (true? (str/includes? (api/song-url "http://localhost" {} song) (str "id=" (:id song))))))))
|
||||
(let [stream-url (api/stream-url {:server "http://localhost"} fixtures/song)]
|
||||
(is (str/includes? stream-url (str "id=" (:id fixtures/song))))))
|
||||
(testing "Should also work for podcasts"
|
||||
(let [stream-url (api/stream-url {:server "http://localhost"} fixtures/podcast-episode)]
|
||||
(is (str/includes? stream-url (str "id=" (:streamId fixtures/podcast-episode)))))))
|
||||
|
||||
(deftest cover-urls
|
||||
(let [album {:coverArt "cover-99999"}]
|
||||
(testing "Should construct the url based on an item's cover-id"
|
||||
(is (true? (str/includes? (api/cover-url "http://server.tld" {} album -1) (str "id=" (:coverArt album))))))
|
||||
(is (true? (str/includes? (api/cover-url {:server "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"))))))
|
||||
(is (true? (str/includes? (api/cover-url {:server "http://server.tld"} album 48) "size=48"))))))
|
||||
|
||||
(deftest response-handling
|
||||
(testing "Should unwrap responses"
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue