mirror of
https://github.com/navidrome/navidrome.git
synced 2026-04-28 03:19:38 +00:00
feat(server): add index-based play queue endpoints to native API (#4210)
* Add migration converting playqueue current to index * refactor Signed-off-by: Deluan <deluan@navidrome.org> * fix(queue): ensure valid current index and improve test coverage Signed-off-by: Deluan <deluan@navidrome.org> --------- Signed-off-by: Deluan <deluan@navidrome.org>
This commit is contained in:
parent
76042ba173
commit
8fcd8ba61a
10 changed files with 398 additions and 15 deletions
|
|
@ -19,6 +19,7 @@ type MockDataStore struct {
|
|||
MockedProperty model.PropertyRepository
|
||||
MockedPlayer model.PlayerRepository
|
||||
MockedPlaylist model.PlaylistRepository
|
||||
MockedPlayQueue model.PlayQueueRepository
|
||||
MockedShare model.ShareRepository
|
||||
MockedTranscoding model.TranscodingRepository
|
||||
MockedUserProps model.UserPropsRepository
|
||||
|
|
@ -115,10 +116,14 @@ func (db *MockDataStore) Playlist(ctx context.Context) model.PlaylistRepository
|
|||
}
|
||||
|
||||
func (db *MockDataStore) PlayQueue(ctx context.Context) model.PlayQueueRepository {
|
||||
if db.RealDS != nil {
|
||||
return db.RealDS.PlayQueue(ctx)
|
||||
if db.MockedPlayQueue == nil {
|
||||
if db.RealDS != nil {
|
||||
db.MockedPlayQueue = db.RealDS.PlayQueue(ctx)
|
||||
} else {
|
||||
db.MockedPlayQueue = &MockPlayQueueRepo{}
|
||||
}
|
||||
}
|
||||
return struct{ model.PlayQueueRepository }{}
|
||||
return db.MockedPlayQueue
|
||||
}
|
||||
|
||||
func (db *MockDataStore) UserProps(ctx context.Context) model.UserPropsRepository {
|
||||
|
|
|
|||
39
tests/mock_playqueue_repo.go
Normal file
39
tests/mock_playqueue_repo.go
Normal file
|
|
@ -0,0 +1,39 @@
|
|||
package tests
|
||||
|
||||
import (
|
||||
"errors"
|
||||
|
||||
"github.com/navidrome/navidrome/model"
|
||||
)
|
||||
|
||||
type MockPlayQueueRepo struct {
|
||||
model.PlayQueueRepository
|
||||
Queue *model.PlayQueue
|
||||
Err bool
|
||||
}
|
||||
|
||||
func (m *MockPlayQueueRepo) Store(q *model.PlayQueue) error {
|
||||
if m.Err {
|
||||
return errors.New("error")
|
||||
}
|
||||
copyItems := make(model.MediaFiles, len(q.Items))
|
||||
copy(copyItems, q.Items)
|
||||
qCopy := *q
|
||||
qCopy.Items = copyItems
|
||||
m.Queue = &qCopy
|
||||
return nil
|
||||
}
|
||||
|
||||
func (m *MockPlayQueueRepo) Retrieve(userId string) (*model.PlayQueue, error) {
|
||||
if m.Err {
|
||||
return nil, errors.New("error")
|
||||
}
|
||||
if m.Queue == nil || m.Queue.UserID != userId {
|
||||
return nil, model.ErrNotFound
|
||||
}
|
||||
copyItems := make(model.MediaFiles, len(m.Queue.Items))
|
||||
copy(copyItems, m.Queue.Items)
|
||||
qCopy := *m.Queue
|
||||
qCopy.Items = copyItems
|
||||
return &qCopy, nil
|
||||
}
|
||||
Loading…
Add table
Add a link
Reference in a new issue