machine

package
v0.0.0-...-90fa48b Latest Latest
Warning

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

Go to latest
Published: Jan 11, 2025 License: BSD-3-Clause Imports: 5 Imported by: 0

Documentation

Index

Constants

View Source
const (
	DimID                        = "id"
	DimOS                        = "os"
	DimQuarantined               = "quarantined"
	DimDeviceType                = "device_type"
	DimAndroidDevices            = "android_devices"
	DimChromeOSChannel           = "chromeos_channel"
	DimChromeOSMilestone         = "chromeos_milestone"
	DimChromeOSReleaseVersion    = "release_version"
	DimCores                     = "cores"
	DimCPU                       = "cpu"
	DimGPU                       = "gpu"
	DimGCE                       = "gce"
	DimMachineType               = "machine_type"
	DimDockerInstalled           = "docker_installed"
	DimTestMachineMonitorVersion = "tmm_version"
	DimTaskType                  = "task_type"
	DimPool                      = "pool"

	BadBatteryLevel = -99
)

Well-known swarming dimensions:

View Source
const (
	PoolSkia         = "Skia"
	PoolSkiaInternal = "SkiaInternal"
)

Pool names.

Variables

View Source
var AllPowerCycleStates = []PowerCycleState{NotAvailable, Available, InError}
View Source
var AllTaskRequestorStates = []TaskRequestor{Swarming, SkTask}
View Source
var AllValidPools = []string{PoolSkia, PoolSkiaInternal}

AllValidPools contains all valid pool names.

Functions

func DestFromDescription

func DestFromDescription(d *Description) []interface{}

DestFromDescription returns a slice of interface containing pointers to every public member of Description. This is useful in code that stores the Description in an SQL database.

Make sure this always stays in the same order as the fields appear in the struct.

func SetSwarmingQuarantinedMessage

func SetSwarmingQuarantinedMessage(d *Description) bool

SetSwarmingQuarantinedMessage sets the Swarming Dimensions to reflect the full quarantined state. Returns true if the machine is quarantined.

Types

type Android

type Android struct {
	GetProp               string `json:"getprop"`
	DumpsysBattery        string `json:"dumpsys_battery"`
	DumpsysThermalService string `json:"dumpsys_thermal_service"`
	// A positive Uptime indicates there is an Android device attached to the host.
	Uptime time.Duration `json:"uptime"`
}

Android contains the raw results from interrogating an Android device.

func (*Android) IsPopulated

func (a *Android) IsPopulated() bool

IsPopulated returns whether the Android subevent record has been filled out, indicating that an Android device is attached.

type Annotation

type Annotation struct {
	Message   string
	User      string
	Timestamp time.Time
}

Annotation represents a timestamped message.

type AttachedDevice

type AttachedDevice string

AttachedDevice is what kind of mobile device, if any, we expect to find attached to the test machine.

const (
	// AttachedDeviceNone means no device is attached. Used for all non-mobile
	// test machines, like Windows boxes, as well as Raspberry Pis that have no
	// device attached yet.
	AttachedDeviceNone AttachedDevice = "nodevice"

	// AttachedDeviceAdb means an Android device, or anything else that
	// understands adb.
	AttachedDeviceAdb AttachedDevice = "adb"

	// AttachedDeviceIOS means an iOS device, or anything else that we talk to
	// using idevice* commands.
	AttachedDeviceIOS AttachedDevice = "ios"

	// AttachedDevicePyOCD means a device, typically a hardware devkit, which we
	// interact with via pyocd. https://github.com/pyocd/pyOCD
	AttachedDevicePyOCD AttachedDevice = "pyocd"

	// AttachedDeviceSSH means a ChromeOS device, or any other device we
	// interact with via SSH.
	AttachedDeviceSSH AttachedDevice = "ssh"
)

type ChromeOS

type ChromeOS struct {
	Channel        string `json:"channel"`
	Milestone      string `json:"milestone"`
	ReleaseVersion string `json:"release_version"`
	// A positive Uptime indicates there is an ChromeOS device attached to the host.
	Uptime time.Duration `json:"uptime"`
}

ChromeOS encapsulates the information reported by a ChromeOS machine.

func (*ChromeOS) IsPopulated

func (c *ChromeOS) IsPopulated() bool

IsPopulated returns whether the ChromeOS subevent record has been filled out, implying that the machine from which the event originated drives tests on a ChromeOS device.

type Description

