1 /*
2  * Copyright (C) 2021 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  */
16 
17 #define LOG_TAG "TestExecutionTracer"
18 
19 #include "test_execution_tracer.h"
20 
21 #include <android-base/logging.h>
22 
OnTestStart(const::testing::TestInfo & test_info)23 void TestExecutionTracer::OnTestStart(const ::testing::TestInfo& test_info) {
24     TraceTestState("Started", test_info);
25 }
26 
OnTestEnd(const::testing::TestInfo & test_info)27 void TestExecutionTracer::OnTestEnd(const ::testing::TestInfo& test_info) {
28     TraceTestState("Finished", test_info);
29 }
30 
OnTestPartResult(const::testing::TestPartResult & result)31 void TestExecutionTracer::OnTestPartResult(const ::testing::TestPartResult& result) {
32     if (result.failed()) {
33         LOG(ERROR) << result;
34     } else {
35         LOG(INFO) << result;
36     }
37 }
38 
39 // static
TraceTestState(const std::string & state,const::testing::TestInfo & test_info)40 void TestExecutionTracer::TraceTestState(const std::string& state,
41                                          const ::testing::TestInfo& test_info) {
42     LOG(INFO) << state << " " << test_info.test_suite_name() << "::" << test_info.name();
43 }
44