| /* |
| * Copyright (C) 2007 The Android Open Source Project |
| * |
| * Licensed under the Apache License, Version 2.0 (the "License"); |
| * you may not use this file except in compliance with the License. |
| * You may obtain a copy of the License at |
| * |
| * http://www.apache.org/licenses/LICENSE-2.0 |
| * |
| * Unless required by applicable law or agreed to in writing, software |
| * distributed under the License is distributed on an "AS IS" BASIS, |
| * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
| * See the License for the specific language governing permissions and |
| * limitations under the License. |
| */ |
| |
| package android.util; |
| |
| import junit.framework.Assert; |
| import junit.framework.TestCase; |
| |
| import android.os.SystemProperties; |
| import android.test.PerformanceTestCase; |
| import android.test.suitebuilder.annotation.Suppress; |
| import android.util.Log; |
| |
| //This is an empty TestCase. |
| @Suppress |
| public class LogTest extends TestCase { |
| private static final String PROPERTY_TAG = "log.tag.LogTest"; |
| private static final String LOG_TAG = "LogTest"; |
| |
| |
| // TODO: remove this test once we uncomment out the following test. |
| public void testLogTestDummy() { |
| return; |
| } |
| |
| |
| /* TODO: This test is commented out because we will not be able to set properities. Fix the test. |
| public void testIsLoggable() { |
| // First clear any SystemProperty setting for our test key. |
| SystemProperties.set(PROPERTY_TAG, null); |
| |
| String value = SystemProperties.get(PROPERTY_TAG); |
| Assert.assertTrue(value == null || value.length() == 0); |
| |
| // Check to make sure that all levels expect for INFO, WARN, ERROR, and ASSERT are loggable. |
| Assert.assertFalse(Log.isLoggable(LOG_TAG, Log.VERBOSE)); |
| Assert.assertFalse(Log.isLoggable(LOG_TAG, Log.DEBUG)); |
| Assert.assertTrue(Log.isLoggable(LOG_TAG, Log.INFO)); |
| Assert.assertTrue(Log.isLoggable(LOG_TAG, Log.WARN)); |
| Assert.assertTrue(Log.isLoggable(LOG_TAG, Log.ERROR)); |
| Assert.assertTrue(Log.isLoggable(LOG_TAG, Log.ASSERT)); |
| |
| // Set the log level to be VERBOSE for this tag. |
| SystemProperties.set(PROPERTY_TAG, "VERBOSE"); |
| |
| // Test to make sure all log levels >= VERBOSE are loggable. |
| Assert.assertTrue(Log.isLoggable(LOG_TAG, Log.VERBOSE)); |
| Assert.assertTrue(Log.isLoggable(LOG_TAG, Log.DEBUG)); |
| Assert.assertTrue(Log.isLoggable(LOG_TAG, Log.INFO)); |
| Assert.assertTrue(Log.isLoggable(LOG_TAG, Log.WARN)); |
| Assert.assertTrue(Log.isLoggable(LOG_TAG, Log.ERROR)); |
| Assert.assertTrue(Log.isLoggable(LOG_TAG, Log.ASSERT)); |
| |
| // Set the log level to be DEBUG for this tag. |
| SystemProperties.set(PROPERTY_TAG, "DEBUG"); |
| |
| // Test to make sure all log levels >= DEBUG are loggable. |
| Assert.assertFalse(Log.isLoggable(LOG_TAG, Log.VERBOSE)); |
| Assert.assertTrue(Log.isLoggable(LOG_TAG, Log.DEBUG)); |
| Assert.assertTrue(Log.isLoggable(LOG_TAG, Log.INFO)); |
| Assert.assertTrue(Log.isLoggable(LOG_TAG, Log.WARN)); |
| Assert.assertTrue(Log.isLoggable(LOG_TAG, Log.ERROR)); |
| Assert.assertTrue(Log.isLoggable(LOG_TAG, Log.ASSERT)); |
| |
| // Set the log level to be INFO for this tag. |
| SystemProperties.set(PROPERTY_TAG, "INFO"); |
| |
| // Test to make sure all log levels >= INFO are loggable. |
| Assert.assertFalse(Log.isLoggable(LOG_TAG, Log.VERBOSE)); |
| Assert.assertFalse(Log.isLoggable(LOG_TAG, Log.DEBUG)); |
| Assert.assertTrue(Log.isLoggable(LOG_TAG, Log.INFO)); |
| Assert.assertTrue(Log.isLoggable(LOG_TAG, Log.WARN)); |
| Assert.assertTrue(Log.isLoggable(LOG_TAG, Log.ERROR)); |
| Assert.assertTrue(Log.isLoggable(LOG_TAG, Log.ASSERT)); |
| |
| // Set the log level to be WARN for this tag. |
| SystemProperties.set(PROPERTY_TAG, "WARN"); |
| |
| // Test to make sure all log levels >= WARN are loggable. |
| Assert.assertFalse(Log.isLoggable(LOG_TAG, Log.VERBOSE)); |
| Assert.assertFalse(Log.isLoggable(LOG_TAG, Log.DEBUG)); |
| Assert.assertFalse(Log.isLoggable(LOG_TAG, Log.INFO)); |
| Assert.assertTrue(Log.isLoggable(LOG_TAG, Log.WARN)); |
| Assert.assertTrue(Log.isLoggable(LOG_TAG, Log.ERROR)); |
| Assert.assertTrue(Log.isLoggable(LOG_TAG, Log.ASSERT)); |
| |
| // Set the log level to be ERROR for this tag. |
| SystemProperties.set(PROPERTY_TAG, "ERROR"); |
| |
| // Test to make sure all log levels >= ERROR are loggable. |
| Assert.assertFalse(Log.isLoggable(LOG_TAG, Log.VERBOSE)); |
| Assert.assertFalse(Log.isLoggable(LOG_TAG, Log.DEBUG)); |
| Assert.assertFalse(Log.isLoggable(LOG_TAG, Log.INFO)); |
| Assert.assertFalse(Log.isLoggable(LOG_TAG, Log.WARN)); |
| Assert.assertTrue(Log.isLoggable(LOG_TAG, Log.ERROR)); |
| Assert.assertTrue(Log.isLoggable(LOG_TAG, Log.ASSERT)); |
| |
| // Set the log level to be ASSERT for this tag. |
| SystemProperties.set(PROPERTY_TAG, "ASSERT"); |
| |
| // Test to make sure all log levels >= ASSERT are loggable. |
| Assert.assertFalse(Log.isLoggable(LOG_TAG, Log.VERBOSE)); |
| Assert.assertFalse(Log.isLoggable(LOG_TAG, Log.DEBUG)); |
| Assert.assertFalse(Log.isLoggable(LOG_TAG, Log.INFO)); |
| Assert.assertFalse(Log.isLoggable(LOG_TAG, Log.WARN)); |
| Assert.assertFalse(Log.isLoggable(LOG_TAG, Log.ERROR)); |
| Assert.assertTrue(Log.isLoggable(LOG_TAG, Log.ASSERT)); |
| |
| // Set the log level to be SUPPRESS for this tag. |
| SystemProperties.set(PROPERTY_TAG, "SUPPRESS"); |
| |
| // Test to make sure all log levels >= ASSERT are loggable. |
| Assert.assertFalse(Log.isLoggable(LOG_TAG, Log.VERBOSE)); |
| Assert.assertFalse(Log.isLoggable(LOG_TAG, Log.DEBUG)); |
| Assert.assertFalse(Log.isLoggable(LOG_TAG, Log.INFO)); |
| Assert.assertFalse(Log.isLoggable(LOG_TAG, Log.WARN)); |
| Assert.assertFalse(Log.isLoggable(LOG_TAG, Log.ERROR)); |
| Assert.assertFalse(Log.isLoggable(LOG_TAG, Log.ASSERT)); |
| } |
| */ |
| |
| public static class PerformanceTest extends TestCase implements PerformanceTestCase { |
| private static final int ITERATIONS = 1000; |
| |
| @Override |
| public void setUp() { |
| SystemProperties.set(LOG_TAG, "VERBOSE"); |
| } |
| |
| public boolean isPerformanceOnly() { |
| return true; |
| } |
| |
| public int startPerformance(PerformanceTestCase.Intermediates intermediates) { |
| intermediates.setInternalIterations(ITERATIONS * 10); |
| return 0; |
| } |
| |
| public void testIsLoggable() { |
| boolean canLog = false; |
| for (int i = ITERATIONS - 1; i >= 0; i--) { |
| canLog = Log.isLoggable(LOG_TAG, Log.VERBOSE); |
| canLog = Log.isLoggable(LOG_TAG, Log.VERBOSE); |
| canLog = Log.isLoggable(LOG_TAG, Log.VERBOSE); |
| canLog = Log.isLoggable(LOG_TAG, Log.VERBOSE); |
| canLog = Log.isLoggable(LOG_TAG, Log.VERBOSE); |
| canLog = Log.isLoggable(LOG_TAG, Log.VERBOSE); |
| canLog = Log.isLoggable(LOG_TAG, Log.VERBOSE); |
| canLog = Log.isLoggable(LOG_TAG, Log.VERBOSE); |
| canLog = Log.isLoggable(LOG_TAG, Log.VERBOSE); |
| canLog = Log.isLoggable(LOG_TAG, Log.VERBOSE); |
| } |
| } |
| } |
| } |