2019-08-23 19:05:13 +00:00
|
|
|
package backend
|
|
|
|
|
|
|
|
import (
|
|
|
|
"context"
|
|
|
|
"testing"
|
|
|
|
"time"
|
|
|
|
|
|
|
|
"github.com/google/go-cmp/cmp"
|
2021-04-07 18:42:55 +00:00
|
|
|
"github.com/influxdata/influxdb/v2/kit/platform"
|
|
|
|
"github.com/influxdata/influxdb/v2/task/taskmodel"
|
2019-12-04 23:10:23 +00:00
|
|
|
"go.uber.org/zap/zaptest"
|
2019-08-23 19:05:13 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
var (
|
2021-03-30 18:10:02 +00:00
|
|
|
one = platform.ID(1)
|
|
|
|
two = platform.ID(2)
|
|
|
|
three = platform.ID(3)
|
|
|
|
four = platform.ID(4)
|
2019-08-23 19:05:13 +00:00
|
|
|
|
2019-11-13 01:13:56 +00:00
|
|
|
aTime = time.Now().UTC()
|
2019-08-23 19:05:13 +00:00
|
|
|
|
2021-04-07 18:42:55 +00:00
|
|
|
taskOne = &taskmodel.Task{ID: one}
|
|
|
|
taskTwo = &taskmodel.Task{ID: two, Status: "active"}
|
|
|
|
taskThree = &taskmodel.Task{ID: three, Status: "inactive"}
|
|
|
|
taskFour = &taskmodel.Task{ID: four}
|
2019-08-23 19:05:13 +00:00
|
|
|
|
2021-04-07 18:42:55 +00:00
|
|
|
allTasks = map[platform.ID]*taskmodel.Task{
|
2019-08-23 19:05:13 +00:00
|
|
|
one: taskOne,
|
|
|
|
two: taskTwo,
|
|
|
|
three: taskThree,
|
|
|
|
four: taskFour,
|
|
|
|
}
|
|
|
|
)
|
|
|
|
|
|
|
|
func Test_NotifyCoordinatorOfCreated(t *testing.T) {
|
|
|
|
var (
|
|
|
|
coordinator = &coordinator{}
|
|
|
|
tasks = &taskService{
|
2020-11-11 18:54:21 +00:00
|
|
|
// paginated responses
|
2021-04-07 18:42:55 +00:00
|
|
|
pageOne: []*taskmodel.Task{taskOne},
|
|
|
|
otherPages: map[platform.ID][]*taskmodel.Task{
|
2021-01-29 16:50:57 +00:00
|
|
|
one: {taskTwo, taskThree},
|
|
|
|
three: {taskFour},
|
2019-08-23 19:05:13 +00:00
|
|
|
},
|
|
|
|
}
|
|
|
|
)
|
|
|
|
|
|
|
|
defer func(old func() time.Time) {
|
|
|
|
now = old
|
|
|
|
}(now)
|
|
|
|
|
|
|
|
now = func() time.Time { return aTime }
|
|
|
|
|
2019-12-04 23:10:23 +00:00
|
|
|
if err := NotifyCoordinatorOfExisting(context.Background(), zaptest.NewLogger(t), tasks, coordinator); err != nil {
|
2019-08-23 19:05:13 +00:00
|
|
|
t.Errorf("expected nil, found %q", err)
|
|
|
|
}
|
|
|
|
|
|
|
|
if diff := cmp.Diff([]update{
|
2021-04-07 18:42:55 +00:00
|
|
|
{two, taskmodel.TaskUpdate{LatestCompleted: &aTime, LatestScheduled: &aTime}},
|
2019-08-23 19:05:13 +00:00
|
|
|
}, tasks.updates); diff != "" {
|
|
|
|
t.Errorf("unexpected updates to task service %v", diff)
|
|
|
|
}
|
|
|
|
|
2021-04-07 18:42:55 +00:00
|
|
|
if diff := cmp.Diff([]*taskmodel.Task{
|
2019-08-23 19:05:13 +00:00
|
|
|
taskTwo,
|
|
|
|
}, coordinator.tasks); diff != "" {
|
|
|
|
t.Errorf("unexpected tasks sent to coordinator %v", diff)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
type coordinator struct {
|
2021-04-07 18:42:55 +00:00
|
|
|
tasks []*taskmodel.Task
|
2019-08-23 19:05:13 +00:00
|
|
|
}
|
|
|
|
|
2021-04-07 18:42:55 +00:00
|
|
|
func (c *coordinator) TaskCreated(_ context.Context, task *taskmodel.Task) error {
|
2019-08-23 19:05:13 +00:00
|
|
|
c.tasks = append(c.tasks, task)
|
|
|
|
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
|
|
|
// TasksService mocking
|
|
|
|
type taskService struct {
|
|
|
|
// paginated tasks
|
2021-04-07 18:42:55 +00:00
|
|
|
pageOne []*taskmodel.Task
|
|
|
|
otherPages map[platform.ID][]*taskmodel.Task
|
2019-08-23 19:05:13 +00:00
|
|
|
|
|
|
|
// find tasks call
|
2021-04-07 18:42:55 +00:00
|
|
|
filter taskmodel.TaskFilter
|
2019-08-23 19:05:13 +00:00
|
|
|
// update call
|
|
|
|
updates []update
|
|
|
|
}
|
|
|
|
|
|
|
|
type update struct {
|
2021-03-30 18:10:02 +00:00
|
|
|
ID platform.ID
|
2021-04-07 18:42:55 +00:00
|
|
|
Update taskmodel.TaskUpdate
|
2019-08-23 19:05:13 +00:00
|
|
|
}
|
|
|
|
|
2021-04-07 18:42:55 +00:00
|
|
|
func (t *taskService) UpdateTask(_ context.Context, id platform.ID, upd taskmodel.TaskUpdate) (*taskmodel.Task, error) {
|
2019-08-23 19:05:13 +00:00
|
|
|
t.updates = append(t.updates, update{id, upd})
|
|
|
|
|
|
|
|
return allTasks[id], nil
|
|
|
|
}
|
|
|
|
|
2021-04-07 18:42:55 +00:00
|
|
|
func (t *taskService) FindTasks(_ context.Context, filter taskmodel.TaskFilter) ([]*taskmodel.Task, int, error) {
|
2019-08-23 19:05:13 +00:00
|
|
|
t.filter = filter
|
|
|
|
|
|
|
|
if filter.After == nil {
|
|
|
|
return t.pageOne, len(t.pageOne), nil
|
|
|
|
}
|
|
|
|
|
|
|
|
tasks := t.otherPages[*filter.After]
|
|
|
|
return tasks, len(tasks), nil
|
|
|
|
}
|