type Description struct {

	// MaintenanceMode is non-empy if someone manually puts the machine into
	// this mode. The value will be the user's email address and the date of the
	// change.
	MaintenanceMode string `sql:"maintenance_mode STRING NOT NULL DEFAULT ''"`

	// IsQuarantined is true if the machine has failed too many tasks and should
	// stop running tasks pending user intervention. Recipes/Task Drivers can
	// write a $HOME/${SWARMING_BOT_ID}.quarantined file to move a machine into
	// quarantined mode.
	IsQuarantined bool `sql:"is_quarantined BOOL NOT NULL DEFAULT FALSE"`

	// Recovering is a non-empty string if test_machine_monitor detects the
	// device is too hot, or low on charge. The value is a description of what
	// is recovering.
	Recovering string `sql:"recovering STRING NOT NULL DEFAULT ''"`

	// AttachedDevice defines the kind of device attached to this test machine,
	// if any.
	AttachedDevice AttachedDevice `sql:"attached_device STRING NOT NULL DEFAULT 'nodevice'"`

	// Annotation is used to record the most recent non-user change to Description.
	// For example, if the device battery is too low, this will be set automatically.
	// This will be in addition to the normal auditlog of user actions:
	// https://pkg.go.dev/go.skia.org/infra/go/auditlog?tab=doc
	Annotation Annotation `sql:"annotation JSONB NOT NULL"`

	// Note is a user authored message on the state of a machine.
	Note Annotation `sql:"note JSONB NOT NULL"`

	// Version of test_machine_monitor being run.
	Version string `sql:"version STRING NOT NULL DEFAULT ''"`

	// PowerCycle is true if the machine needs to be power-cycled.
	PowerCycle bool `sql:"powercycle BOOL NOT NULL DEFAULT FALSE"`

	// PowerCycleState is the state of power cycling availability for this
	// machine.
	PowerCycleState PowerCycleState `sql:"powercycle_state STRING NOT NULL DEFAULT 'not_available'"`

	LastUpdated         time.Time          `sql:"last_updated TIMESTAMPTZ NOT NULL"`
	Battery             int                `sql:"battery INT NOT NULL DEFAULT 0"` // Charge as an integer percent, e.g. 50% = 50.
	Temperature         map[string]float64 `sql:"temperatures JSONB NOT NULL"`    // In Celsius.
	RunningSwarmingTask bool               `sql:"running_swarmingTask BOOL NOT NULL DEFAULT FALSE"`
	LaunchedSwarming    bool               `sql:"launched_swarming BOOL NOT NULL DEFAULT FALSE"` // True if test_machine_monitor launched Swarming.
	RecoveryStart       time.Time          `sql:"recovery_start TIMESTAMPTZ NOT NULL"`           // When did the machine start being in recovery mode.
	// DeviceUptime is how long the attached device has been up. It is measured in seconds.
	DeviceUptime int32 `sql:"device_uptime INT4 DEFAULT 0"`

	// SSHUserIP, for example, "root@skia-sparky360-03" indicates we should connect to the
	// given ChromeOS device at that username and ip/hostname.
	SSHUserIP string `sql:"ssh_user_ip STRING NOT NULL DEFAULT ''"`

	// SuppliedDimensions are dimensions that we, the humans, supply because they are difficult
	// for the automated system to gather. These are used only for ChromeOS devices, which don't
	// readily report their CPU and GPU.
	SuppliedDimensions SwarmingDimensions `sql:"supplied_dimensions JSONB NOT NULL"`

	// Dimensions describe what hardware/software this machine has and informs what tasks
	// it can run.
	Dimensions SwarmingDimensions `sql:"dimensions JSONB NOT NULL"`

	// TaskRequest, if present, will be the trigger that launches a task.
	//
	// To kill a running TaskRequest, just modify the Description to delete the TaskRequest, i.e. TaskRequest = null.
	TaskRequest *types.TaskRequest `sql:"task_request JSONB" json:",omitempty"`

	// TaskStarted records when a task was started. This value is set on
	// machineserver during Update.
	TaskStarted time.Time `sql:"task_started TIMESTAMPTZ NOT NULL DEFAULT (0)::TIMESTAMPTZ"`
	// contains filtered or unexported fields
}

Description is the current state of a single machine.

func NewDescription

func NewDescription(ctx context.Context) Description

NewDescription returns a new Description instance. It describes an available machine with no known dimensions.

func (Description) Copy

func (d Description) Copy() Description

