2024-10-17 07:30:02 +02:00
|
|
|
package command_test
|
|
|
|
|
|
|
|
import (
|
|
|
|
"testing"
|
|
|
|
"time"
|
|
|
|
|
|
|
|
"github.com/google/go-cmp/cmp"
|
|
|
|
"go-mod.ewintr.nl/planner/item"
|
|
|
|
"go-mod.ewintr.nl/planner/plan/command"
|
|
|
|
"go-mod.ewintr.nl/planner/plan/storage/memory"
|
|
|
|
"go-mod.ewintr.nl/planner/sync/client"
|
|
|
|
)
|
|
|
|
|
2024-10-22 07:26:59 +02:00
|
|
|
func TestSyncSend(t *testing.T) {
|
2024-10-17 07:30:02 +02:00
|
|
|
t.Parallel()
|
|
|
|
|
|
|
|
syncClient := client.NewMemory()
|
|
|
|
syncRepo := memory.NewSync()
|
|
|
|
localIDRepo := memory.NewLocalID()
|
|
|
|
eventRepo := memory.NewEvent()
|
|
|
|
|
|
|
|
it := item.Item{
|
|
|
|
ID: "a",
|
|
|
|
Kind: item.KindEvent,
|
2024-10-18 07:26:11 +02:00
|
|
|
Body: `{
|
|
|
|
"title":"title",
|
|
|
|
"start":"2024-10-18T08:00:00Z",
|
|
|
|
"duration":"1h"
|
|
|
|
}`,
|
2024-10-17 07:30:02 +02:00
|
|
|
}
|
2024-10-22 07:26:59 +02:00
|
|
|
if err := syncRepo.Store(it); err != nil {
|
|
|
|
t.Errorf("exp nil, got %v", err)
|
|
|
|
}
|
2024-10-17 07:30:02 +02:00
|
|
|
|
2024-10-18 07:26:11 +02:00
|
|
|
for _, tc := range []struct {
|
|
|
|
name string
|
|
|
|
ks []item.Kind
|
|
|
|
ts time.Time
|
|
|
|
expItems []item.Item
|
|
|
|
}{
|
|
|
|
{
|
|
|
|
name: "single",
|
|
|
|
ks: []item.Kind{item.KindEvent},
|
|
|
|
expItems: []item.Item{it},
|
|
|
|
},
|
|
|
|
} {
|
|
|
|
t.Run(tc.name, func(t *testing.T) {
|
|
|
|
|
|
|
|
if err := command.Sync(syncClient, syncRepo, localIDRepo, eventRepo, false); err != nil {
|
|
|
|
t.Errorf("exp nil, got %v", err)
|
|
|
|
}
|
|
|
|
actItems, actErr := syncClient.Updated(tc.ks, tc.ts)
|
|
|
|
if actErr != nil {
|
|
|
|
t.Errorf("exp nil, got %v", actErr)
|
|
|
|
}
|
|
|
|
if diff := cmp.Diff(tc.expItems, actItems); diff != "" {
|
|
|
|
t.Errorf("(exp +, got -)\n%s", diff)
|
|
|
|
}
|
2024-10-22 07:26:59 +02:00
|
|
|
|
|
|
|
actLeft, actErr := syncRepo.FindAll()
|
|
|
|
if actErr != nil {
|
|
|
|
t.Errorf("exp nil, got %v", actErr)
|
|
|
|
}
|
|
|
|
if len(actLeft) != 0 {
|
|
|
|
t.Errorf("exp 0, got %v", actLeft)
|
|
|
|
}
|
|
|
|
})
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestSyncReceive(t *testing.T) {
|
|
|
|
t.Parallel()
|
|
|
|
|
2024-10-23 07:36:17 +02:00
|
|
|
oneHour, err := time.ParseDuration("1h")
|
|
|
|
if err != nil {
|
|
|
|
t.Errorf("exp nil, got %v", err)
|
|
|
|
}
|
2024-10-22 07:26:59 +02:00
|
|
|
|
|
|
|
for _, tc := range []struct {
|
2024-10-23 07:36:17 +02:00
|
|
|
name string
|
|
|
|
present []item.Event
|
|
|
|
updated []item.Item
|
|
|
|
expEvent []item.Event
|
|
|
|
expLocalID map[string]int
|
2024-10-22 07:26:59 +02:00
|
|
|
}{
|
2024-10-23 07:36:17 +02:00
|
|
|
{
|
|
|
|
name: "no new",
|
|
|
|
expEvent: []item.Event{},
|
|
|
|
expLocalID: map[string]int{},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
name: "new",
|
|
|
|
updated: []item.Item{{
|
|
|
|
ID: "a",
|
|
|
|
Kind: item.KindEvent,
|
|
|
|
Body: `{
|
|
|
|
"title":"title",
|
|
|
|
"start":"2024-10-23T08:00:00Z",
|
|
|
|
"duration":"1h"
|
|
|
|
}`,
|
|
|
|
}},
|
|
|
|
expEvent: []item.Event{{
|
|
|
|
ID: "a",
|
|
|
|
EventBody: item.EventBody{
|
|
|
|
Title: "title",
|
|
|
|
Start: time.Date(2024, 10, 23, 8, 0, 0, 0, time.UTC),
|
|
|
|
Duration: oneHour,
|
|
|
|
},
|
|
|
|
}},
|
|
|
|
expLocalID: map[string]int{
|
|
|
|
"a": 1,
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
name: "update existing",
|
|
|
|
present: []item.Event{{
|
|
|
|
ID: "a",
|
|
|
|
EventBody: item.EventBody{
|
|
|
|
Title: "title",
|
|
|
|
Start: time.Date(2024, 10, 23, 8, 0, 0, 0, time.UTC),
|
|
|
|
Duration: oneHour,
|
|
|
|
},
|
|
|
|
}},
|
|
|
|
updated: []item.Item{{
|
|
|
|
ID: "a",
|
|
|
|
Kind: item.KindEvent,
|
|
|
|
Body: `{
|
|
|
|
"title":"new title",
|
|
|
|
"start":"2024-10-23T08:00:00Z",
|
|
|
|
"duration":"1h"
|
|
|
|
}`,
|
|
|
|
}},
|
|
|
|
expEvent: []item.Event{{
|
|
|
|
ID: "a",
|
|
|
|
EventBody: item.EventBody{
|
|
|
|
Title: "new title",
|
|
|
|
Start: time.Date(2024, 10, 23, 8, 0, 0, 0, time.UTC),
|
|
|
|
Duration: oneHour,
|
|
|
|
},
|
|
|
|
}},
|
|
|
|
expLocalID: map[string]int{
|
|
|
|
"a": 1,
|
|
|
|
},
|
|
|
|
},
|
2024-10-22 07:26:59 +02:00
|
|
|
} {
|
|
|
|
t.Run(tc.name, func(t *testing.T) {
|
2024-10-23 07:36:17 +02:00
|
|
|
// setup
|
|
|
|
syncClient := client.NewMemory()
|
|
|
|
syncRepo := memory.NewSync()
|
|
|
|
localIDRepo := memory.NewLocalID()
|
|
|
|
eventRepo := memory.NewEvent()
|
2024-10-22 07:26:59 +02:00
|
|
|
|
2024-10-23 07:36:17 +02:00
|
|
|
for i, p := range tc.present {
|
|
|
|
if err := eventRepo.Store(p); err != nil {
|
|
|
|
t.Errorf("exp nil, got %v", err)
|
|
|
|
}
|
|
|
|
if err := localIDRepo.Store(p.ID, i+1); err != nil {
|
|
|
|
t.Errorf("exp nil, got %v", err)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if err := syncClient.Update(tc.updated); err != nil {
|
|
|
|
t.Errorf("exp nil, got %v", err)
|
|
|
|
}
|
|
|
|
|
|
|
|
// sync
|
|
|
|
if err := command.Sync(syncClient, syncRepo, localIDRepo, eventRepo, false); err != nil {
|
|
|
|
t.Errorf("exp nil, got %v", err)
|
|
|
|
}
|
|
|
|
|
|
|
|
// check result
|
|
|
|
actEvents, err := eventRepo.FindAll()
|
|
|
|
if err != nil {
|
|
|
|
t.Errorf("exp nil, got %v", err)
|
|
|
|
}
|
|
|
|
if diff := cmp.Diff(tc.expEvent, actEvents); diff != "" {
|
|
|
|
t.Errorf("(exp +, got -)\n%s", diff)
|
|
|
|
}
|
|
|
|
actLocalIDs, err := localIDRepo.FindAll()
|
|
|
|
if err != nil {
|
|
|
|
t.Errorf("exp nil, got %v", err)
|
|
|
|
}
|
|
|
|
if diff := cmp.Diff(tc.expLocalID, actLocalIDs); diff != "" {
|
|
|
|
t.Errorf("(exp +, got -)\n%s", diff)
|
|
|
|
}
|
2024-10-18 07:26:11 +02:00
|
|
|
})
|
2024-10-17 07:30:02 +02:00
|
|
|
}
|
|
|
|
}
|