1/* 2 * Copyright (C) 2018 The Android Open Source Project 3 * 4 * Licensed under the Apache License, Version 2.0 (the "License"); 5 * you may not use this file except in compliance with the License. 6 * You may obtain a copy of the License at 7 * 8 * http://www.apache.org/licenses/LICENSE-2.0 9 * 10 * Unless required by applicable law or agreed to in writing, software 11 * distributed under the License is distributed on an "AS IS" BASIS, 12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 13 * See the License for the specific language governing permissions and 14 * limitations under the License. 15 */ 16syntax = "proto3"; 17 18import "google/protobuf/any.proto"; 19import "google/protobuf/timestamp.proto"; 20import "atest/tf_proto/metric_measurement.proto"; 21 22option java_package = "com.android.tradefed.result.proto"; 23option java_outer_classname = "TestRecordProto"; 24 25package android_test_record; 26 27// A record containing the status, logs, and other information associated with a 28// particular test execution. 29message TestRecord { 30 // The UUID of this TestRecord. 31 string test_record_id = 1; 32 33 // The UUID of this TestRecord's parent. Unset if this is a top-level record. 34 string parent_test_record_id = 2; 35 36 // References to any finer-grained TestRecords that were generated as part of 37 // this test. 38 repeated ChildReference children = 3; 39 40 // The number of children this TestRecord was expected to have. Unset if not 41 // known in advance. 42 int64 num_expected_children = 4; 43 44 // The result status (Pass, Fail, etc) of this test unit. 45 TestStatus status = 5; 46 47 // Extra debugging information. 48 DebugInfo debug_info = 6; 49 50 // The time at which this test started executing. 51 google.protobuf.Timestamp start_time = 7; 52 53 // The time at which this test finished executing. 54 google.protobuf.Timestamp end_time = 8; 55 56 // Any artifact files associated with this test. 57 map<string, google.protobuf.Any> artifacts = 9; 58 59 // Any metrics or measurements associated with this test. 60 map<string, tradefed.metric.Metric> metrics = 10; 61 62 // Metadata describing the test that was run. 63 google.protobuf.Any description = 11; 64 65 // The attempt number of a target if the target ran several times. First 66 // attempt is 0 (Default value). 67 int64 attempt_id = 12; 68} 69 70// A reference to a finer-grained TestRecord. 71message ChildReference { 72 oneof reference { 73 // The UUID of the TestRecord. 74 string test_record_id = 1; 75 76 // An inlined TestRecord. 77 TestRecord inline_test_record = 2; 78 } 79} 80 81// The overall pass / fail status for a particular TestRecord. 82enum TestStatus { 83 UNKNOWN = 0; 84 PASS = 1; 85 FAIL = 2; 86 IGNORED = 3; 87 ASSUMPTION_FAILURE = 4; 88} 89 90// Associated debugging information to accompany a TestStatus. 91message DebugInfo { 92 // An error message. 93 string error_message = 1; 94 95 // A stacktrace. 96 string trace = 2; 97 98 // A more detailed failure status description. 99 FailureStatus failure_status = 3; 100 101 // Optional context to the failure 102 DebugInfoContext debug_info_context = 4; 103} 104 105// A Fail TestStatus can be associated with a more granular failure status that helps understanding 106// the context. 107enum FailureStatus { 108 UNSET = 0; 109 // The test in progress was the reason for the failure. 110 TEST_FAILURE = 1; 111 // A timeout condition on the operation in progress occurred. 112 TIMED_OUT = 2; 113 // The test in progress was cancelled. 114 CANCELLED = 3; 115 // A failure attributed to something not functioning properly. 116 INFRA_FAILURE = 10; 117 // System under test crashed and caused the test to fail. 118 SYSTEM_UNDER_TEST_CRASHED = 20; 119 // The test was expected to run but did not. 120 NOT_EXECUTED = 30; 121 // System under test became unavailable and never came back available again. 122 LOST_SYSTEM_UNDER_TEST = 35; 123 // Represent an error caused by an unmet dependency that the current infra 124 // depends on. For example: Unfound resources, Device error, Hardware issue 125 // (lab host, device wear), Underlying tools 126 DEPENDENCY_ISSUE = 40; 127 // Represent an error caused by the input from the end user. For example: 128 // Unexpected option combination, Configuration error, Bad flags 129 CUSTOMER_ISSUE = 41; 130} 131 132// A context to DebugInfo that allows to optionally specify some debugging context. 133message DebugInfoContext { 134 // Category of the action that was in progress during the failure 135 string action_in_progress = 1; 136 137 // A free-formed text that can help debugging the issue at hand. 138 string debug_help_message = 10; 139 140 // The fully-qualified name of the exception class associated with the error. 141 string error_type = 20; 142 143 // Error Identifiers 144 // The name identifying the error 145 string error_name = 30; 146 // The class that raised the error 147 string origin = 31; 148 // The error code associated with the error_name 149 int64 error_code = 32; 150} 151