Copy returns a deep copy of Description.

func (Description) InMaintenanceMode

func (d Description) InMaintenanceMode() bool

InMaintenanceMode returns true if the machine is in maintenance mode, i.e. has a non-empty MaintenanceMode message.

func (Description) IsRecovering

func (d Description) IsRecovering() bool

IsRecovering returns true if the machine is recoving, i.e. has a non-empty Recovering message.

type Event

type Event struct {
	EventType           EventType  `json:"type"`
	Android             Android    `json:"android"`
	ChromeOS            ChromeOS   `json:"chromeos"`
	IOS                 IOS        `json:"ios"`
	PyOCD               PyOCD      `json:"pyocd"`
	Standalone          Standalone `json:"standalone"`
	Host                Host       `json:"host"`
	RunningSwarmingTask bool       `json:"running_swarming_task"`

	// ForcedQuarantine is true if a TaskDriver or Recipe wrote a file $HOME/${MACHINE_ID}.force_quarantine.
	ForcedQuarantine bool `json:"forced_quarantine"`

	// LaunchedSwarming is true if test_machine_monitor launched Swarming.
	LaunchedSwarming bool `json:"launched_swarming"`
}

Event is the information a machine should send via Source when its local state has changed.

func NewEvent

func NewEvent() Event

NewEvent returns a new Event instance.

type EventType

type EventType string

EventType is the type of update we got from the machine.

const (
	// EventTypeRawState means the raw state from test_machine_monitor has been
	// updated.
	EventTypeRawState EventType = "raw_state"
)

type Host

type Host struct {
	// Name is the machine id, from SWARMING_BOT_ID environment variable or hostname().
	Name string `json:"name"`

	// Version of test_machine_monitor being run.
	Version string `json:"version"`

	// StartTime is when the test_machine_monitor started running.
	StartTime time.Time `json:"start_time"`
}

Host is information about the host machine.

type IOS

type IOS struct {
	OSVersion  string `json:"version"`     // e.g. "13.3.1". "" if it couldn't be detected.
	DeviceType string `json:"device_type"` // e.g. "iPhone10,1"
	Battery    int    `json:"battery"`     // as integer percent, or BadBatteryLevel
}

func (*IOS) IsPopulated

func (i *IOS) IsPopulated() bool

IsPopulated returns whether the IOS subevent record has been filled out, implying an attached iOS device.

type PowerCycleState

type PowerCycleState string

PowerCycleState is the state of powercycling for a single machine.

const (
	// NotAvailable means powercycling is not available for this machine. This
	// is the default.
	NotAvailable PowerCycleState = "not_available"

	// Available means powercycling is available for this machine.
	Available PowerCycleState = "available"

	// InError means that powercycle should be available, but an error has
	// occurred on powercycle_server, likely it failed to connect to the power
	// cycle device, aka the POE switch, or the PD.
	InError PowerCycleState = "in_error"
)

type PyOCD

type PyOCD struct {
	DeviceType string `json:"device_type"` // e.g. "MIMXRT1170-EVK"
}

func (*PyOCD) IsPopulated

func (p *PyOCD) IsPopulated() bool

IsPopulated returns whether the PyOCD subevent record has been filled out, implying an attached PyOCD device.

type Standalone

type Standalone struct {
	// Number of CPU cores:
	Cores int `json:"cores"`

	// Model of CPU, e.g. "arm64-64-Apple_M1" or "x86-64", in various precisions, e.g. "x86",
	// "x86-64", "x86-64-i7-9750H":
	CPUs []string `json:"cpus"`

	// Model of GPU, e.g. "1002:6821-4.0.20-3.2.8" or "8086:591e", in various precisions:
	GPUs []string `json:"gpus"`

	// OS version in various previsions, e.g. ["Mac-10", "Mac-10.15", "Mac-10.15.7"]:
	OSVersions []string `json:"os_versions"`

	// IsGCEMachine is true if the machine is running on GCE.
	IsGCEMachine bool `json:"gce"`

	// GCEMachineType is the type of GCE machine, e.g. "n1-highmem-2".
	GCEMachineType string `json:"machine_type"`

	// IsDockerInstalled indicates where the "docker" binary is available on the machine.
	IsDockerInstalled bool `json:"docker_installed"`
}

Standalone represents the Swarming-style dimensions of a test machine that runs tests on itself, not on some attached device.

