163 lines
6.7 KiB
Go
163 lines
6.7 KiB
Go
package mock
|
|
|
|
import (
|
|
"context"
|
|
"time"
|
|
|
|
"github.com/influxdata/influxdb"
|
|
"github.com/influxdata/influxdb/task/backend"
|
|
)
|
|
|
|
var _ influxdb.TaskService = (*TaskService)(nil)
|
|
var _ backend.TaskControlService = (*TaskControlService)(nil)
|
|
|
|
type TaskService struct {
|
|
FindTaskByIDFn func(context.Context, influxdb.ID) (*influxdb.Task, error)
|
|
FindTaskByIDCalls SafeCount
|
|
FindTasksFn func(context.Context, influxdb.TaskFilter) ([]*influxdb.Task, int, error)
|
|
FindTasksCalls SafeCount
|
|
CreateTaskFn func(context.Context, influxdb.TaskCreate) (*influxdb.Task, error)
|
|
CreateTaskCalls SafeCount
|
|
UpdateTaskFn func(context.Context, influxdb.ID, influxdb.TaskUpdate) (*influxdb.Task, error)
|
|
UpdateTaskCalls SafeCount
|
|
DeleteTaskFn func(context.Context, influxdb.ID) error
|
|
DeleteTaskCalls SafeCount
|
|
FindLogsFn func(context.Context, influxdb.LogFilter) ([]*influxdb.Log, int, error)
|
|
FindLogsCalls SafeCount
|
|
FindRunsFn func(context.Context, influxdb.RunFilter) ([]*influxdb.Run, int, error)
|
|
FindRunsCalls SafeCount
|
|
FindRunByIDFn func(context.Context, influxdb.ID, influxdb.ID) (*influxdb.Run, error)
|
|
FindRunByIDCalls SafeCount
|
|
CancelRunFn func(context.Context, influxdb.ID, influxdb.ID) error
|
|
CancelRunCalls SafeCount
|
|
RetryRunFn func(context.Context, influxdb.ID, influxdb.ID) (*influxdb.Run, error)
|
|
RetryRunCalls SafeCount
|
|
ForceRunFn func(context.Context, influxdb.ID, int64) (*influxdb.Run, error)
|
|
ForceRunCalls SafeCount
|
|
}
|
|
|
|
func NewTaskService() *TaskService {
|
|
return &TaskService{
|
|
FindTaskByIDFn: func(ctx context.Context, id influxdb.ID) (*influxdb.Task, error) {
|
|
return nil, nil
|
|
},
|
|
FindTasksFn: func(ctx context.Context, f influxdb.TaskFilter) ([]*influxdb.Task, int, error) {
|
|
return nil, 0, nil
|
|
},
|
|
CreateTaskFn: func(ctx context.Context, taskCreate influxdb.TaskCreate) (*influxdb.Task, error) {
|
|
return nil, nil
|
|
},
|
|
UpdateTaskFn: func(ctx context.Context, id influxdb.ID, update influxdb.TaskUpdate) (*influxdb.Task, error) {
|
|
return nil, nil
|
|
},
|
|
DeleteTaskFn: func(ctx context.Context, id influxdb.ID) error {
|
|
return nil
|
|
},
|
|
FindLogsFn: func(ctx context.Context, f influxdb.LogFilter) ([]*influxdb.Log, int, error) {
|
|
return nil, 0, nil
|
|
},
|
|
FindRunsFn: func(ctx context.Context, f influxdb.RunFilter) ([]*influxdb.Run, int, error) {
|
|
return nil, 0, nil
|
|
},
|
|
FindRunByIDFn: func(ctx context.Context, id influxdb.ID, id2 influxdb.ID) (*influxdb.Run, error) {
|
|
return nil, nil
|
|
},
|
|
CancelRunFn: func(ctx context.Context, id influxdb.ID, id2 influxdb.ID) error {
|
|
return nil
|
|
},
|
|
RetryRunFn: func(ctx context.Context, id influxdb.ID, id2 influxdb.ID) (*influxdb.Run, error) {
|
|
return nil, nil
|
|
},
|
|
ForceRunFn: func(ctx context.Context, id influxdb.ID, i int64) (*influxdb.Run, error) {
|
|
return nil, nil
|
|
},
|
|
}
|
|
}
|
|
|
|
func (s *TaskService) FindTaskByID(ctx context.Context, id influxdb.ID) (*influxdb.Task, error) {
|
|
defer s.FindTaskByIDCalls.IncrFn()()
|
|
return s.FindTaskByIDFn(ctx, id)
|
|
}
|
|
|
|
func (s *TaskService) FindTasks(ctx context.Context, filter influxdb.TaskFilter) ([]*influxdb.Task, int, error) {
|
|
defer s.FindTasksCalls.IncrFn()()
|
|
return s.FindTasksFn(ctx, filter)
|
|
}
|
|
|
|
func (s *TaskService) CreateTask(ctx context.Context, t influxdb.TaskCreate) (*influxdb.Task, error) {
|
|
defer s.CreateTaskCalls.IncrFn()()
|
|
return s.CreateTaskFn(ctx, t)
|
|
}
|
|
|
|
func (s *TaskService) UpdateTask(ctx context.Context, id influxdb.ID, upd influxdb.TaskUpdate) (*influxdb.Task, error) {
|
|
defer s.UpdateTaskCalls.IncrFn()()
|
|
return s.UpdateTaskFn(ctx, id, upd)
|
|
}
|
|
|
|
func (s *TaskService) DeleteTask(ctx context.Context, id influxdb.ID) error {
|
|
defer s.DeleteTaskCalls.IncrFn()()
|
|
return s.DeleteTaskFn(ctx, id)
|
|
}
|
|
|
|
func (s *TaskService) FindLogs(ctx context.Context, filter influxdb.LogFilter) ([]*influxdb.Log, int, error) {
|
|
defer s.FindLogsCalls.IncrFn()()
|
|
return s.FindLogsFn(ctx, filter)
|
|
}
|
|
|
|
func (s *TaskService) FindRuns(ctx context.Context, filter influxdb.RunFilter) ([]*influxdb.Run, int, error) {
|
|
defer s.FindRunsCalls.IncrFn()()
|
|
return s.FindRunsFn(ctx, filter)
|
|
}
|
|
|
|
func (s *TaskService) FindRunByID(ctx context.Context, taskID, runID influxdb.ID) (*influxdb.Run, error) {
|
|
defer s.FindRunByIDCalls.IncrFn()()
|
|
return s.FindRunByIDFn(ctx, taskID, runID)
|
|
}
|
|
|
|
func (s *TaskService) CancelRun(ctx context.Context, taskID, runID influxdb.ID) error {
|
|
defer s.CancelRunCalls.IncrFn()()
|
|
return s.CancelRunFn(ctx, taskID, runID)
|
|
}
|
|
|
|
func (s *TaskService) RetryRun(ctx context.Context, taskID, runID influxdb.ID) (*influxdb.Run, error) {
|
|
defer s.RetryRunCalls.IncrFn()()
|
|
return s.RetryRunFn(ctx, taskID, runID)
|
|
}
|
|
|
|
func (s *TaskService) ForceRun(ctx context.Context, taskID influxdb.ID, scheduledFor int64) (*influxdb.Run, error) {
|
|
defer s.ForceRunCalls.IncrFn()()
|
|
return s.ForceRunFn(ctx, taskID, scheduledFor)
|
|
}
|
|
|
|
type TaskControlService struct {
|
|
CreateRunFn func(ctx context.Context, taskID influxdb.ID, scheduledFor time.Time, runAt time.Time) (*influxdb.Run, error)
|
|
CurrentlyRunningFn func(ctx context.Context, taskID influxdb.ID) ([]*influxdb.Run, error)
|
|
ManualRunsFn func(ctx context.Context, taskID influxdb.ID) ([]*influxdb.Run, error)
|
|
StartManualRunFn func(ctx context.Context, taskID, runID influxdb.ID) (*influxdb.Run, error)
|
|
FinishRunFn func(ctx context.Context, taskID, runID influxdb.ID) (*influxdb.Run, error)
|
|
UpdateRunStateFn func(ctx context.Context, taskID, runID influxdb.ID, when time.Time, state influxdb.RunStatus) error
|
|
AddRunLogFn func(ctx context.Context, taskID, runID influxdb.ID, when time.Time, log string) error
|
|
}
|
|
|
|
func (tcs *TaskControlService) CreateRun(ctx context.Context, taskID influxdb.ID, scheduledFor time.Time, runAt time.Time) (*influxdb.Run, error) {
|
|
return tcs.CreateRunFn(ctx, taskID, scheduledFor, runAt)
|
|
}
|
|
func (tcs *TaskControlService) CurrentlyRunning(ctx context.Context, taskID influxdb.ID) ([]*influxdb.Run, error) {
|
|
return tcs.CurrentlyRunningFn(ctx, taskID)
|
|
}
|
|
func (tcs *TaskControlService) ManualRuns(ctx context.Context, taskID influxdb.ID) ([]*influxdb.Run, error) {
|
|
return tcs.ManualRunsFn(ctx, taskID)
|
|
}
|
|
func (tcs *TaskControlService) StartManualRun(ctx context.Context, taskID, runID influxdb.ID) (*influxdb.Run, error) {
|
|
return tcs.StartManualRunFn(ctx, taskID, runID)
|
|
}
|
|
func (tcs *TaskControlService) FinishRun(ctx context.Context, taskID, runID influxdb.ID) (*influxdb.Run, error) {
|
|
return tcs.FinishRunFn(ctx, taskID, runID)
|
|
}
|
|
func (tcs *TaskControlService) UpdateRunState(ctx context.Context, taskID, runID influxdb.ID, when time.Time, state influxdb.RunStatus) error {
|
|
return tcs.UpdateRunStateFn(ctx, taskID, runID, when, state)
|
|
}
|
|
func (tcs *TaskControlService) AddRunLog(ctx context.Context, taskID, runID influxdb.ID, when time.Time, log string) error {
|
|
return tcs.AddRunLogFn(ctx, taskID, runID, when, log)
|
|
}
|