Struct gapi_grpc::google::devtools::remoteworkers::v1test2::Worker[][src]

pub struct Worker {
    pub devices: Vec<Device>,
    pub properties: Vec<Property>,
    pub configs: Vec<Config>,
}

Describes a worker, which is a list of one or more devices and the connections between them. A device could be a computer, a phone, or even an accelerator like a GPU; it’s up to the farm administrator to decide how to model their farm. For example, if a farm only has one type of GPU, the GPU could be modelled as a “has_gpu” property on its host computer; if it has many subproperties itself, it might be better to model it as a separate device.

The first device in the worker is the “primary device” - that is, the device running a bot and which is responsible for actually executing commands. All other devices are considered to be attached devices, and must be controllable by the primary device.

This message (and all its submessages) can be used in two contexts:

Several of the fields in this message have different semantics depending on which of which of these contexts it is used. These semantics are described below.

Several messages in Worker and its submessages have the concept of keys and values, such as Worker.Property and Device.Property. All keys are simple strings, but certain keys are “standard” keys and should be broadly supported across farms and implementations; these are listed below each relevant message. Bot implementations or farm admins may add additional keys, but these SHOULD all begin with an underscore so they do not conflict with standard keys that may be added in the future.

Keys are not context sensitive.

See http://goo.gl/NurY8g for more information on the Worker message.

Fields

devices: Vec<Device>

A list of devices; the first device is the primary device. See the Device message for more information.

properties: Vec<Property>

A worker may contain “global” properties. For example, certain machines might be reserved for certain types of jobs, like short-running compilation versus long-running integration tests. This property is known as a “pool” and is not related to any one device within the worker; rather, it applies to the worker as a whole.

The behaviour of repeated keys is identical to that of Device.Property.

configs: Vec<Config>

Bots can be configured in certain ways when accepting leases. For example, many leases are executed inside a Docker container. To support this, the bot needs to be able to report that it has Docker installed (and knows how to execute something inside a container), and the task submitter needs to specify which image should be used to start the container. Similarly, a lease may be able to run as one of several users on the worker; in such cases, the bot needs to report what users are available, and the submitter needs to choose one.

Therefore, when this message is reported by the bot to the service, each key represents a type of configuration that the bot knows how to set, while each value represents a legal value for that configuration (the empty string is interpretted as a wildcard, such as for Docker images). When this message is sent by the server to the bot in the context of a lease, it represents a command to the bot to apply the setting. Keys may be repeated during reporting but not in a lease.

Trait Implementations

impl Clone for Worker[src]

impl Debug for Worker[src]

impl Default for Worker[src]

impl Message for Worker[src]

impl PartialEq<Worker> for Worker[src]

impl StructuralPartialEq for Worker[src]

Auto Trait Implementations

impl RefUnwindSafe for Worker

impl Send for Worker

impl Sync for Worker

impl Unpin for Worker

impl UnwindSafe for Worker

Blanket Implementations

impl<T> Any for T where
    T: 'static + ?Sized
[src]

impl<T> Borrow<T> for T where
    T: ?Sized
[src]

impl<T> BorrowMut<T> for T where
    T: ?Sized
[src]

impl<T> From<T> for T[src]

impl<T> Instrument for T[src]

impl<T> Instrument for T[src]

impl<T, U> Into<U> for T where
    U: From<T>, 
[src]

impl<T> IntoRequest<T> for T[src]

impl<T> ToOwned for T where
    T: Clone
[src]

type Owned = T

The resulting type after obtaining ownership.

impl<T, U> TryFrom<U> for T where
    U: Into<T>, 
[src]

type Error = Infallible

The type returned in the event of a conversion error.

impl<T, U> TryInto<U> for T where
    U: TryFrom<T>, 
[src]

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.

impl<V, T> VZip<V> for T where
    V: MultiLane<T>, 
[src]

impl<T> WithSubscriber for T[src]