tasks

package
v0.0.0-...-e7509a3 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Nov 22, 2024 License: Apache-2.0 Imports: 19 Imported by: 0

Documentation

Overview

Package tasks contains code to manage a task's lifecycle.

Index

Constants

This section is empty.

Variables

This section is empty.

Functions

func RegisterCleanupHandlers

func RegisterCleanupHandlers(crondisp *cron.Dispatcher, tqdisp *tq.Dispatcher)

RegisterCleanupHandlers registers cron and TQ handlers that implement old task cleanup.

Types

type Cancellation

type Cancellation struct {
	TaskID string

	// TaskRequest and TaskResultSummary are required in RunInTxn.
	TaskRequest       *model.TaskRequest
	TaskResultSummary *model.TaskResultSummary

	// Whether to kill the task if it has started running.
	KillRunning bool
	// ID of the bot the task should run on. Can only be specified if
	// KillRunning is true.
	BotID string

	// LifecycleTasks is used to emit TQ tasks related to Swarming task lifecycle.
	LifecycleTasks LifecycleTasks
}

Cancellation contains information to cancel a task.

func (*Cancellation) Run

func (c *Cancellation) Run(ctx context.Context) (bool, bool, error)

Run cancels a task if possible.

Ensures that the associated TaskToRun is canceled (when PENDING) and updates the TaskResultSummary/TaskRunResult accordingly.

For PENDING tasks, the TaskResultSummary's state is immediately changed. For RUNNING tasks, the TaskRunResult.Killing bit is immediately set, but their state (in TaskRunResult and TaskResultSummary) is not changed yet.

Warning: ACL check must have been done before.

Returns * a bool for whether the task has started the cancellation process as requested, * a bool for whether the task was running when being canceled, * an err for errors to cancel the task.

func (*Cancellation) RunInTxn

func (c *Cancellation) RunInTxn(ctx context.Context) (bool, error)

RunInTxn updates entities of the task to cancel and enqueues the cloud tasks to cancel its children and send notifications.

Mutates c.TaskResultSummary in place.

Must run in a transaction.

Returns * a bool for whether the task has started the cancellation process as requested, * an err for errors to cancel the task.

type LifecycleTasks

type LifecycleTasks interface {
	EnqueueBatchCancel(ctx context.Context, batch []string, killRunning bool, purpose string, retries int32) error
	// contains filtered or unexported methods
}

LifecycleTasks is used to emit TQ tasks related to Swarming task lifecycle.

type LifecycleTasksForTests

type LifecycleTasksForTests struct {
	// contains filtered or unexported fields
}

LifecycleTasksForTests mocks tq tasks for task lifecycle management, only used for tests.

func MockTQTasks

func MockTQTasks() *LifecycleTasksForTests

MockTQTasks returns TestTQTasks with mocked tq functions for managing a task's lifecycle.

func (*LifecycleTasksForTests) EnqueueBatchCancel

func (lt *LifecycleTasksForTests) EnqueueBatchCancel(ctx context.Context, batch []string, killRunning bool, purpose string, retries int32) error

EnqueueBatchCancel enqueues a tq task to cancel tasks in batch.

func (*LifecycleTasksForTests) PeekTasks

func (lt *LifecycleTasksForTests) PeekTasks(queue string) []string

PeekTasks returns all the tasks in the queue without popping them.

func (*LifecycleTasksForTests) PopNTasks

func (lt *LifecycleTasksForTests) PopNTasks(qName string, n int) (res []string)

PopNTasks pops n tasks from the queue.

If there are fewer than n tasks in the queue, just pop all of them.

func (*LifecycleTasksForTests) PopTask

func (lt *LifecycleTasksForTests) PopTask(queue string) string

PopTask pops a task from the queue.

type LifecycleTasksViaTQ

type LifecycleTasksViaTQ struct {
	Dispatcher *tq.Dispatcher
}

func (*LifecycleTasksViaTQ) EnqueueBatchCancel

func (l *LifecycleTasksViaTQ) EnqueueBatchCancel(ctx context.Context, batch []string, killRunning bool, purpose string, retries int32) error

EnqueueBatchCancel enqueues a tq task to cancel tasks in batch.

func (*LifecycleTasksViaTQ) RegisterTQTasks

func (l *LifecycleTasksViaTQ) RegisterTQTasks()

RegisterTQTasks regusters TQ tasks for task lifecycle management.

Directories

Path Synopsis
Package taskspb contains Cloud Tasks proto definations which will be used for tasks workflow management.
Package taskspb contains Cloud Tasks proto definations which will be used for tasks workflow management.

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL