xref: /aosp_15_r20/art/libartbase/base/logging_test.cc (revision 795d594fd825385562da6b089ea9b2033f3abf5a)
1*795d594fSAndroid Build Coastguard Worker /*
2*795d594fSAndroid Build Coastguard Worker  * Copyright (C) 2017 The Android Open Source Project
3*795d594fSAndroid Build Coastguard Worker  *
4*795d594fSAndroid Build Coastguard Worker  * Licensed under the Apache License, Version 2.0 (the "License");
5*795d594fSAndroid Build Coastguard Worker  * you may not use this file except in compliance with the License.
6*795d594fSAndroid Build Coastguard Worker  * You may obtain a copy of the License at
7*795d594fSAndroid Build Coastguard Worker  *
8*795d594fSAndroid Build Coastguard Worker  *      http://www.apache.org/licenses/LICENSE-2.0
9*795d594fSAndroid Build Coastguard Worker  *
10*795d594fSAndroid Build Coastguard Worker  * Unless required by applicable law or agreed to in writing, software
11*795d594fSAndroid Build Coastguard Worker  * distributed under the License is distributed on an "AS IS" BASIS,
12*795d594fSAndroid Build Coastguard Worker  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13*795d594fSAndroid Build Coastguard Worker  * See the License for the specific language governing permissions and
14*795d594fSAndroid Build Coastguard Worker  * limitations under the License.
15*795d594fSAndroid Build Coastguard Worker  */
16*795d594fSAndroid Build Coastguard Worker 
17*795d594fSAndroid Build Coastguard Worker #include "logging.h"
18*795d594fSAndroid Build Coastguard Worker 
19*795d594fSAndroid Build Coastguard Worker #include <type_traits>
20*795d594fSAndroid Build Coastguard Worker 
21*795d594fSAndroid Build Coastguard Worker #include "android-base/logging.h"
22*795d594fSAndroid Build Coastguard Worker #include "bit_utils.h"
23*795d594fSAndroid Build Coastguard Worker #include "gtest/gtest.h"
24*795d594fSAndroid Build Coastguard Worker #include "macros.h"
25*795d594fSAndroid Build Coastguard Worker #include "runtime_debug.h"
26*795d594fSAndroid Build Coastguard Worker 
27*795d594fSAndroid Build Coastguard Worker namespace art {
28*795d594fSAndroid Build Coastguard Worker 
29*795d594fSAndroid Build Coastguard Worker [[noreturn]]
SimpleAborter(const char * msg)30*795d594fSAndroid Build Coastguard Worker static void SimpleAborter(const char* msg) {
31*795d594fSAndroid Build Coastguard Worker   LOG(FATAL_WITHOUT_ABORT) << msg;
32*795d594fSAndroid Build Coastguard Worker   _exit(1);
33*795d594fSAndroid Build Coastguard Worker }
34*795d594fSAndroid Build Coastguard Worker 
35*795d594fSAndroid Build Coastguard Worker class LoggingTest : public testing::Test {
36*795d594fSAndroid Build Coastguard Worker  protected:
LoggingTest()37*795d594fSAndroid Build Coastguard Worker   LoggingTest() {
38*795d594fSAndroid Build Coastguard Worker     // In our abort tests we really don't want the runtime to create a real dump.
39*795d594fSAndroid Build Coastguard Worker     android::base::SetAborter(SimpleAborter);
40*795d594fSAndroid Build Coastguard Worker   }
41*795d594fSAndroid Build Coastguard Worker };
42*795d594fSAndroid Build Coastguard Worker 
43*795d594fSAndroid Build Coastguard Worker class TestClass {
44*795d594fSAndroid Build Coastguard Worker  public:
45*795d594fSAndroid Build Coastguard Worker   DECLARE_RUNTIME_DEBUG_FLAG(kFlag);
46*795d594fSAndroid Build Coastguard Worker };
47*795d594fSAndroid Build Coastguard Worker DEFINE_RUNTIME_DEBUG_FLAG(TestClass, kFlag);
48*795d594fSAndroid Build Coastguard Worker 
TEST_F(LoggingTest,DECL_DEF)49*795d594fSAndroid Build Coastguard Worker TEST_F(LoggingTest, DECL_DEF) {
50*795d594fSAndroid Build Coastguard Worker   SetRuntimeDebugFlagsEnabled(true);
51*795d594fSAndroid Build Coastguard Worker   if (kIsDebugBuild) {
52*795d594fSAndroid Build Coastguard Worker     EXPECT_TRUE(TestClass::kFlag);
53*795d594fSAndroid Build Coastguard Worker   } else {
54*795d594fSAndroid Build Coastguard Worker     // Runtime debug flags have a constant `false` value on non-debug builds.
55*795d594fSAndroid Build Coastguard Worker     EXPECT_FALSE(TestClass::kFlag);
56*795d594fSAndroid Build Coastguard Worker   }
57*795d594fSAndroid Build Coastguard Worker 
58*795d594fSAndroid Build Coastguard Worker   SetRuntimeDebugFlagsEnabled(false);
59*795d594fSAndroid Build Coastguard Worker   EXPECT_FALSE(TestClass::kFlag);
60*795d594fSAndroid Build Coastguard Worker }
61*795d594fSAndroid Build Coastguard Worker 
62*795d594fSAndroid Build Coastguard Worker }  // namespace art
63