pub struct BuildBazelRemoteExecutionV2ActionResult {
pub execution_metadata: Option<BuildBazelRemoteExecutionV2ExecutedActionMetadata>,
pub exit_code: Option<i32>,
pub output_directories: Option<Vec<BuildBazelRemoteExecutionV2OutputDirectory>>,
pub output_directory_symlinks: Option<Vec<BuildBazelRemoteExecutionV2OutputSymlink>>,
pub output_file_symlinks: Option<Vec<BuildBazelRemoteExecutionV2OutputSymlink>>,
pub output_files: Option<Vec<BuildBazelRemoteExecutionV2OutputFile>>,
pub output_symlinks: Option<Vec<BuildBazelRemoteExecutionV2OutputSymlink>>,
pub stderr_digest: Option<BuildBazelRemoteExecutionV2Digest>,
pub stderr_raw: Option<Vec<u8>>,
pub stdout_digest: Option<BuildBazelRemoteExecutionV2Digest>,
pub stdout_raw: Option<Vec<u8>>,
}
Expand description
An ActionResult represents the result of an Action being run. It is advised that at least one field (for example ActionResult.execution_metadata.Worker
) have a non-default value, to ensure that the serialized value is non-empty, which can then be used as a basic data sanity check.
§Activities
This type is used in activities, which are methods you may call on this type or where this type is involved in. The list links the activity name, along with information about where it is used (one of request and response).
- get action results (response)
- update action results (request|response)
Fields§
§execution_metadata: Option<BuildBazelRemoteExecutionV2ExecutedActionMetadata>
The details of the execution that originally produced this result.
exit_code: Option<i32>
The exit code of the command.
output_directories: Option<Vec<BuildBazelRemoteExecutionV2OutputDirectory>>
The output directories of the action. For each output directory requested in the output_directories
or output_paths
field of the Action, if the corresponding directory existed after the action completed, a single entry will be present in the output list, which will contain the digest of a Tree message containing the directory tree, and the path equal exactly to the corresponding Action output_directories member. As an example, suppose the Action had an output directory a/b/dir
and the execution produced the following contents in a/b/dir
: a file named bar
and a directory named foo
with an executable file named baz
. Then, output_directory will contain (hashes shortened for readability): json // OutputDirectory proto: { path: "a/b/dir" tree_digest: { hash: "4a73bc9d03...", size: 55 } } // Tree proto with hash "4a73bc9d03..." and size 55: { root: { files: [ { name: "bar", digest: { hash: "4a73bc9d03...", size: 65534 } } ], directories: [ { name: "foo", digest: { hash: "4cf2eda940...", size: 43 } } ] } children : { // (Directory proto with hash "4cf2eda940..." and size 43) files: [ { name: "baz", digest: { hash: "b2c941073e...", size: 1294, }, is_executable: true } ] } }
If an output of the same name as listed in output_files
of the Command was found in output_directories
, but was not a directory, the server will return a FAILED_PRECONDITION.
output_directory_symlinks: Option<Vec<BuildBazelRemoteExecutionV2OutputSymlink>>
The output directories of the action that are symbolic links to other directories. Those may be links to other output directories, or input directories, or even absolute paths outside of the working directory, if the server supports SymlinkAbsolutePathStrategy.ALLOWED. For each output directory requested in the output_directories
field of the Action, if the directory existed after the action completed, a single entry will be present either in this field, or in the output_directories
field, if the directory was not a symbolic link. If an output of the same name was found, but was a symbolic link to a file instead of a directory, the server will return a FAILED_PRECONDITION. If the action does not produce the requested output, then that output will be omitted from the list. The server is free to arrange the output list as desired; clients MUST NOT assume that the output list is sorted. DEPRECATED as of v2.1. Servers that wish to be compatible with v2.0 API should still populate this field in addition to output_symlinks
.
output_file_symlinks: Option<Vec<BuildBazelRemoteExecutionV2OutputSymlink>>
The output files of the action that are symbolic links to other files. Those may be links to other output files, or input files, or even absolute paths outside of the working directory, if the server supports SymlinkAbsolutePathStrategy.ALLOWED. For each output file requested in the output_files
or output_paths
field of the Action, if the corresponding file existed after the action completed, a single entry will be present either in this field, or in the output_files
field, if the file was not a symbolic link. If an output symbolic link of the same name as listed in output_files
of the Command was found, but its target type was not a regular file, the server will return a FAILED_PRECONDITION. If the action does not produce the requested output, then that output will be omitted from the list. The server is free to arrange the output list as desired; clients MUST NOT assume that the output list is sorted. DEPRECATED as of v2.1. Servers that wish to be compatible with v2.0 API should still populate this field in addition to output_symlinks
.
output_files: Option<Vec<BuildBazelRemoteExecutionV2OutputFile>>
The output files of the action. For each output file requested in the output_files
or output_paths
field of the Action, if the corresponding file existed after the action completed, a single entry will be present either in this field, or the output_file_symlinks
field if the file was a symbolic link to another file (output_symlinks
field after v2.1). If an output listed in output_files
was found, but was a directory rather than a regular file, the server will return a FAILED_PRECONDITION. If the action does not produce the requested output, then that output will be omitted from the list. The server is free to arrange the output list as desired; clients MUST NOT assume that the output list is sorted.
output_symlinks: Option<Vec<BuildBazelRemoteExecutionV2OutputSymlink>>
New in v2.1: this field will only be populated if the command output_paths
field was used, and not the pre v2.1 output_files
or output_directories
fields. The output paths of the action that are symbolic links to other paths. Those may be links to other outputs, or inputs, or even absolute paths outside of the working directory, if the server supports SymlinkAbsolutePathStrategy.ALLOWED. A single entry for each output requested in output_paths
field of the Action, if the corresponding path existed after the action completed and was a symbolic link. If the action does not produce a requested output, then that output will be omitted from the list. The server is free to arrange the output list as desired; clients MUST NOT assume that the output list is sorted.
stderr_digest: Option<BuildBazelRemoteExecutionV2Digest>
The digest for a blob containing the standard error of the action, which can be retrieved from the ContentAddressableStorage.
stderr_raw: Option<Vec<u8>>
The standard error buffer of the action. The server SHOULD NOT inline stderr unless requested by the client in the GetActionResultRequest message. The server MAY omit inlining, even if requested, and MUST do so if inlining would cause the response to exceed message size limits.
stdout_digest: Option<BuildBazelRemoteExecutionV2Digest>
The digest for a blob containing the standard output of the action, which can be retrieved from the ContentAddressableStorage.
stdout_raw: Option<Vec<u8>>
The standard output buffer of the action. The server SHOULD NOT inline stdout unless requested by the client in the GetActionResultRequest message. The server MAY omit inlining, even if requested, and MUST do so if inlining would cause the response to exceed message size limits.
Trait Implementations§
source§impl Clone for BuildBazelRemoteExecutionV2ActionResult
impl Clone for BuildBazelRemoteExecutionV2ActionResult
source§fn clone(&self) -> BuildBazelRemoteExecutionV2ActionResult
fn clone(&self) -> BuildBazelRemoteExecutionV2ActionResult
1.0.0 · source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
source
. Read more