mirror of
https://github.com/navidrome/navidrome.git
synced 2025-04-04 21:17:37 +03:00
99 lines
3.2 KiB
Go
99 lines
3.2 KiB
Go
package api_test
|
|
|
|
import (
|
|
"testing"
|
|
|
|
"github.com/deluan/gosonic/api/responses"
|
|
"github.com/deluan/gosonic/consts"
|
|
"github.com/deluan/gosonic/domain"
|
|
"github.com/deluan/gosonic/engine"
|
|
. "github.com/deluan/gosonic/tests"
|
|
"github.com/deluan/gosonic/tests/mocks"
|
|
"github.com/deluan/gosonic/utils"
|
|
. "github.com/smartystreets/goconvey/convey"
|
|
)
|
|
|
|
const (
|
|
emptyResponse = `{"indexes":{"ignoredArticles":"The El La Los Las Le Les Os As O A","lastModified":"1"}`
|
|
)
|
|
|
|
func TestGetIndexes(t *testing.T) {
|
|
Init(t, false)
|
|
|
|
mockRepo := mocks.CreateMockArtistIndexRepo()
|
|
utils.DefineSingleton(new(domain.ArtistIndexRepository), func() domain.ArtistIndexRepository {
|
|
return mockRepo
|
|
})
|
|
propRepo := mocks.CreateMockPropertyRepo()
|
|
utils.DefineSingleton(new(engine.PropertyRepository), func() engine.PropertyRepository {
|
|
return propRepo
|
|
})
|
|
|
|
mockRepo.SetData("[]", 0)
|
|
mockRepo.SetError(false)
|
|
propRepo.Put(consts.LastScan, "1")
|
|
propRepo.SetError(false)
|
|
|
|
Convey("Subject: GetIndexes Endpoint", t, func() {
|
|
Convey("Return fail on Index Table error", func() {
|
|
mockRepo.SetError(true)
|
|
_, w := Get(AddParams("/rest/getIndexes.view", "ifModifiedSince=0"), "TestGetIndexes")
|
|
|
|
So(w.Body, ShouldReceiveError, responses.ERROR_GENERIC)
|
|
})
|
|
Convey("Return fail on Property Table error", func() {
|
|
propRepo.SetError(true)
|
|
_, w := Get(AddParams("/rest/getIndexes.view"), "TestGetIndexes")
|
|
|
|
So(w.Body, ShouldReceiveError, responses.ERROR_GENERIC)
|
|
})
|
|
Convey("When the index is empty", func() {
|
|
_, w := Get(AddParams("/rest/getIndexes.view"), "TestGetIndexes")
|
|
|
|
Convey("Status code should be 200", func() {
|
|
So(w.Code, ShouldEqual, 200)
|
|
})
|
|
Convey("Then it should return an empty collection", func() {
|
|
So(UnindentJSON(w.Body.Bytes()), ShouldContainSubstring, emptyResponse)
|
|
})
|
|
})
|
|
Convey("When the index is not empty", func() {
|
|
mockRepo.SetData(`[{"Id": "A","Artists": [
|
|
{"ArtistId": "21", "Artist": "Afrolicious"}
|
|
]}]`, 2)
|
|
|
|
SkipConvey("Then it should return the the items in the response", func() {
|
|
_, w := Get(AddParams("/rest/getIndexes.view"), "TestGetIndexes")
|
|
|
|
So(w.Body.String(), ShouldContainSubstring,
|
|
`<index name="A"><artist id="21" name="Afrolicious"></artist></index>`)
|
|
})
|
|
})
|
|
Convey("And it should return empty if 'ifModifiedSince' is more recent than the index", func() {
|
|
mockRepo.SetData(`[{"Id": "A","Artists": [
|
|
{"ArtistId": "21", "Artist": "Afrolicious"}
|
|
]}]`, 2)
|
|
propRepo.Put(consts.LastScan, "1")
|
|
|
|
_, w := Get(AddParams("/rest/getIndexes.view", "ifModifiedSince=2"), "TestGetIndexes")
|
|
|
|
So(UnindentJSON(w.Body.Bytes()), ShouldContainSubstring, emptyResponse)
|
|
})
|
|
Convey("And it should return empty if 'ifModifiedSince' is the asme as tie index last update", func() {
|
|
mockRepo.SetData(`[{"Id": "A","Artists": [
|
|
{"ArtistId": "21", "Artist": "Afrolicious"}
|
|
]}]`, 2)
|
|
propRepo.Put(consts.LastScan, "1")
|
|
|
|
_, w := Get(AddParams("/rest/getIndexes.view", "ifModifiedSince=1"), "TestGetIndexes")
|
|
|
|
So(UnindentJSON(w.Body.Bytes()), ShouldContainSubstring, emptyResponse)
|
|
})
|
|
Reset(func() {
|
|
mockRepo.SetData("[]", 0)
|
|
mockRepo.SetError(false)
|
|
propRepo.Put(consts.LastScan, "1")
|
|
propRepo.SetError(false)
|
|
})
|
|
})
|
|
}
|