1 /* 2 * Copyright (C) 2017 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 #include "logging.h" 18 19 #include <type_traits> 20 21 #include "android-base/logging.h" 22 #include "base/bit_utils.h" 23 #include "base/macros.h" 24 #include "common_runtime_test.h" 25 #include "runtime_debug.h" 26 27 namespace art { 28 SimpleAborter(const char * msg)29static void SimpleAborter(const char* msg) { 30 LOG(FATAL_WITHOUT_ABORT) << msg; 31 _exit(1); 32 } 33 34 class LoggingTest : public CommonRuntimeTest { 35 protected: PostRuntimeCreate()36 void PostRuntimeCreate() OVERRIDE { 37 // In our abort tests we really don't want the runtime to create a real dump. 38 android::base::SetAborter(SimpleAborter); 39 } 40 }; 41 42 #ifdef NDEBUG 43 #error Unexpected NDEBUG 44 #endif 45 46 class TestClass { 47 public: 48 DECLARE_RUNTIME_DEBUG_FLAG(kFlag); 49 }; 50 DEFINE_RUNTIME_DEBUG_FLAG(TestClass, kFlag); 51 TEST_F(LoggingTest,DECL_DEF)52TEST_F(LoggingTest, DECL_DEF) { 53 SetRuntimeDebugFlagsEnabled(true); 54 EXPECT_TRUE(TestClass::kFlag); 55 56 SetRuntimeDebugFlagsEnabled(false); 57 EXPECT_FALSE(TestClass::kFlag); 58 } 59 60 } // namespace art 61