More getMusicDirectory
This commit is contained in:
@@ -30,15 +30,30 @@ func (c *GetMusicDirectoryController) Get() {
|
|||||||
c.SendError(responses.ERROR_GENERIC, "Internal Error")
|
c.SendError(responses.ERROR_GENERIC, "Internal Error")
|
||||||
}
|
}
|
||||||
|
|
||||||
|
dir := &responses.Directory{}
|
||||||
if found {
|
if found {
|
||||||
_, err := c.artistRepo.Get(id)
|
a, _:= c.retrieveArtist(id)
|
||||||
if err != nil {
|
|
||||||
beego.Error("Error reading Artist from DB", err)
|
dir.Id = a.Id
|
||||||
c.SendError(responses.ERROR_GENERIC, "Internal Error")
|
dir.Name = a.Name
|
||||||
}
|
} else {
|
||||||
|
beego.Info("Artist", id, "not found")
|
||||||
|
c.SendError(responses.ERROR_DATA_NOT_FOUND, "Directory not found")
|
||||||
}
|
}
|
||||||
|
|
||||||
response := c.NewEmpty()
|
response := c.NewEmpty()
|
||||||
response.Directory = &responses.Directory{}
|
response.Directory = dir
|
||||||
c.SendResponse(response)
|
c.SendResponse(response)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func (c *GetMusicDirectoryController) retrieveArtist(id string) (a *domain.Artist, as[]domain.Album) {
|
||||||
|
var err error
|
||||||
|
|
||||||
|
if a, err = c.artistRepo.Get(id); err != nil {
|
||||||
|
beego.Error("Error reading Artist from DB", err)
|
||||||
|
c.SendError(responses.ERROR_GENERIC, "Internal Error")
|
||||||
|
}
|
||||||
|
|
||||||
|
as = make([]domain.Album, 0)
|
||||||
|
return
|
||||||
|
}
|
||||||
@@ -14,13 +14,13 @@ import (
|
|||||||
func TestGetMusicDirectory(t *testing.T) {
|
func TestGetMusicDirectory(t *testing.T) {
|
||||||
Init(t, false)
|
Init(t, false)
|
||||||
|
|
||||||
mockRepo := mocks.CreateMockArtistRepo()
|
mockArtistRepo := mocks.CreateMockArtistRepo()
|
||||||
utils.DefineSingleton(new(domain.ArtistRepository), func() domain.ArtistRepository {
|
utils.DefineSingleton(new(domain.ArtistRepository), func() domain.ArtistRepository {
|
||||||
return mockRepo
|
return mockArtistRepo
|
||||||
})
|
})
|
||||||
|
|
||||||
mockRepo.SetData("[]")
|
mockArtistRepo.SetData("[]", 0)
|
||||||
mockRepo.SetError(false)
|
mockArtistRepo.SetError(false)
|
||||||
|
|
||||||
Convey("Subject: GetMusicDirectory Endpoint", t, func() {
|
Convey("Subject: GetMusicDirectory Endpoint", t, func() {
|
||||||
Convey("Should fail if missing Id parameter", func() {
|
Convey("Should fail if missing Id parameter", func() {
|
||||||
@@ -30,11 +30,27 @@ func TestGetMusicDirectory(t *testing.T) {
|
|||||||
})
|
})
|
||||||
Convey("Id is for an artist", func() {
|
Convey("Id is for an artist", func() {
|
||||||
Convey("Return fail on Artist Table error", func() {
|
Convey("Return fail on Artist Table error", func() {
|
||||||
mockRepo.SetError(true)
|
mockArtistRepo.SetError(true)
|
||||||
_, w := Get(AddParams("/rest/getMusicDirectory.view", "id=1"), "TestGetMusicDirectory")
|
_, w := Get(AddParams("/rest/getMusicDirectory.view", "id=1"), "TestGetMusicDirectory")
|
||||||
|
|
||||||
So(w.Body, ShouldReceiveError, responses.ERROR_GENERIC)
|
So(w.Body, ShouldReceiveError, responses.ERROR_GENERIC)
|
||||||
})
|
})
|
||||||
})
|
})
|
||||||
|
Convey("When id is not found", func() {
|
||||||
|
mockArtistRepo.SetData(`[{"Id":"1","Name":"The Charlatans"}]`, 1)
|
||||||
|
_, w := Get(AddParams("/rest/getMusicDirectory.view", "id=NOT_FOUND"), "TestGetMusicDirectory")
|
||||||
|
|
||||||
|
So(w.Body, ShouldReceiveError, responses.ERROR_DATA_NOT_FOUND)
|
||||||
|
})
|
||||||
|
Convey("When id matches an artist without albums", func() {
|
||||||
|
mockArtistRepo.SetData(`[{"Id":"1","Name":"The KLF"}]`, 1)
|
||||||
|
_, w := Get(AddParams("/rest/getMusicDirectory.view", "id=1"), "TestGetMusicDirectory")
|
||||||
|
|
||||||
|
So(w.Body, ShouldContainJSON, `"id":"1","name":"The KLF"`)
|
||||||
|
})
|
||||||
|
Reset(func() {
|
||||||
|
mockArtistRepo.SetData("[]", 0)
|
||||||
|
mockArtistRepo.SetError(false)
|
||||||
|
})
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
+6
-1
@@ -27,6 +27,12 @@ func ShouldMatchJSON(actual interface{}, expected ...interface{}) string {
|
|||||||
return ShouldEqual(s, expected[0].(string))
|
return ShouldEqual(s, expected[0].(string))
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func ShouldContainJSON(actual interface{}, expected ...interface{}) string {
|
||||||
|
a := UnindentJSON(actual.(*bytes.Buffer).Bytes())
|
||||||
|
|
||||||
|
return ShouldContainSubstring(a, expected[0].(string))
|
||||||
|
}
|
||||||
|
|
||||||
func ShouldReceiveError(actual interface{}, expected ...interface{}) string {
|
func ShouldReceiveError(actual interface{}, expected ...interface{}) string {
|
||||||
v := responses.Subsonic{}
|
v := responses.Subsonic{}
|
||||||
err := xml.Unmarshal(actual.(*bytes.Buffer).Bytes(), &v)
|
err := xml.Unmarshal(actual.(*bytes.Buffer).Bytes(), &v)
|
||||||
@@ -35,7 +41,6 @@ func ShouldReceiveError(actual interface{}, expected ...interface{}) string {
|
|||||||
}
|
}
|
||||||
|
|
||||||
return ShouldEqual(v.Error.Code, expected[0].(int))
|
return ShouldEqual(v.Error.Code, expected[0].(int))
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
func UnindentJSON(j []byte) string {
|
func UnindentJSON(j []byte) string {
|
||||||
|
|||||||
@@ -13,7 +13,7 @@ func CreateMockArtistRepo() *MockArtist {
|
|||||||
|
|
||||||
type MockArtist struct {
|
type MockArtist struct {
|
||||||
domain.ArtistRepository
|
domain.ArtistRepository
|
||||||
data map[string]domain.Artist
|
data map[string]*domain.Artist
|
||||||
err bool
|
err bool
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -21,12 +21,16 @@ func (m *MockArtist) SetError(err bool) {
|
|||||||
m.err = err
|
m.err = err
|
||||||
}
|
}
|
||||||
|
|
||||||
func (m *MockArtist) SetData(j string) {
|
func (m *MockArtist) SetData(j string, size int) {
|
||||||
m.data = make(map[string]domain.Artist)
|
m.data = make(map[string]*domain.Artist)
|
||||||
err := json.Unmarshal([]byte(j), &m.data)
|
var l = make([]domain.Artist, size)
|
||||||
|
err := json.Unmarshal([]byte(j), &l)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
fmt.Println("ERROR: ", err)
|
fmt.Println("ERROR: ", err)
|
||||||
}
|
}
|
||||||
|
for _, a := range l {
|
||||||
|
m.data[a.Id] = &a
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
func (m *MockArtist) Exists(id string) (bool, error) {
|
func (m *MockArtist) Exists(id string) (bool, error) {
|
||||||
@@ -35,4 +39,11 @@ func (m *MockArtist) Exists(id string) (bool, error) {
|
|||||||
}
|
}
|
||||||
_, found := m.data[id];
|
_, found := m.data[id];
|
||||||
return found, nil
|
return found, nil
|
||||||
|
}
|
||||||
|
|
||||||
|
func (m *MockArtist) Get(id string) (*domain.Artist, error) {
|
||||||
|
if m.err {
|
||||||
|
return nil, errors.New("Error!")
|
||||||
|
}
|
||||||
|
return m.data[id], nil
|
||||||
}
|
}
|
||||||
Reference in New Issue
Block a user