This commit is contained in:
Erik Winter 2024-10-15 07:28:46 +02:00
parent 86c4cdc957
commit 405cf05341
3 changed files with 38 additions and 0 deletions

View File

@ -1,6 +1,7 @@
package memory package memory
import ( import (
"errors"
"sync" "sync"
"go-mod.ewintr.nl/planner/plan/storage" "go-mod.ewintr.nl/planner/plan/storage"
@ -24,6 +25,33 @@ func (ml *LocalID) FindAll() (map[string]int, error) {
return ml.ids, nil return ml.ids, nil
} }
func (ml *LocalID) Find(id string) (int, error) {
ml.mutex.RLock()
defer ml.mutex.RUnlock()
lid, ok := ml.ids[id]
if !ok {
return 0, storage.ErrNotFound
}
return lid, nil
}
func (ml *LocalID) FindOrNext(id string) (int, error) {
ml.mutex.Lock()
defer ml.mutex.Unlock()
lid, err := ml.Find(id)
switch {
case errors.Is(err, storage.ErrNotFound):
return ml.Next()
case err != nil:
return 0, err
default:
return lid, nil
}
}
func (ml *LocalID) Next() (int, error) { func (ml *LocalID) Next() (int, error) {
ml.mutex.RLock() ml.mutex.RLock()
defer ml.mutex.RUnlock() defer ml.mutex.RUnlock()

View File

@ -37,6 +37,15 @@ func TestLocalID(t *testing.T) {
t.Errorf("exp nil, got %v", actErr) t.Errorf("exp nil, got %v", actErr)
} }
t.Log("retrieve known")
actLid, actErr := repo.FindOrNext("test")
if actErr != nil {
t.Errorf("exp nil, got %v", actErr)
}
if actLid != 1 {
t.Errorf("exp 1, git %v", actLid)
}
actIDs, actErr = repo.FindAll() actIDs, actErr = repo.FindAll()
if actErr != nil { if actErr != nil {
t.Errorf("exp nil, got %v", actErr) t.Errorf("exp nil, got %v", actErr)

View File

@ -13,6 +13,7 @@ var (
type LocalID interface { type LocalID interface {
FindAll() (map[string]int, error) FindAll() (map[string]int, error)
FindOrNext(id string) (int, error)
Next() (int, error) Next() (int, error)
Store(id string, localID int) error Store(id string, localID int) error
Delete(id string) error Delete(id string) error