autobuild

package
v0.27.3 Latest Latest
Warning

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

Go to latest
Published: Aug 1, 2023 License: AGPL-3.0 Imports: 15 Imported by: 0

Documentation

Overview

Package autobuild contains logic for scheduling workspace builds in the background.

Index

Constants

This section is empty.

Variables

This section is empty.

Functions

This section is empty.

Types

type Executor

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

Executor automatically starts or stops workspaces.

func NewExecutor

func NewExecutor(ctx context.Context, db database.Store, tss *atomic.Pointer[schedule.TemplateScheduleStore], log slog.Logger, tick <-chan time.Time) *Executor

New returns a new wsactions executor.

func (*Executor) Run

func (e *Executor) Run()

Run will cause executor to start or stop workspaces on every tick from its channel. It will stop when its context is Done, or when its channel is closed.

func (*Executor) WithStatsChannel

func (e *Executor) WithStatsChannel(ch chan<- Stats) *Executor

WithStatsChannel will cause Executor to push a RunStats to ch after every tick.

type Stats

type Stats struct {
	Transitions map[uuid.UUID]database.WorkspaceTransition
	Elapsed     time.Duration
	Error       error
}

Stats contains information about one run of Executor.

Directories

Path Synopsis

Jump to

Keyboard shortcuts

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