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:
Deluan Quintão
2025-06-10 23:00:44 -04:00
committed by GitHub
parent 76042ba173
commit 8fcd8ba61a
10 changed files with 398 additions and 15 deletions

View File

@@ -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 {

View 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
}