We may merge this into Host later, once we get consistent about dimensions referring to either the host or the attached device. Right now, they're a mix. Having Standalone makes it more obvious, in the processor flow control, which dimension values take precedence.

func (*Standalone) IsPopulated

func (s *Standalone) IsPopulated() bool

IsPopulated returns whether the Standalone subevent record is filled out, which is the case iff a host is explicitly marked as having no device in the machineserver UI. IsPopulated does not return true when a device merely falls off a host accidentally.

type SwarmingDimensions

type SwarmingDimensions map[string][]string

SwarmingDimensions is for de/serializing swarming dimensions:

https://chromium.googlesource.com/infra/luci/luci-py.git/+doc/master/appengine/swarming/doc/Magic-Values.md#bot-dimensions

func (SwarmingDimensions) AsMetricsTags

func (s SwarmingDimensions) AsMetricsTags() map[string]string

AsMetricsTags returns a map that is suitable to pass as tags for a metric.

If there are multiple values for a key only the most specific value us used.

func (SwarmingDimensions) Copy

Copy returns a deep copy of the dimensions map.

func (SwarmingDimensions) GetDimensionValueOrEmptyString

func (s SwarmingDimensions) GetDimensionValueOrEmptyString(key string) string

GetDimensionValueOrEmptyString returns the last string in the value slice at the given key, or the empty string if the key doesn't exist.

type TaskRequestor

type TaskRequestor string

TaskRequestor is the system that is allowed to schedule jobs on a machine. This is the value type for the Dimension keyed by DimTaskType.

const (
	// Swarming is allowed to schedule tasks.
	Swarming TaskRequestor = "swarming"

	// SkTask means Skia Task Scheduler is allowed to schedule tasks.
	SkTask TaskRequestor = "sktask"
)

type TaskResult

type TaskResult struct {
	// TaskResult from Task Scheduler stored as JSONB so that it may change without affecting
	// machineserver code.
	TaskResult types.TaskResult `sql:"result JSONB NOT NULL"`
	// ID should match the TaskResult's ID.
	ID        string           `sql:"id STRING NOT NULL PRIMARY KEY"`
	MachineID string           `sql:"machine_id STRING NOT NULL"`
	Finished  time.Time        `sql:"finished TIMESTAMPTZ NOT NULL"`
	Status    types.TaskStatus `sql:"status STRING NOT NULL DEFAULT ''"`
	// contains filtered or unexported fields
}

TaskResult is a task result.

Directories

Path Synopsis
change
sink/sse
Package sse implements sink.Sink using Server-Sent Events.
Package sse implements sink.Sink using Server-Sent Events.
event
sink
Package sink is for sending machine.Events that are eventually picked up by 'source'.
Package sink is for sending machine.Events that are eventually picked up by 'source'.
sink/httpsink
Package httpsink sends event to the machine server via HTTP.
Package httpsink sends event to the machine server via HTTP.
source/httpsource
Package httpsource implements event.Source by accepting incoming HTTP requests that contain a machine.Event serialized as JSON.
Package httpsource implements event.Source by accepting incoming HTTP requests that contain a machine.Event serialized as JSON.
Pools handles processing the pool configuration and applying it to Dimensions.
Pools handles processing the pool configuration and applying it to Dimensions.
Package processor does the work of taking incoming events from machines and updating the machine state using that information.
Package processor does the work of taking incoming events from machines and updating the machine state using that information.
Package store is for storing and retrieving machine.Descriptions.
Package store is for storing and retrieving machine.Descriptions.
cdb
Package cdb contains an implementation of ../store.Store that uses CockroachDB.
Package cdb contains an implementation of ../store.Store that uses CockroachDB.
cdb/expectedschema
Package expectedschema contains the schema the database is expected to have.
Package expectedschema contains the schema the database is expected to have.
cdb/exportschema
Application exportschema exports the expected schema as a serialized schema.Description.
Application exportschema exports the expected schema as a serialized schema.Description.
cdb/mscdbinit
Command line tool to set up the CockroachDB database for machineserver.
Command line tool to set up the CockroachDB database for machineserver.
cdb/tosql
This executable generates a go file that contains the SQL schema for machineserver defined as a string.
This executable generates a go file that contains the SQL schema for machineserver defined as a string.
Program to generate TypeScript definition files for Golang structs that are serialized to JSON for the web UI.
Program to generate TypeScript definition files for Golang structs that are serialized to JSON for the web UI.

Jump to

Keyboard shortcuts

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