From 1012e416203fc57f17d4a4c38726f76defb8ce1d Mon Sep 17 00:00:00 2001 From: Yahor Berdnikau Date: Sat, 11 Nov 2017 20:07:15 +0100 Subject: [PATCH] Add createShare api call. Signed-off-by: Yahor Berdnikau --- .../subsonic/SubsonicApiCreateShareTest.kt | 78 +++++++++++++++++++ .../api/subsonic/SubsonicApiGetSharesTest.kt | 2 +- .../resources/get_shares_ok.json | 2 +- .../api/subsonic/SubsonicAPIDefinition.kt | 5 ++ 4 files changed, 85 insertions(+), 2 deletions(-) create mode 100644 subsonic-api/src/integrationTest/kotlin/org/moire/ultrasonic/api/subsonic/SubsonicApiCreateShareTest.kt diff --git a/subsonic-api/src/integrationTest/kotlin/org/moire/ultrasonic/api/subsonic/SubsonicApiCreateShareTest.kt b/subsonic-api/src/integrationTest/kotlin/org/moire/ultrasonic/api/subsonic/SubsonicApiCreateShareTest.kt new file mode 100644 index 00000000..caebfde4 --- /dev/null +++ b/subsonic-api/src/integrationTest/kotlin/org/moire/ultrasonic/api/subsonic/SubsonicApiCreateShareTest.kt @@ -0,0 +1,78 @@ +package org.moire.ultrasonic.api.subsonic + +import org.amshove.kluent.`should equal to` +import org.amshove.kluent.`should equal` +import org.junit.Test +import org.moire.ultrasonic.api.subsonic.models.MusicDirectoryChild +import java.util.Calendar + +/** + * Instrumentation test for [SubsonicAPIDefinition.createShare] call. + */ +class SubsonicApiCreateShareTest : SubsonicAPIClientTest() { + @Test + fun `Should handle error responce`() { + val response = checkErrorCallParsed(mockWebServerRule) { + client.api.createShare(listOf("some-id")).execute() + } + + response.shares `should equal` emptyList() + } + + @Test + fun `Should handle ok response`() { + mockWebServerRule.enqueueResponse("get_shares_ok.json") + + val response = client.api.createShare(listOf("some-id")).execute() + + assertResponseSuccessful(response) + response.body().shares.size `should equal to` 1 + with(response.body().shares[0]) { + id `should equal to` 0 + url `should equal to` "https://subsonic.com/ext/share/awdwo?jwt=eyJhbGciOiJIUzI1NiJ9." + + "eyJwYXRoIjoiL2V4dC9zaGFyZS9hd2R3byIsImV4cCI6MTU0MTYyNjQzMX0.iy8dkt_ZZc8hJ692" + + "UxorHdHWFU2RB-fMCmCA4IJ_dTw" + username `should equal to` "admin" + created `should equal` parseDate("2017-11-07T21:33:51.748Z") + expires `should equal` parseDate("2018-11-07T21:33:51.748Z") + lastVisited `should equal` parseDate("2018-11-07T21:33:51.748Z") + description `should equal to` "Awesome link!" + visitCount `should equal to` 0 + items.size `should equal to` 1 + items[0] `should equal` MusicDirectoryChild(id = 4212, parent = 4186, isDir = false, + title = "Heaven Knows", album = "Going to Hell", artist = "The Pretty Reckless", + track = 3, year = 2014, genre = "Hard Rock", coverArt = "4186", size = 9025090, + contentType = "audio/mpeg", suffix = "mp3", duration = 225, bitRate = 320, + path = "The Pretty Reckless/Going to Hell/03 Heaven Knows.mp3", isVideo = false, + playCount = 2, discNumber = 1, created = parseDate("2016-10-23T21:30:40.000Z"), + albumId = 388, artistId = 238, type = "music") + } + } + + @Test + fun `Should pass ids in request param`() { + val idsList = listOf("some-id1", "some-id2") + mockWebServerRule.assertRequestParam(expectedParam = "id=${idsList[0]}&id=${idsList[1]}") { + client.api.createShare(idsList).execute() + } + } + + @Test + fun `Should pass description in request param`() { + val description = "description-banana" + + mockWebServerRule.assertRequestParam(expectedParam = "description=$description") { + client.api.createShare(idsToShare = listOf("id1", "id2"), description = description) + .execute() + } + } + + @Test + fun `Should pass expires in request param`() { + val expires = Calendar.getInstance().timeInMillis + + mockWebServerRule.assertRequestParam(expectedParam = "expires=$expires") { + client.api.createShare(idsToShare = listOf("id1"), expires = expires).execute() + } + } +} diff --git a/subsonic-api/src/integrationTest/kotlin/org/moire/ultrasonic/api/subsonic/SubsonicApiGetSharesTest.kt b/subsonic-api/src/integrationTest/kotlin/org/moire/ultrasonic/api/subsonic/SubsonicApiGetSharesTest.kt index dd98c2d2..8fc2dc28 100644 --- a/subsonic-api/src/integrationTest/kotlin/org/moire/ultrasonic/api/subsonic/SubsonicApiGetSharesTest.kt +++ b/subsonic-api/src/integrationTest/kotlin/org/moire/ultrasonic/api/subsonic/SubsonicApiGetSharesTest.kt @@ -28,7 +28,7 @@ class SubsonicApiGetSharesTest : SubsonicAPIClientTest() { response.body().shares.size `should equal to` 1 with(response.body().shares[0]) { id `should equal to` 0 - url `should equal to` "https://airsonic.egorr.by/ext/share/awdwo?jwt=eyJhbGciOiJIUzI1" + + url `should equal to` "https://subsonic.com/ext/share/awdwo?jwt=eyJhbGciOiJIUzI1" + "NiJ9.eyJwYXRoIjoiL2V4dC9zaGFyZS9hd2R3byIsImV4cCI6MTU0MTYyNjQzMX0.iy8dkt_ZZc8" + "hJ692UxorHdHWFU2RB-fMCmCA4IJ_dTw" username `should equal to` "admin" diff --git a/subsonic-api/src/integrationTest/resources/get_shares_ok.json b/subsonic-api/src/integrationTest/resources/get_shares_ok.json index 1a165c94..b6c11b52 100644 --- a/subsonic-api/src/integrationTest/resources/get_shares_ok.json +++ b/subsonic-api/src/integrationTest/resources/get_shares_ok.json @@ -5,7 +5,7 @@ "shares" : { "share" : [ { "id" : "0", - "url" : "https://airsonic.egorr.by/ext/share/awdwo?jwt=eyJhbGciOiJIUzI1NiJ9.eyJwYXRoIjoiL2V4dC9zaGFyZS9hd2R3byIsImV4cCI6MTU0MTYyNjQzMX0.iy8dkt_ZZc8hJ692UxorHdHWFU2RB-fMCmCA4IJ_dTw", + "url" : "https://subsonic.com/ext/share/awdwo?jwt=eyJhbGciOiJIUzI1NiJ9.eyJwYXRoIjoiL2V4dC9zaGFyZS9hd2R3byIsImV4cCI6MTU0MTYyNjQzMX0.iy8dkt_ZZc8hJ692UxorHdHWFU2RB-fMCmCA4IJ_dTw", "username" : "admin", "created" : "2017-11-07T21:33:51.748Z", "expires" : "2018-11-07T21:33:51.748Z", diff --git a/subsonic-api/src/main/kotlin/org/moire/ultrasonic/api/subsonic/SubsonicAPIDefinition.kt b/subsonic-api/src/main/kotlin/org/moire/ultrasonic/api/subsonic/SubsonicAPIDefinition.kt index 4650afba..afce5798 100644 --- a/subsonic-api/src/main/kotlin/org/moire/ultrasonic/api/subsonic/SubsonicAPIDefinition.kt +++ b/subsonic-api/src/main/kotlin/org/moire/ultrasonic/api/subsonic/SubsonicAPIDefinition.kt @@ -192,4 +192,9 @@ interface SubsonicAPIDefinition { @GET("getShares.view") fun getShares(): Call + + @GET("createShare.view") + fun createShare(@Query("id") idsToShare: List, + @Query("description") description: String? = null, + @Query("expires") expires: Long? = null): Call }