Storm ChecksumsRepository complete.

This commit is contained in:
Deluan 2020-01-10 20:17:06 -05:00 committed by Deluan Quintão
parent 4f151a7409
commit c9be5f7201
7 changed files with 83 additions and 13 deletions

View File

@ -1,8 +1,6 @@
package db_ledis
import (
"errors"
"github.com/cloudsonic/sonic-server/log"
"github.com/cloudsonic/sonic-server/scanner"
"github.com/siddontang/ledisdb/ledis"
@ -35,14 +33,6 @@ func (r *checkSumRepository) loadData() {
log.Debug("Loaded checksums", "total", len(r.data))
}
func (r *checkSumRepository) Put(id, sum string) error {
if id == "" {
return errors.New("ID is required")
}
_, err := Db().HSet(checkSumKeyName, []byte(id), []byte(sum))
return err
}
func (r *checkSumRepository) Get(id string) (string, error) {
return r.data[id], nil
}

View File

@ -5,6 +5,5 @@ import (
)
var Set = wire.NewSet(
NewCheckSumRepository,
NewNowPlayingRepository,
)

View File

@ -0,0 +1,53 @@
package db_storm
import (
"github.com/asdine/storm"
"github.com/cloudsonic/sonic-server/domain"
"github.com/cloudsonic/sonic-server/log"
"github.com/cloudsonic/sonic-server/scanner"
)
var (
checkSumBucket = "_Checksums"
)
type checkSumRepository struct {
data map[string]string
}
func NewCheckSumRepository() scanner.CheckSumRepository {
r := &checkSumRepository{}
return r
}
func (r *checkSumRepository) loadData() error {
loadedData := make(map[string]string)
err := Db().Get(checkSumBucket, checkSumBucket, &loadedData)
if err == storm.ErrNotFound {
return domain.ErrNotFound
}
log.Debug("Loaded checksums", "total", len(loadedData))
r.data = loadedData
return err
}
func (r *checkSumRepository) Get(id string) (string, error) {
if r.data == nil {
err := r.loadData()
if err != nil {
return "", err
}
}
return r.data[id], nil
}
func (r *checkSumRepository) SetData(newSums map[string]string) error {
err := Db().Set(checkSumBucket, checkSumBucket, newSums)
if err != nil {
return err
}
r.data = newSums
return nil
}
var _ scanner.CheckSumRepository = (*checkSumRepository)(nil)

View File

@ -0,0 +1,28 @@
package db_storm
import (
"github.com/cloudsonic/sonic-server/scanner"
. "github.com/onsi/ginkgo"
. "github.com/onsi/gomega"
)
var _ = Describe("ChecksumRepository", func() {
var repo scanner.CheckSumRepository
BeforeEach(func() {
Db().Drop(checkSumBucket)
repo = NewCheckSumRepository()
repo.SetData(map[string]string{
"a": "AAA", "b": "BBB",
})
})
It("can retrieve data", func() {
Expect(repo.Get("b")).To(Equal("BBB"))
})
It("persists data", func() {
newRepo := NewCheckSumRepository()
Expect(newRepo.Get("b")).To(Equal("BBB"))
})
})

View File

@ -12,5 +12,6 @@ var Set = wire.NewSet(
NewMediaFileRepository,
NewArtistIndexRepository,
NewPlaylistRepository,
NewCheckSumRepository,
persistence.NewMediaFolderRepository,
)

View File

@ -37,7 +37,6 @@ func NewItunesScanner(checksumRepo CheckSumRepository) *ItunesScanner {
}
type CheckSumRepository interface {
Put(id, sum string) error
Get(id string) (string, error)
SetData(newSums map[string]string) error
}

View File

@ -19,7 +19,7 @@ import (
// Injectors from wire_injectors.go:
func initImporter(musicFolder string) *scanner.Importer {
checkSumRepository := db_ledis.NewCheckSumRepository()
checkSumRepository := db_storm.NewCheckSumRepository()
itunesScanner := scanner.NewItunesScanner(checkSumRepository)
mediaFileRepository := db_storm.NewMediaFileRepository()
albumRepository := db_storm.NewAlbumRepository()