mirror of
https://github.com/navidrome/navidrome.git
synced 2025-04-04 21:17:37 +03:00
Fix getOpenSubsonicExtensions endpoint
Match the current doc: https://opensubsonic.netlify.app/docs/endpoints/getopensubsonicextensions/ openSubsonicExtensions must be an array, not a struct
This commit is contained in:
parent
60a5fbe1fe
commit
f543e7accc
6 changed files with 68 additions and 2 deletions
|
@ -0,0 +1,16 @@
|
||||||
|
{
|
||||||
|
"status": "ok",
|
||||||
|
"version": "1.8.0",
|
||||||
|
"type": "navidrome",
|
||||||
|
"serverVersion": "v0.0.0",
|
||||||
|
"openSubsonic": true,
|
||||||
|
"openSubsonicExtensions": [
|
||||||
|
{
|
||||||
|
"name": "template",
|
||||||
|
"versions": [
|
||||||
|
1,
|
||||||
|
2
|
||||||
|
]
|
||||||
|
}
|
||||||
|
]
|
||||||
|
}
|
|
@ -0,0 +1,6 @@
|
||||||
|
<subsonic-response xmlns="http://subsonic.org/restapi" status="ok" version="1.8.0" type="navidrome" serverVersion="v0.0.0" openSubsonic="true">
|
||||||
|
<openSubsonicExtensions name="template">
|
||||||
|
<versions>1</versions>
|
||||||
|
<versions>2</versions>
|
||||||
|
</openSubsonicExtensions>
|
||||||
|
</subsonic-response>
|
|
@ -0,0 +1,8 @@
|
||||||
|
{
|
||||||
|
"status": "ok",
|
||||||
|
"version": "1.8.0",
|
||||||
|
"type": "navidrome",
|
||||||
|
"serverVersion": "v0.0.0",
|
||||||
|
"openSubsonic": true,
|
||||||
|
"openSubsonicExtensions": []
|
||||||
|
}
|
|
@ -0,0 +1 @@
|
||||||
|
<subsonic-response xmlns="http://subsonic.org/restapi" status="ok" version="1.8.0" type="navidrome" serverVersion="v0.0.0" openSubsonic="true"></subsonic-response>
|
|
@ -424,13 +424,18 @@ type JukeboxPlaylist struct {
|
||||||
JukeboxStatus
|
JukeboxStatus
|
||||||
Entry []Child `xml:"entry,omitempty" json:"entry,omitempty"`
|
Entry []Child `xml:"entry,omitempty" json:"entry,omitempty"`
|
||||||
}
|
}
|
||||||
type OpenSubsonicExtensions struct{}
|
type OpenSubsonicExtension struct {
|
||||||
|
Name string `xml:"name,attr" json:"name"`
|
||||||
|
Versions []int32 `xml:"versions" json:"versions"`
|
||||||
|
}
|
||||||
|
|
||||||
|
type OpenSubsonicExtensions []OpenSubsonicExtension
|
||||||
|
|
||||||
// OpenSubsonic response type for multi-valued genres list
|
|
||||||
type ItemGenre struct {
|
type ItemGenre struct {
|
||||||
Name string `xml:"name,attr" json:"name"`
|
Name string `xml:"name,attr" json:"name"`
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// ItemGenres holds a list of genres (OpenSubsonic). If it is null, it must be marshalled as an empty array.
|
||||||
type ItemGenres []ItemGenre
|
type ItemGenres []ItemGenre
|
||||||
|
|
||||||
func (i ItemGenres) MarshalJSON() ([]byte, error) {
|
func (i ItemGenres) MarshalJSON() ([]byte, error) {
|
||||||
|
|
|
@ -725,6 +725,36 @@ var _ = Describe("Responses", func() {
|
||||||
})
|
})
|
||||||
})
|
})
|
||||||
|
|
||||||
|
Describe("OpenSubsonicExtensions", func() {
|
||||||
|
BeforeEach(func() {
|
||||||
|
response.OpenSubsonic = true
|
||||||
|
response.OpenSubsonicExtensions = &OpenSubsonicExtensions{}
|
||||||
|
})
|
||||||
|
|
||||||
|
Describe("without data", func() {
|
||||||
|
It("should match .XML", func() {
|
||||||
|
Expect(xml.MarshalIndent(response, "", " ")).To(MatchSnapshot())
|
||||||
|
})
|
||||||
|
It("should match .JSON", func() {
|
||||||
|
Expect(json.MarshalIndent(response, "", " ")).To(MatchSnapshot())
|
||||||
|
})
|
||||||
|
})
|
||||||
|
|
||||||
|
Describe("with data", func() {
|
||||||
|
BeforeEach(func() {
|
||||||
|
response.OpenSubsonicExtensions = &OpenSubsonicExtensions{
|
||||||
|
OpenSubsonicExtension{Name: "template", Versions: []int32{1, 2}},
|
||||||
|
}
|
||||||
|
})
|
||||||
|
It("should match .XML", func() {
|
||||||
|
Expect(xml.MarshalIndent(response, "", " ")).To(MatchSnapshot())
|
||||||
|
})
|
||||||
|
It("should match .JSON", func() {
|
||||||
|
Expect(json.MarshalIndent(response, "", " ")).To(MatchSnapshot())
|
||||||
|
})
|
||||||
|
})
|
||||||
|
})
|
||||||
|
|
||||||
Describe("InternetRadioStations", func() {
|
Describe("InternetRadioStations", func() {
|
||||||
BeforeEach(func() {
|
BeforeEach(func() {
|
||||||
response.InternetRadioStations = &InternetRadioStations{}
|
response.InternetRadioStations = &InternetRadioStations{}
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue