xref: /aosp_15_r20/system/logging/liblog/tests/log_wrap_test.cpp (revision 598139dc91b21518d67c408eaea2644226490971)
1*598139dcSAndroid Build Coastguard Worker /*
2*598139dcSAndroid Build Coastguard Worker  * Copyright (C) 2013-2017 The Android Open Source Project
3*598139dcSAndroid Build Coastguard Worker  *
4*598139dcSAndroid Build Coastguard Worker  * Licensed under the Apache License, Version 2.0 (the "License");
5*598139dcSAndroid Build Coastguard Worker  * you may not use this file except in compliance with the License.
6*598139dcSAndroid Build Coastguard Worker  * You may obtain a copy of the License at
7*598139dcSAndroid Build Coastguard Worker  *
8*598139dcSAndroid Build Coastguard Worker  *      http://www.apache.org/licenses/LICENSE-2.0
9*598139dcSAndroid Build Coastguard Worker  *
10*598139dcSAndroid Build Coastguard Worker  * Unless required by applicable law or agreed to in writing, software
11*598139dcSAndroid Build Coastguard Worker  * distributed under the License is distributed on an "AS IS" BASIS,
12*598139dcSAndroid Build Coastguard Worker  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13*598139dcSAndroid Build Coastguard Worker  * See the License for the specific language governing permissions and
14*598139dcSAndroid Build Coastguard Worker  * limitations under the License.
15*598139dcSAndroid Build Coastguard Worker  */
16*598139dcSAndroid Build Coastguard Worker 
17*598139dcSAndroid Build Coastguard Worker #include <sys/types.h>
18*598139dcSAndroid Build Coastguard Worker #include <time.h>
19*598139dcSAndroid Build Coastguard Worker #include <unistd.h>
20*598139dcSAndroid Build Coastguard Worker 
21*598139dcSAndroid Build Coastguard Worker #include <string>
22*598139dcSAndroid Build Coastguard Worker 
23*598139dcSAndroid Build Coastguard Worker #include <android-base/chrono_utils.h>
24*598139dcSAndroid Build Coastguard Worker #include <android-base/stringprintf.h>
25*598139dcSAndroid Build Coastguard Worker #include <android/log.h>  // minimal logging API
26*598139dcSAndroid Build Coastguard Worker #include <gtest/gtest.h>
27*598139dcSAndroid Build Coastguard Worker #include <log/log_properties.h>
28*598139dcSAndroid Build Coastguard Worker #include <log/log_read.h>
29*598139dcSAndroid Build Coastguard Worker #include <log/log_time.h>
30*598139dcSAndroid Build Coastguard Worker 
31*598139dcSAndroid Build Coastguard Worker #include "test_utils.h"
32*598139dcSAndroid Build Coastguard Worker 
33*598139dcSAndroid Build Coastguard Worker #ifdef __ANDROID__
read_with_wrap()34*598139dcSAndroid Build Coastguard Worker static void read_with_wrap() {
35*598139dcSAndroid Build Coastguard Worker   // Read the last line in the log to get a starting timestamp. We're assuming
36*598139dcSAndroid Build Coastguard Worker   // the log is not empty.
37*598139dcSAndroid Build Coastguard Worker   const int mode = ANDROID_LOG_NONBLOCK;
38*598139dcSAndroid Build Coastguard Worker   struct logger_list* logger_list = android_logger_list_open(LOG_ID_SYSTEM, mode, INT_MAX, 0);
39*598139dcSAndroid Build Coastguard Worker 
40*598139dcSAndroid Build Coastguard Worker   ASSERT_NE(logger_list, nullptr);
41*598139dcSAndroid Build Coastguard Worker 
42*598139dcSAndroid Build Coastguard Worker   log_msg log_msg;
43*598139dcSAndroid Build Coastguard Worker   int ret = android_logger_list_read(logger_list, &log_msg);
44*598139dcSAndroid Build Coastguard Worker   android_logger_list_close(logger_list);
45*598139dcSAndroid Build Coastguard Worker   ASSERT_GT(ret, 0);
46*598139dcSAndroid Build Coastguard Worker 
47*598139dcSAndroid Build Coastguard Worker   log_time start(log_msg.entry.sec, log_msg.entry.nsec);
48*598139dcSAndroid Build Coastguard Worker   ASSERT_NE(start, log_time());
49*598139dcSAndroid Build Coastguard Worker 
50*598139dcSAndroid Build Coastguard Worker   logger_list =
51*598139dcSAndroid Build Coastguard Worker       android_logger_list_alloc_time(mode | ANDROID_LOG_WRAP, start, 0);
52*598139dcSAndroid Build Coastguard Worker   ASSERT_NE(logger_list, nullptr);
53*598139dcSAndroid Build Coastguard Worker   struct logger* logger = android_logger_open(logger_list, LOG_ID_SYSTEM);
54*598139dcSAndroid Build Coastguard Worker   EXPECT_NE(logger, nullptr);
55*598139dcSAndroid Build Coastguard Worker   if (logger) {
56*598139dcSAndroid Build Coastguard Worker     android_logger_list_read(logger_list, &log_msg);
57*598139dcSAndroid Build Coastguard Worker   }
58*598139dcSAndroid Build Coastguard Worker 
59*598139dcSAndroid Build Coastguard Worker   android_logger_list_close(logger_list);
60*598139dcSAndroid Build Coastguard Worker }
61*598139dcSAndroid Build Coastguard Worker #endif
62*598139dcSAndroid Build Coastguard Worker 
63*598139dcSAndroid Build Coastguard Worker // b/64143705 confirm fixed
64*598139dcSAndroid Build Coastguard Worker // This test is tends to be flaky based on other log messages in the system,
65*598139dcSAndroid Build Coastguard Worker // so simply disable it.
TEST(liblog,DISABLED_wrap_mode_blocks)66*598139dcSAndroid Build Coastguard Worker TEST(liblog, DISABLED_wrap_mode_blocks) {
67*598139dcSAndroid Build Coastguard Worker #ifdef __ANDROID__
68*598139dcSAndroid Build Coastguard Worker   // The read call is expected to take up to 2 hours in the happy case.  There was a previous bug
69*598139dcSAndroid Build Coastguard Worker   // where it would take only 30 seconds due to an alarm() in logd_reader.cpp.  That alarm has been
70*598139dcSAndroid Build Coastguard Worker   // removed, so we check here that the read call blocks for a reasonable amount of time (5s).
71*598139dcSAndroid Build Coastguard Worker 
72*598139dcSAndroid Build Coastguard Worker   struct sigaction ignore = {.sa_handler = [](int) { _exit(0); }};
73*598139dcSAndroid Build Coastguard Worker   struct sigaction old_sigaction;
74*598139dcSAndroid Build Coastguard Worker   sigaction(SIGALRM, &ignore, &old_sigaction);
75*598139dcSAndroid Build Coastguard Worker   alarm(getAlarmSeconds(5));
76*598139dcSAndroid Build Coastguard Worker 
77*598139dcSAndroid Build Coastguard Worker   android::base::Timer timer;
78*598139dcSAndroid Build Coastguard Worker   read_with_wrap();
79*598139dcSAndroid Build Coastguard Worker 
80*598139dcSAndroid Build Coastguard Worker   FAIL() << "read_with_wrap() should not return before the alarm is triggered.";
81*598139dcSAndroid Build Coastguard Worker 
82*598139dcSAndroid Build Coastguard Worker   alarm(0);
83*598139dcSAndroid Build Coastguard Worker   sigaction(SIGALRM, &old_sigaction, nullptr);
84*598139dcSAndroid Build Coastguard Worker #else
85*598139dcSAndroid Build Coastguard Worker   GTEST_LOG_(INFO) << "This test does nothing.\n";
86*598139dcSAndroid Build Coastguard Worker #endif
87*598139dcSAndroid Build Coastguard Worker }
88