mirror of
https://github.com/navidrome/navidrome.git
synced 2025-04-12 10:20:10 +03:00
* tests for TopSongs Signed-off-by: Deluan <deluan@navidrome.org> * convert to Ginkgo Signed-off-by: Deluan <deluan@navidrome.org> * consolidate tests Signed-off-by: Deluan <deluan@navidrome.org> * rename external metadata -wip Signed-off-by: Deluan <deluan@navidrome.org> * rename external metadata to extdata.Provider Signed-off-by: Deluan <deluan@navidrome.org> * refactor tests - wip Signed-off-by: Deluan <deluan@navidrome.org> * refactor test helpers Signed-off-by: Deluan <deluan@navidrome.org> * remove reflection Signed-off-by: Deluan <deluan@navidrome.org> * use mock.Mock Signed-off-by: Deluan <deluan@navidrome.org> * refactor Signed-off-by: Deluan <deluan@navidrome.org> * fix Signed-off-by: Deluan <deluan@navidrome.org> * receive Agents interface in Provider constructor Signed-off-by: Deluan <deluan@navidrome.org> * use mock for Agents Signed-off-by: Deluan <deluan@navidrome.org> * tests for SimilarSongs Signed-off-by: Deluan <deluan@navidrome.org> * remove duplication Signed-off-by: Deluan <deluan@navidrome.org> * ArtistImage tests Signed-off-by: Deluan <deluan@navidrome.org> * AlbumImage tests Signed-off-by: Deluan <deluan@navidrome.org> * fix provider error handling Signed-off-by: Deluan <deluan@navidrome.org> * UpdateAlbumInfo tests - wip Signed-off-by: Deluan <deluan@navidrome.org> * UpdateAlbumInfo tests - wip Signed-off-by: Deluan <deluan@navidrome.org> * refactor Signed-off-by: Deluan <deluan@navidrome.org> * refactor Signed-off-by: Deluan <deluan@navidrome.org> * refactor Signed-off-by: Deluan <deluan@navidrome.org> * UpdateArtistInfo tests - wip Signed-off-by: Deluan <deluan@navidrome.org> * clean up Signed-off-by: Deluan <deluan@navidrome.org> * refactor Signed-off-by: Deluan <deluan@navidrome.org> * fix test descriptions Signed-off-by: Deluan <deluan@navidrome.org> * refactor Signed-off-by: Deluan <deluan@navidrome.org> * refactor: rename extdata package to external Signed-off-by: Deluan <deluan@navidrome.org> --------- Signed-off-by: Deluan <deluan@navidrome.org>
165 lines
3.4 KiB
Go
165 lines
3.4 KiB
Go
package tests
|
|
|
|
import (
|
|
"cmp"
|
|
"errors"
|
|
"maps"
|
|
"slices"
|
|
"time"
|
|
|
|
"github.com/navidrome/navidrome/model"
|
|
"github.com/navidrome/navidrome/model/id"
|
|
"github.com/navidrome/navidrome/utils/slice"
|
|
)
|
|
|
|
func CreateMockMediaFileRepo() *MockMediaFileRepo {
|
|
return &MockMediaFileRepo{
|
|
Data: make(map[string]*model.MediaFile),
|
|
}
|
|
}
|
|
|
|
type MockMediaFileRepo struct {
|
|
model.MediaFileRepository
|
|
Data map[string]*model.MediaFile
|
|
Err bool
|
|
}
|
|
|
|
func (m *MockMediaFileRepo) SetError(err bool) {
|
|
m.Err = err
|
|
}
|
|
|
|
func (m *MockMediaFileRepo) SetData(mfs model.MediaFiles) {
|
|
m.Data = make(map[string]*model.MediaFile)
|
|
for i, mf := range mfs {
|
|
m.Data[mf.ID] = &mfs[i]
|
|
}
|
|
}
|
|
|
|
func (m *MockMediaFileRepo) Exists(id string) (bool, error) {
|
|
if m.Err {
|
|
return false, errors.New("error")
|
|
}
|
|
_, found := m.Data[id]
|
|
return found, nil
|
|
}
|
|
|
|
func (m *MockMediaFileRepo) Get(id string) (*model.MediaFile, error) {
|
|
if m.Err {
|
|
return nil, errors.New("error")
|
|
}
|
|
if d, ok := m.Data[id]; ok {
|
|
// Intentionally clone the file and remove participants. This should
|
|
// catch any caller that actually means to call GetWithParticipants
|
|
res := *d
|
|
res.Participants = model.Participants{}
|
|
return &res, nil
|
|
}
|
|
return nil, model.ErrNotFound
|
|
}
|
|
|
|
func (m *MockMediaFileRepo) GetWithParticipants(id string) (*model.MediaFile, error) {
|
|
if m.Err {
|
|
return nil, errors.New("error")
|
|
}
|
|
if d, ok := m.Data[id]; ok {
|
|
return d, nil
|
|
}
|
|
return nil, model.ErrNotFound
|
|
}
|
|
|
|
func (m *MockMediaFileRepo) GetAll(...model.QueryOptions) (model.MediaFiles, error) {
|
|
if m.Err {
|
|
return nil, errors.New("error")
|
|
}
|
|
values := slices.Collect(maps.Values(m.Data))
|
|
return slice.Map(values, func(p *model.MediaFile) model.MediaFile {
|
|
return *p
|
|
}), nil
|
|
}
|
|
|
|
func (m *MockMediaFileRepo) Put(mf *model.MediaFile) error {
|
|
if m.Err {
|
|
return errors.New("error")
|
|
}
|
|
if mf.ID == "" {
|
|
mf.ID = id.NewRandom()
|
|
}
|
|
m.Data[mf.ID] = mf
|
|
return nil
|
|
}
|
|
|
|
func (m *MockMediaFileRepo) Delete(id string) error {
|
|
if m.Err {
|
|
return errors.New("error")
|
|
}
|
|
if _, ok := m.Data[id]; !ok {
|
|
return model.ErrNotFound
|
|
}
|
|
delete(m.Data, id)
|
|
return nil
|
|
}
|
|
|
|
func (m *MockMediaFileRepo) IncPlayCount(id string, timestamp time.Time) error {
|
|
if m.Err {
|
|
return errors.New("error")
|
|
}
|
|
if d, ok := m.Data[id]; ok {
|
|
d.PlayCount++
|
|
d.PlayDate = ×tamp
|
|
return nil
|
|
}
|
|
return model.ErrNotFound
|
|
}
|
|
|
|
func (m *MockMediaFileRepo) FindByAlbum(artistId string) (model.MediaFiles, error) {
|
|
if m.Err {
|
|
return nil, errors.New("error")
|
|
}
|
|
var res = make(model.MediaFiles, len(m.Data))
|
|
i := 0
|
|
for _, a := range m.Data {
|
|
if a.AlbumID == artistId {
|
|
res[i] = *a
|
|
i++
|
|
}
|
|
}
|
|
|
|
return res, nil
|
|
}
|
|
|
|
func (m *MockMediaFileRepo) GetMissingAndMatching(libId int) (model.MediaFileCursor, error) {
|
|
if m.Err {
|
|
return nil, errors.New("error")
|
|
}
|
|
var res model.MediaFiles
|
|
for _, a := range m.Data {
|
|
if a.LibraryID == libId && a.Missing {
|
|
res = append(res, *a)
|
|
}
|
|
}
|
|
|
|
for _, a := range m.Data {
|
|
if a.LibraryID == libId && !(*a).Missing && slices.IndexFunc(res, func(mediaFile model.MediaFile) bool {
|
|
return mediaFile.PID == a.PID
|
|
}) != -1 {
|
|
res = append(res, *a)
|
|
}
|
|
}
|
|
slices.SortFunc(res, func(i, j model.MediaFile) int {
|
|
return cmp.Or(
|
|
cmp.Compare(i.PID, j.PID),
|
|
cmp.Compare(i.ID, j.ID),
|
|
)
|
|
})
|
|
|
|
return func(yield func(model.MediaFile, error) bool) {
|
|
for _, a := range res {
|
|
if !yield(a, nil) {
|
|
break
|
|
}
|
|
}
|
|
}, nil
|
|
}
|
|
|
|
var _ model.MediaFileRepository = (*MockMediaFileRepo)(nil)
|