kratos/third_party/google/devtools/resultstore/v2/action.proto

381 lines
14 KiB

// Copyright 2018 Google LLC.
//
// 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 google.devtools.resultstore.v2;
import "google/devtools/resultstore/v2/common.proto";
import "google/devtools/resultstore/v2/coverage.proto";
import "google/devtools/resultstore/v2/file.proto";
import "google/devtools/resultstore/v2/test_suite.proto";
import "google/protobuf/duration.proto";
option go_package = "google.golang.org/genproto/googleapis/devtools/resultstore/v2;resultstore";
option java_multiple_files = true;
option java_package = "com.google.devtools.resultstore.v2";
// An action that happened as part of a configured target. This action could be
// a build, a test, or another type of action.
// Each parent ConfiguredTarget resource should have at least one Action as its
// child resource before the invocation is finalized. ResultStore is a tool to
// store build & test results. ConfiguredTarget proto by itself does not contain
// enough fields to fully represent such results. For a simple build, at least
// one build action is required to represent the build result.
message Action {
// The resource ID components that identify the Action.
message Id {
// The Invocation ID.
string invocation_id = 1;
// The Target ID.
string target_id = 2;
// The Configuration ID.
string configuration_id = 3;
// The Action ID.
string action_id = 4;
}
// The resource name. Its format must be:
// invocations/${INVOCATION_ID}/targets/${TARGET_ID}/configuredTargets/${CONFIG_ID}/actions/${ACTION_ID}
string name = 1;
// The resource ID components that identify the Action. They must match the
// resource name after proper encoding.
Id id = 2;
// The status of the action.
StatusAttributes status_attributes = 3;
// The timing of the whole action. For TestActions, the start time may be
// before the test actually started, and the duration may last until after the
// test actually finished.
Timing timing = 4;
// The type of the action. The type of an action may not change over the
// lifetime of the invocation. If one of these fields is to be set, it must be
// set in the CreateAction method. It may be set to an empty message that is
// populated in later methods or post-processing. A generic "untyped" action
// can be created by not setting any of these fields. An untyped action will
// be untyped for the lifetime of the invocation.
oneof action_type {
// Used only when this action represents a build action.
BuildAction build_action = 9;
// Only for test actions.
TestAction test_action = 10;
}
// General attributes of the action.
ActionAttributes action_attributes = 5;
// A list of resources that this action depended upon. May be used to provide
// the cause of a build failure in the case of a failed build action.
repeated Dependency action_dependencies = 14;
// Arbitrary name-value pairs.
// This is implemented as a multi-map. Multiple properties are allowed with
// the same key. Properties will be returned in lexicographical order by key.
repeated Property properties = 7;
// A list of file references for action level files.
// The file IDs must be unique within this list. Duplicate file IDs will
// result in an error. Files will be returned in lexicographical order by ID.
// Files with the following reserved file IDs cause specific post-processing
// or have special handling:
//
// For build actions:
// stdout: The stdout of the action
// stderr: The stderr of the action
// baseline.lcov: Baseline coverage file to be parsed by the server. This
// uses a stripped down implementation of the LCOV standard.
// http://ltp.sourceforge.net/coverage/lcov/geninfo.1.php
//
// For test actions:
// test.xml: The test suite / test case data in XML format.
// test.log: The combined stdout and stderr of the test process.
// test.lcov: Coverage file to be parsed by the server. This uses a stripped
// down implementation of the LCOV standard.
// http://ltp.sourceforge.net/coverage/lcov/geninfo.1.php
repeated File files = 8;
// Coverage data was collected while running the build or test action. This
// usually includes line coverage, and may also include branch coverage.
// For test actions, this is usually only for the source files which were
// actually executed by that particular action.
// For build actions, this is the baseline coverage, which captures the
// instrumented files and lines, without any lines being executed. This
// ensures files that are never covered at all are included.
ActionCoverage coverage = 11;
// ResultStore will read and parse Files with reserved IDs listed above. Read
// and parse errors for all these Files are reported here.
// This is implemented as a map, with one FileProcessingErrors for each file.
// Typically produced when parsing Files, but may also be provided directly
// by clients.
repeated FileProcessingErrors file_processing_errors = 13;
}
// A build action, such as building a java library.
message BuildAction {
// The type of the action. This is intended to be a clue as to how the output
// of the action should be parsed. For example "javac" for a Java compile
// action.
string type = 1;
// The "primary" input artifact processed by this action. E.g., the .cc file
// of a C++ compile action. Empty string ("") if the action has no input
// artifacts or no "primary" input artifact.
string primary_input_path = 2;
// The "primary" output artifact processed by this action. E.g., the .o file
// of a C++ compile action. Empty string ("") if the action has no output
// artifacts or no "primary" output artifact.
string primary_output_path = 3;
}
// A test action, such as running a JUnit4 test binary.
message TestAction {
// Timing data for execution of the test action.
TestTiming test_timing = 1;
// If the test is divided up into shards to improve performance, set this to
// indicate which shard this test action is for. Value must be in interval
// [0, total_shard_count). Defaults to 0, which is appropriate if all test
// cases are run in the same process.
int32 shard_number = 2;
// If the user requested that every test be run multiple times, as is often
// done to measure flakiness, set this to indicate which run this test action
// is for. Value must be in interval [0, total_run_count). Defaults to 0,
// which is appropriate if multiple runs were not requested.
int32 run_number = 3;
// If flaky tests are automatically retried, set this to indicate which
// attempt this test action is for. (e.g. 0 for the first attempt, 1 for
// second, and so on). Defaults to 0, which is appropriate if this is only
// attempt.
int32 attempt_number = 4;
// A tree of test suites and test cases that were run by this test action.
// Each test case has its own status information, including stack traces.
// Typically produced by parsing an XML Log, but may also be provided directly
// by clients.
TestSuite test_suite = 5;
// Warnings for this test action.
repeated TestWarning warnings = 8;
// Estimated memory consumption of the test action, in bytes. A default value
// of 0 means there is no memory consumption estimate specified.
int64 estimated_memory_bytes = 10;
}
// General attributes of an action
message ActionAttributes {
// Strategy used for executing the action.
ExecutionStrategy execution_strategy = 1;
// Exit code of the process that ran the action. A non-zero value means
// failure.
int32 exit_code = 2;
// Where the action was run.
string hostname = 3;
// Information about the input files used in all actions under this configured
// target.
InputFileInfo input_file_info = 4;
}
// File count and size information for the input files to a configured target.
message InputFileInfo {
// The number of input files (counting every file, even if a duplicate).
int64 count = 1;
// The number of distinct input files.
int64 distinct_count = 2;
// The max number of input files allowed by the build system (counting every
// file, even if a duplicate).
int64 count_limit = 3;
// The total size of the distinct input files.
int64 distinct_bytes = 4;
// The max allowed total size of the distinct input files.
int64 distinct_byte_limit = 5;
}
// Timing data for tests executed locally on the machine running the build.
message LocalTestTiming {
// Time taken by the test process, typically surrounded by a small wrapper
// script.
google.protobuf.Duration test_process_duration = 1;
}
// Timing data for one attempt to execute a test action remotely.
message RemoteTestAttemptTiming {
// Idle period before the test process is invoked on the remote machine.
google.protobuf.Duration queue_duration = 1;
// Time to upload data dependencies from the local machine to the remote
// machine running the test, or to the distributed cache.
google.protobuf.Duration upload_duration = 2;
// Time to set up the remote machine.
// Not to be confused with setup time in
// xUnit test frameworks, which falls within the test_process_time.
google.protobuf.Duration machine_setup_duration = 3;
// Time taken by the test process, typically surrounded by a small wrapper
// script.
// For Java tests, this includes JVM setup, flag parsing, class path setup,
// parsing files to setup the suite, and finally running your test methods.
// In many cases, only a small fraction of the test process time is spent
// running the test methods.
google.protobuf.Duration test_process_duration = 4;
// Time spent retrieving test logs and any other test outputs, back to the
// local machine.
google.protobuf.Duration download_duration = 5;
}
// Timing data for the part of the test execution that is done remotely.
message RemoteTestTiming {
// Time taken locally to determine what to do.
google.protobuf.Duration local_analysis_duration = 1;
// Normally there is only one attempt, but the system may retry on internal
// errors, leading to multiple attempts.
repeated RemoteTestAttemptTiming attempts = 2;
}
// Timing data for execution of a test action. The action may be performed
// locally, on the machine running the build, or remotely.
message TestTiming {
// Test timing for either a local or remote execution.
oneof location {
// Used for local test actions.
LocalTestTiming local = 1;
// Used for remote test actions.
RemoteTestTiming remote = 2;
}
// The amount of CPU time spent by the test process executing system calls
// within the kernel, as opposed to library code. Time the test process spent
// blocked does not count towards this figure.
google.protobuf.Duration system_time_duration = 3;
// The amount of CPU time spent by the test process executing user-mode code
// outside the kernel, as opposed to library code. Time the test process
// spent blocked does not count towards this figure. You can add user_time to
// system_time to get total CPU time taken by the test process.
google.protobuf.Duration user_time_duration = 4;
// Most build systems cache build results to speed up incremental builds.
// Some also cache test results too. This indicates whether the test results
// were found in a cache, and where that cache was located.
TestCaching test_caching = 5;
}
// A warning from a test execution.
message TestWarning {
// Contains the message detailing the warning.
string warning_message = 1;
}
// Stores errors reading or parsing a file during post-processing.
message FileProcessingErrors {
// The uid of the File being read or parsed.
string file_uid = 1;
// What went wrong.
repeated FileProcessingError file_processing_errors = 3;
}
// Stores an error reading or parsing a file during post-processing.
message FileProcessingError {
// The type of error that occurred.
FileProcessingErrorType type = 1;
// Error message describing the problem.
string message = 2;
}
// Indicates how/where this Action was executed.
enum ExecutionStrategy {
// The action did not indicate how it was executed.
EXECUTION_STRATEGY_UNSPECIFIED = 0;
// The action was executed in some other form.
OTHER_ENVIRONMENT = 1;
// The action used a remote build service.
REMOTE_SERVICE = 2;
// The action was executed locally, in parallel with other actions.
LOCAL_PARALLEL = 3;
// The action was executed locally, without parallelism.
LOCAL_SEQUENTIAL = 4;
}
// Most build systems cache build results to speed up incremental builds.
// Some also cache test results too. This indicates whether the test results
// were found in a cache, and where that cache was located.
enum TestCaching {
// The implicit default enum value. Should never be set.
TEST_CACHING_UNSPECIFIED = 0;
// The test result was found in a local cache, so it wasn't run again.
LOCAL_CACHE_HIT = 1;
// The test result was found in a remote cache, so it wasn't run again.
REMOTE_CACHE_HIT = 2;
// The test result was not found in any cache, so it had to be run again.
CACHE_MISS = 3;
}
// Errors in file post-processing are categorized using this enum.
enum FileProcessingErrorType {
// Type unspecified or not listed here.
FILE_PROCESSING_ERROR_TYPE_UNSPECIFIED = 0;
// A read error occurred trying to read the file.
GENERIC_READ_ERROR = 1;
// There was an error trying to parse the file.
GENERIC_PARSE_ERROR = 2;
// File is exceeds size limit.
FILE_TOO_LARGE = 3;
// The result of parsing the file exceeded size limit.
OUTPUT_TOO_LARGE = 4;
// Read access to the file was denied by file system.
ACCESS_DENIED = 5;
// Deadline exceeded trying to read the file.
DEADLINE_EXCEEDED = 6;
// File not found.
NOT_FOUND = 7;
}