xref: /aosp_15_r20/external/perfetto/test/gtest_logcat_printer.cc (revision 6dbdd20afdafa5e3ca9b8809fa73465d530080dc)
1*6dbdd20aSAndroid Build Coastguard Worker /*
2*6dbdd20aSAndroid Build Coastguard Worker  * Copyright (C) 2020 The Android Open Source Project
3*6dbdd20aSAndroid Build Coastguard Worker  *
4*6dbdd20aSAndroid Build Coastguard Worker  * Licensed under the Apache License, Version 2.0 (the "License");
5*6dbdd20aSAndroid Build Coastguard Worker  * you may not use this file except in compliance with the License.
6*6dbdd20aSAndroid Build Coastguard Worker  * You may obtain a copy of the License at
7*6dbdd20aSAndroid Build Coastguard Worker  *
8*6dbdd20aSAndroid Build Coastguard Worker  *      http://www.apache.org/licenses/LICENSE-2.0
9*6dbdd20aSAndroid Build Coastguard Worker  *
10*6dbdd20aSAndroid Build Coastguard Worker  * Unless required by applicable law or agreed to in writing, software
11*6dbdd20aSAndroid Build Coastguard Worker  * distributed under the License is distributed on an "AS IS" BASIS,
12*6dbdd20aSAndroid Build Coastguard Worker  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13*6dbdd20aSAndroid Build Coastguard Worker  * See the License for the specific language governing permissions and
14*6dbdd20aSAndroid Build Coastguard Worker  * limitations under the License.
15*6dbdd20aSAndroid Build Coastguard Worker  */
16*6dbdd20aSAndroid Build Coastguard Worker 
17*6dbdd20aSAndroid Build Coastguard Worker // This file registers a GTest listener that logs test begin/end in logcat.
18*6dbdd20aSAndroid Build Coastguard Worker // This is to avoid problems like b/149852934 where the test output cannot be
19*6dbdd20aSAndroid Build Coastguard Worker // correlated with the prouction code's logcat logs because they use different
20*6dbdd20aSAndroid Build Coastguard Worker // clock sources.
21*6dbdd20aSAndroid Build Coastguard Worker 
22*6dbdd20aSAndroid Build Coastguard Worker #include <android/log.h>
23*6dbdd20aSAndroid Build Coastguard Worker 
24*6dbdd20aSAndroid Build Coastguard Worker #include "test/gtest_and_gmock.h"
25*6dbdd20aSAndroid Build Coastguard Worker 
26*6dbdd20aSAndroid Build Coastguard Worker namespace perfetto {
27*6dbdd20aSAndroid Build Coastguard Worker namespace test {
28*6dbdd20aSAndroid Build Coastguard Worker 
29*6dbdd20aSAndroid Build Coastguard Worker namespace {
30*6dbdd20aSAndroid Build Coastguard Worker 
31*6dbdd20aSAndroid Build Coastguard Worker #define PERFETTO_TEST_LOG(...) \
32*6dbdd20aSAndroid Build Coastguard Worker   __android_log_print(ANDROID_LOG_DEBUG, "perfetto", ##__VA_ARGS__)
33*6dbdd20aSAndroid Build Coastguard Worker 
34*6dbdd20aSAndroid Build Coastguard Worker class LogcatPrinter : public testing::EmptyTestEventListener {
35*6dbdd20aSAndroid Build Coastguard Worker  public:
36*6dbdd20aSAndroid Build Coastguard Worker   LogcatPrinter();
37*6dbdd20aSAndroid Build Coastguard Worker   ~LogcatPrinter() override;
38*6dbdd20aSAndroid Build Coastguard Worker 
39*6dbdd20aSAndroid Build Coastguard Worker   // testing::EmptyTestEventListener:
40*6dbdd20aSAndroid Build Coastguard Worker   void OnTestCaseStart(const testing::TestCase& test_case) override;
41*6dbdd20aSAndroid Build Coastguard Worker   void OnTestStart(const testing::TestInfo& test_info) override;
42*6dbdd20aSAndroid Build Coastguard Worker   void OnTestEnd(const testing::TestInfo& test_info) override;
43*6dbdd20aSAndroid Build Coastguard Worker   void OnTestCaseEnd(const testing::TestCase& test_case) override;
44*6dbdd20aSAndroid Build Coastguard Worker };
45*6dbdd20aSAndroid Build Coastguard Worker 
46*6dbdd20aSAndroid Build Coastguard Worker LogcatPrinter::LogcatPrinter() = default;
47*6dbdd20aSAndroid Build Coastguard Worker LogcatPrinter::~LogcatPrinter() = default;
48*6dbdd20aSAndroid Build Coastguard Worker 
OnTestCaseStart(const testing::TestCase & test_case)49*6dbdd20aSAndroid Build Coastguard Worker void LogcatPrinter::OnTestCaseStart(const testing::TestCase& test_case) {
50*6dbdd20aSAndroid Build Coastguard Worker   PERFETTO_TEST_LOG("Test case start: %s", test_case.name());
51*6dbdd20aSAndroid Build Coastguard Worker }
52*6dbdd20aSAndroid Build Coastguard Worker 
OnTestStart(const testing::TestInfo & test_info)53*6dbdd20aSAndroid Build Coastguard Worker void LogcatPrinter::OnTestStart(const testing::TestInfo& test_info) {
54*6dbdd20aSAndroid Build Coastguard Worker   PERFETTO_TEST_LOG("Test start: %s.%s", test_info.test_case_name(),
55*6dbdd20aSAndroid Build Coastguard Worker                     test_info.name());
56*6dbdd20aSAndroid Build Coastguard Worker }
57*6dbdd20aSAndroid Build Coastguard Worker 
OnTestEnd(const testing::TestInfo & test_info)58*6dbdd20aSAndroid Build Coastguard Worker void LogcatPrinter::OnTestEnd(const testing::TestInfo& test_info) {
59*6dbdd20aSAndroid Build Coastguard Worker   const auto* result = test_info.result();
60*6dbdd20aSAndroid Build Coastguard Worker   const char* state = "N/A";
61*6dbdd20aSAndroid Build Coastguard Worker   if (result) {
62*6dbdd20aSAndroid Build Coastguard Worker     if (result->Passed())
63*6dbdd20aSAndroid Build Coastguard Worker       state = "PASS";
64*6dbdd20aSAndroid Build Coastguard Worker     else if (result->Skipped())
65*6dbdd20aSAndroid Build Coastguard Worker       state = "SKIPPED";
66*6dbdd20aSAndroid Build Coastguard Worker     else if (result->Failed())
67*6dbdd20aSAndroid Build Coastguard Worker       state = "FAIL";
68*6dbdd20aSAndroid Build Coastguard Worker   }
69*6dbdd20aSAndroid Build Coastguard Worker   PERFETTO_TEST_LOG("Test end: %s.%s [%s]", test_info.test_case_name(),
70*6dbdd20aSAndroid Build Coastguard Worker                     test_info.name(), state);
71*6dbdd20aSAndroid Build Coastguard Worker }
72*6dbdd20aSAndroid Build Coastguard Worker 
OnTestCaseEnd(const testing::TestCase & test_case)73*6dbdd20aSAndroid Build Coastguard Worker void LogcatPrinter::OnTestCaseEnd(const testing::TestCase& test_case) {
74*6dbdd20aSAndroid Build Coastguard Worker   PERFETTO_TEST_LOG("Test case end: %s. succeeded=%d, failed=%d",
75*6dbdd20aSAndroid Build Coastguard Worker                     test_case.name(), test_case.successful_test_count(),
76*6dbdd20aSAndroid Build Coastguard Worker                     test_case.failed_test_count());
77*6dbdd20aSAndroid Build Coastguard Worker }
78*6dbdd20aSAndroid Build Coastguard Worker 
79*6dbdd20aSAndroid Build Coastguard Worker // This static initializer
80*6dbdd20aSAndroid Build Coastguard Worker void __attribute__((constructor)) __attribute__((visibility("default")))
SetupGtestLogcatPrinter()81*6dbdd20aSAndroid Build Coastguard Worker SetupGtestLogcatPrinter() {
82*6dbdd20aSAndroid Build Coastguard Worker   static LogcatPrinter* instance = new LogcatPrinter();
83*6dbdd20aSAndroid Build Coastguard Worker   auto& listeners = testing::UnitTest::GetInstance()->listeners();
84*6dbdd20aSAndroid Build Coastguard Worker   listeners.Append(instance);
85*6dbdd20aSAndroid Build Coastguard Worker }
86*6dbdd20aSAndroid Build Coastguard Worker 
87*6dbdd20aSAndroid Build Coastguard Worker }  // namespace
88*6dbdd20aSAndroid Build Coastguard Worker }  // namespace test
89*6dbdd20aSAndroid Build Coastguard Worker }  // namespace perfetto
90