| // 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; |
| } |