OLD | NEW |
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. |
2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
4 | 4 |
5 #include "base/debug/trace_event_unittest.h" | 5 #include "base/debug/trace_event_unittest.h" |
6 | 6 |
7 #include <math.h> | 7 #include <math.h> |
8 #include <cstdlib> | 8 #include <cstdlib> |
9 | 9 |
10 #include "base/bind.h" | 10 #include "base/bind.h" |
(...skipping 2980 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
2991 filter1.Merge(filter2); | 2991 filter1.Merge(filter2); |
2992 EXPECT_EQ(2u, filter1.GetSyntheticDelayValues().size()); | 2992 EXPECT_EQ(2u, filter1.GetSyntheticDelayValues().size()); |
2993 } | 2993 } |
2994 | 2994 |
2995 TEST_F(TraceEventTestFixture, SyntheticDelayConfigurationToString) { | 2995 TEST_F(TraceEventTestFixture, SyntheticDelayConfigurationToString) { |
2996 const char config[] = "DELAY(test.Delay;16;oneshot)"; | 2996 const char config[] = "DELAY(test.Delay;16;oneshot)"; |
2997 CategoryFilter filter(config); | 2997 CategoryFilter filter(config); |
2998 EXPECT_EQ(config, filter.ToString()); | 2998 EXPECT_EQ(config, filter.ToString()); |
2999 } | 2999 } |
3000 | 3000 |
3001 TEST(TraceOptionsTest, DISABLED_TraceOptionsFromString) { | 3001 TEST(TraceOptionsTest, TraceOptionsFromString) { |
3002 TraceOptions options = TraceOptions("record-until-full"); | 3002 TraceOptions options; |
| 3003 EXPECT_TRUE(options.SetFromString("record-until-full")); |
3003 EXPECT_EQ(RECORD_UNTIL_FULL, options.record_mode); | 3004 EXPECT_EQ(RECORD_UNTIL_FULL, options.record_mode); |
3004 EXPECT_FALSE(options.enable_sampling); | 3005 EXPECT_FALSE(options.enable_sampling); |
3005 EXPECT_FALSE(options.enable_systrace); | 3006 EXPECT_FALSE(options.enable_systrace); |
3006 | 3007 |
3007 options = TraceOptions(RECORD_CONTINUOUSLY); | 3008 EXPECT_TRUE(options.SetFromString("record-continuously")); |
3008 EXPECT_EQ(RECORD_CONTINUOUSLY, options.record_mode); | 3009 EXPECT_EQ(RECORD_CONTINUOUSLY, options.record_mode); |
3009 EXPECT_FALSE(options.enable_sampling); | 3010 EXPECT_FALSE(options.enable_sampling); |
3010 EXPECT_FALSE(options.enable_systrace); | 3011 EXPECT_FALSE(options.enable_systrace); |
3011 | 3012 |
3012 options = TraceOptions("trace-to-console"); | 3013 EXPECT_TRUE(options.SetFromString("trace-to-console")); |
3013 EXPECT_EQ(ECHO_TO_CONSOLE, options.record_mode); | 3014 EXPECT_EQ(ECHO_TO_CONSOLE, options.record_mode); |
3014 EXPECT_FALSE(options.enable_sampling); | 3015 EXPECT_FALSE(options.enable_sampling); |
3015 EXPECT_FALSE(options.enable_systrace); | 3016 EXPECT_FALSE(options.enable_systrace); |
3016 | 3017 |
3017 options = TraceOptions("record-as-much-as-possible"); | 3018 EXPECT_TRUE(options.SetFromString("record-as-much-as-possible")); |
3018 EXPECT_EQ(RECORD_AS_MUCH_AS_POSSIBLE, options.record_mode); | 3019 EXPECT_EQ(RECORD_AS_MUCH_AS_POSSIBLE, options.record_mode); |
3019 EXPECT_FALSE(options.enable_sampling); | 3020 EXPECT_FALSE(options.enable_sampling); |
3020 EXPECT_FALSE(options.enable_systrace); | 3021 EXPECT_FALSE(options.enable_systrace); |
3021 | 3022 |
3022 options = TraceOptions("record-until-full, enable-sampling"); | 3023 EXPECT_TRUE(options.SetFromString("record-until-full, enable-sampling")); |
3023 EXPECT_EQ(RECORD_UNTIL_FULL, options.record_mode); | 3024 EXPECT_EQ(RECORD_UNTIL_FULL, options.record_mode); |
3024 EXPECT_TRUE(options.enable_sampling); | 3025 EXPECT_TRUE(options.enable_sampling); |
3025 EXPECT_FALSE(options.enable_systrace); | 3026 EXPECT_FALSE(options.enable_systrace); |
3026 | 3027 |
3027 options = TraceOptions("enable-systrace,record-continuously"); | 3028 EXPECT_TRUE(options.SetFromString("enable-systrace,record-continuously")); |
3028 EXPECT_EQ(RECORD_CONTINUOUSLY, options.record_mode); | 3029 EXPECT_EQ(RECORD_CONTINUOUSLY, options.record_mode); |
3029 EXPECT_FALSE(options.enable_sampling); | 3030 EXPECT_FALSE(options.enable_sampling); |
3030 EXPECT_TRUE(options.enable_systrace); | 3031 EXPECT_TRUE(options.enable_systrace); |
3031 | 3032 |
3032 options = TraceOptions("enable-systrace, trace-to-console,enable-sampling"); | 3033 EXPECT_TRUE(options.SetFromString( |
| 3034 "enable-systrace, trace-to-console,enable-sampling")); |
3033 EXPECT_EQ(ECHO_TO_CONSOLE, options.record_mode); | 3035 EXPECT_EQ(ECHO_TO_CONSOLE, options.record_mode); |
3034 EXPECT_TRUE(options.enable_sampling); | 3036 EXPECT_TRUE(options.enable_sampling); |
3035 EXPECT_TRUE(options.enable_systrace); | 3037 EXPECT_TRUE(options.enable_systrace); |
3036 | 3038 |
3037 options = | 3039 EXPECT_TRUE(options.SetFromString( |
3038 TraceOptions("record-continuously,record-until-full,trace-to-console"); | 3040 "record-continuously,record-until-full,trace-to-console")); |
3039 EXPECT_EQ(ECHO_TO_CONSOLE, options.record_mode); | 3041 EXPECT_EQ(ECHO_TO_CONSOLE, options.record_mode); |
3040 EXPECT_FALSE(options.enable_systrace); | 3042 EXPECT_FALSE(options.enable_systrace); |
3041 EXPECT_FALSE(options.enable_sampling); | 3043 EXPECT_FALSE(options.enable_sampling); |
3042 | 3044 |
3043 options = TraceOptions(""); | 3045 EXPECT_TRUE(options.SetFromString("")); |
3044 EXPECT_EQ(RECORD_UNTIL_FULL, options.record_mode); | 3046 EXPECT_EQ(RECORD_UNTIL_FULL, options.record_mode); |
3045 EXPECT_FALSE(options.enable_systrace); | 3047 EXPECT_FALSE(options.enable_systrace); |
3046 EXPECT_FALSE(options.enable_sampling); | 3048 EXPECT_FALSE(options.enable_sampling); |
3047 | 3049 |
3048 #if GTEST_HAS_EXCEPTIONS | 3050 EXPECT_FALSE(options.SetFromString("foo-bar-baz")); |
3049 EXPECT_THROW(TraceOptions("foo-bar-baz"), int); | |
3050 #endif | |
3051 } | 3051 } |
3052 | 3052 |
3053 TEST(TraceOptionsTest, TraceOptionsToString) { | 3053 TEST(TraceOptionsTest, TraceOptionsToString) { |
3054 // Test that we can intialize TraceOptions from a string got from | 3054 // Test that we can intialize TraceOptions from a string got from |
3055 // TraceOptions.ToString() method to get a same TraceOptions. | 3055 // TraceOptions.ToString() method to get a same TraceOptions. |
3056 TraceRecordMode modes[] = {RECORD_UNTIL_FULL, | 3056 TraceRecordMode modes[] = {RECORD_UNTIL_FULL, |
3057 RECORD_CONTINUOUSLY, | 3057 RECORD_CONTINUOUSLY, |
3058 ECHO_TO_CONSOLE, | 3058 ECHO_TO_CONSOLE, |
3059 RECORD_AS_MUCH_AS_POSSIBLE}; | 3059 RECORD_AS_MUCH_AS_POSSIBLE}; |
3060 bool enable_sampling_options[] = {true, false}; | 3060 bool enable_sampling_options[] = {true, false}; |
3061 bool enable_systrace_options[] = {true, false}; | 3061 bool enable_systrace_options[] = {true, false}; |
3062 | 3062 |
3063 for (int i = 0; i < 4; ++i) { | 3063 for (int i = 0; i < 4; ++i) { |
3064 for (int j = 0; j < 2; ++j) { | 3064 for (int j = 0; j < 2; ++j) { |
3065 for (int k = 0; k < 2; ++k) { | 3065 for (int k = 0; k < 2; ++k) { |
3066 TraceOptions original_option = TraceOptions(modes[i]); | 3066 TraceOptions original_option = TraceOptions(modes[i]); |
3067 original_option.enable_sampling = enable_sampling_options[j]; | 3067 original_option.enable_sampling = enable_sampling_options[j]; |
3068 original_option.enable_systrace = enable_systrace_options[k]; | 3068 original_option.enable_systrace = enable_systrace_options[k]; |
3069 TraceOptions new_options = TraceOptions(original_option.ToString()); | 3069 TraceOptions new_options; |
| 3070 EXPECT_TRUE(new_options.SetFromString(original_option.ToString())); |
3070 EXPECT_EQ(original_option.record_mode, new_options.record_mode); | 3071 EXPECT_EQ(original_option.record_mode, new_options.record_mode); |
3071 EXPECT_EQ(original_option.enable_sampling, new_options.enable_sampling); | 3072 EXPECT_EQ(original_option.enable_sampling, new_options.enable_sampling); |
3072 EXPECT_EQ(original_option.enable_systrace, new_options.enable_systrace); | 3073 EXPECT_EQ(original_option.enable_systrace, new_options.enable_systrace); |
3073 } | 3074 } |
3074 } | 3075 } |
3075 } | 3076 } |
3076 } | 3077 } |
3077 | 3078 |
3078 | 3079 |
3079 } // namespace debug | 3080 } // namespace debug |
3080 } // namespace base | 3081 } // namespace base |
OLD | NEW |