Compare commits
2 Commits
405cf05341
...
65e8a972e4
Author | SHA1 | Date |
---|---|---|
Erik Winter | 65e8a972e4 | |
Erik Winter | 758f3ccd43 |
|
@ -38,9 +38,6 @@ func (ml *LocalID) Find(id string) (int, error) {
|
||||||
}
|
}
|
||||||
|
|
||||||
func (ml *LocalID) FindOrNext(id string) (int, error) {
|
func (ml *LocalID) FindOrNext(id string) (int, error) {
|
||||||
ml.mutex.Lock()
|
|
||||||
defer ml.mutex.Unlock()
|
|
||||||
|
|
||||||
lid, err := ml.Find(id)
|
lid, err := ml.Find(id)
|
||||||
switch {
|
switch {
|
||||||
case errors.Is(err, storage.ErrNotFound):
|
case errors.Is(err, storage.ErrNotFound):
|
||||||
|
|
|
@ -45,6 +45,14 @@ func TestLocalID(t *testing.T) {
|
||||||
if actLid != 1 {
|
if actLid != 1 {
|
||||||
t.Errorf("exp 1, git %v", actLid)
|
t.Errorf("exp 1, git %v", actLid)
|
||||||
}
|
}
|
||||||
|
t.Log("retrieve unknown")
|
||||||
|
actLid, actErr = repo.FindOrNext("new")
|
||||||
|
if actErr != nil {
|
||||||
|
t.Errorf("exp nil, got %v", actErr)
|
||||||
|
}
|
||||||
|
if actLid != 2 {
|
||||||
|
t.Errorf("exp 2, got %v", actLid)
|
||||||
|
}
|
||||||
|
|
||||||
actIDs, actErr = repo.FindAll()
|
actIDs, actErr = repo.FindAll()
|
||||||
if actErr != nil {
|
if actErr != nil {
|
||||||
|
|
|
@ -3,6 +3,7 @@ package memory
|
||||||
import (
|
import (
|
||||||
"sort"
|
"sort"
|
||||||
"sync"
|
"sync"
|
||||||
|
"time"
|
||||||
|
|
||||||
"go-mod.ewintr.nl/planner/item"
|
"go-mod.ewintr.nl/planner/item"
|
||||||
)
|
)
|
||||||
|
@ -50,3 +51,17 @@ func (r *Sync) DeleteAll() error {
|
||||||
|
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func (r *Sync) LastUpdate() (time.Time, error) {
|
||||||
|
r.mutex.RLock()
|
||||||
|
defer r.mutex.RUnlock()
|
||||||
|
|
||||||
|
var last time.Time
|
||||||
|
for _, i := range r.items {
|
||||||
|
if i.Updated.After(last) {
|
||||||
|
last = i.Updated
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return last, nil
|
||||||
|
}
|
||||||
|
|
|
@ -3,6 +3,7 @@ package memory_test
|
||||||
import (
|
import (
|
||||||
"fmt"
|
"fmt"
|
||||||
"testing"
|
"testing"
|
||||||
|
"time"
|
||||||
|
|
||||||
"go-mod.ewintr.nl/planner/item"
|
"go-mod.ewintr.nl/planner/item"
|
||||||
"go-mod.ewintr.nl/planner/plan/storage/memory"
|
"go-mod.ewintr.nl/planner/plan/storage/memory"
|
||||||
|
@ -14,11 +15,15 @@ func TestSync(t *testing.T) {
|
||||||
mem := memory.NewSync()
|
mem := memory.NewSync()
|
||||||
|
|
||||||
t.Log("store")
|
t.Log("store")
|
||||||
|
now := time.Now()
|
||||||
|
ts := now
|
||||||
count := 3
|
count := 3
|
||||||
for i := 0; i < count; i++ {
|
for i := 0; i < count; i++ {
|
||||||
mem.Store(item.Item{
|
mem.Store(item.Item{
|
||||||
ID: fmt.Sprintf("id-%d", i),
|
ID: fmt.Sprintf("id-%d", i),
|
||||||
|
Updated: ts,
|
||||||
})
|
})
|
||||||
|
ts = ts.Add(-1 * time.Minute)
|
||||||
}
|
}
|
||||||
|
|
||||||
t.Log("find all")
|
t.Log("find all")
|
||||||
|
@ -30,6 +35,15 @@ func TestSync(t *testing.T) {
|
||||||
t.Errorf("exp %v, got %v", count, len(actItems))
|
t.Errorf("exp %v, got %v", count, len(actItems))
|
||||||
}
|
}
|
||||||
|
|
||||||
|
t.Log("last update")
|
||||||
|
actLU, actErr := mem.LastUpdate()
|
||||||
|
if actErr != nil {
|
||||||
|
t.Errorf("exp nil, got %v", actErr)
|
||||||
|
}
|
||||||
|
if !actLU.Equal(now) {
|
||||||
|
t.Errorf("exp %v, got %v", now, actLU)
|
||||||
|
}
|
||||||
|
|
||||||
t.Log("delete all")
|
t.Log("delete all")
|
||||||
if err := mem.DeleteAll(); err != nil {
|
if err := mem.DeleteAll(); err != nil {
|
||||||
t.Errorf("exp nil, got %v", err)
|
t.Errorf("exp nil, got %v", err)
|
||||||
|
|
|
@ -3,6 +3,7 @@ package storage
|
||||||
import (
|
import (
|
||||||
"errors"
|
"errors"
|
||||||
"sort"
|
"sort"
|
||||||
|
"time"
|
||||||
|
|
||||||
"go-mod.ewintr.nl/planner/item"
|
"go-mod.ewintr.nl/planner/item"
|
||||||
)
|
)
|
||||||
|
@ -23,6 +24,7 @@ type Sync interface {
|
||||||
FindAll() ([]item.Item, error)
|
FindAll() ([]item.Item, error)
|
||||||
Store(i item.Item) error
|
Store(i item.Item) error
|
||||||
DeleteAll() error
|
DeleteAll() error
|
||||||
|
LastUpdate() (time.Time, error)
|
||||||
}
|
}
|
||||||
|
|
||||||
type Event interface {
|
type Event interface {
|
||||||
|
|
Loading…
Reference in New Issue