blob: ae17121ba42454dd098eb6b77da36cdb610652e8 [file] [log] [blame]
// Copyright 2015 The Bazel Authors. All rights reserved.
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
syntax = "proto3";
package blaze.worker;
option java_package = "com.google.devtools.build.lib.worker";
// An input file.
message Input {
// The path in the file system where to read this input artifact from. This is
// either a path relative to the execution root (the worker process is
// launched with the working directory set to the execution root), or an
// absolute path.
string path = 1;
// A hash-value of the contents. The format of the contents is unspecified and
// the digest should be treated as an opaque token. This can be empty in some
// cases.
bytes digest = 2;
}
// This represents a single work unit that Blaze sends to the worker.
message WorkRequest {
repeated string arguments = 1;
// The inputs that the worker is allowed to read during execution of this
// request.
repeated Input inputs = 2;
// Each WorkRequest must have either a unique
// request_id or request_id = 0. If request_id is 0, this WorkRequest must be
// processed alone (singleplex), otherwise the worker may process multiple
// WorkRequests in parallel (multiplexing). As an exception to the above, if
// the cancel field is true, the request_id must be the same as a previously
// sent WorkRequest. The request_id must be attached unchanged to the
// corresponding WorkResponse. Only one singleplex request may be sent to a
// worker at a time.
int32 request_id = 3;
// EXPERIMENTAL: When true, this is a cancel request, indicating that a
// previously sent WorkRequest with the same request_id should be cancelled.
// The arguments and inputs fields must be empty and should be ignored.
bool cancel = 4;
// Values greater than 0 indicate that the worker may output extra debug
// information to stderr (which will go into the worker log). Setting the
// --worker_verbose flag for Bazel makes this flag default to 10.
int32 verbosity = 5;
// The relative directory inside the workers working directory where the
// inputs and outputs are placed, for sandboxing purposes. For singleplex
// workers, this is unset, as they can use their working directory as sandbox.
// For multiplex workers, this will be set when the
// --experimental_worker_multiplex_sandbox flag is set _and_ the execution
// requirements for the worker includes 'supports-multiplex-sandbox'.
// The paths in `inputs` will not contain this prefix, but the actual files
// will be placed/must be written relative to this directory. The worker
// implementation is responsible for resolving the file paths.
string sandbox_dir = 6;
}
// The worker sends this message to Blaze when it finished its work on the
// WorkRequest message.
message WorkResponse {
int32 exit_code = 1;
// Output message for this work unit.
// This is akin to the combined stdout/stderr if the work unit were executed
// as a standalone process. Output pertaining to a work unit should be
// reported here instead of through the stdout/stderr of the worker process.
// Assumed to be UTF-8 encoded.
string output = 2;
// This field must be set to the same request_id as the WorkRequest it is a
// response to. Since worker processes which support multiplex worker will
// handle multiple WorkRequests in parallel, this ID will be used to
// determined which WorkerProxy does this WorkResponse belong to.
int32 request_id = 3;
// EXPERIMENTAL When true, indicates that this response was sent due to
// receiving a cancel request. The exit_code and output fields should be empty
// and will be ignored. Exactly one WorkResponse must be sent for each
// non-cancelling WorkRequest received by the worker, but if the worker
// received a cancel request, it doesn't matter if it replies with a regular
// WorkResponse or with one where was_cancelled = true.
bool was_cancelled = 4;
}