| OLD | NEW |
| 1 // Copyright (c) 2015 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2015 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/trace_event/trace_config.h" | 5 #include "base/trace_event/trace_config.h" |
| 6 #include "testing/gtest/include/gtest/gtest.h" | 6 #include "testing/gtest/include/gtest/gtest.h" |
| 7 | 7 |
| 8 namespace base { | 8 namespace base { |
| 9 namespace trace_event { | 9 namespace trace_event { |
| 10 | 10 |
| 11 namespace { | 11 namespace { |
| 12 | 12 |
| 13 const char kDefaultTraceConfigString[] = | 13 const char kDefaultTraceConfigString[] = |
| 14 "{" | 14 "{" |
| 15 "\"enable_argument_filter\":false," | 15 "\"enable_argument_filter\":false," |
| 16 "\"enable_sampling\":false," | 16 "\"enable_sampling\":false," |
| 17 "\"enable_systrace\":false," | 17 "\"enable_systrace\":false," |
| 18 "\"excluded_categories\":[\"*Debug\",\"*Test\"]," | 18 "\"excluded_categories\":[\"*Debug\",\"*Test\"]," |
| 19 "\"record_mode\":\"record-until-full\"" | 19 "\"record_mode\":\"record-until-full\"" |
| 20 "}"; | 20 "}"; |
| 21 | 21 |
| 22 } // namespace | 22 } // namespace |
| 23 | 23 |
| 24 TEST(TraceConfigTest, TraceConfigFromValidLegacyStrings) { | 24 TEST(TraceConfigTest, TraceConfigFromValidLegacyFormat) { |
| 25 // From trace options strings | 25 // From trace options strings |
| 26 TraceConfig config("", "record-until-full"); | 26 TraceConfig config("", "record-until-full"); |
| 27 EXPECT_EQ(RECORD_UNTIL_FULL, config.record_mode_); | 27 EXPECT_EQ(RECORD_UNTIL_FULL, config.GetTraceRecordMode()); |
| 28 EXPECT_FALSE(config.enable_sampling_); | 28 EXPECT_FALSE(config.IsSamplingEnabled()); |
| 29 EXPECT_FALSE(config.enable_systrace_); | 29 EXPECT_FALSE(config.IsSystraceEnabled()); |
| 30 EXPECT_FALSE(config.enable_argument_filter_); | 30 EXPECT_FALSE(config.IsArgumentFilterEnabled()); |
| 31 EXPECT_STREQ("record-until-full", config.ToTraceOptionsString().c_str()); | 31 EXPECT_STREQ("record-until-full", config.ToTraceOptionsString().c_str()); |
| 32 | 32 |
| 33 config = TraceConfig("", "record-continuously"); | 33 config = TraceConfig("", "record-continuously"); |
| 34 EXPECT_EQ(RECORD_CONTINUOUSLY, config.record_mode_); | 34 EXPECT_EQ(RECORD_CONTINUOUSLY, config.GetTraceRecordMode()); |
| 35 EXPECT_FALSE(config.enable_sampling_); | 35 EXPECT_FALSE(config.IsSamplingEnabled()); |
| 36 EXPECT_FALSE(config.enable_systrace_); | 36 EXPECT_FALSE(config.IsSystraceEnabled()); |
| 37 EXPECT_FALSE(config.enable_argument_filter_); | 37 EXPECT_FALSE(config.IsArgumentFilterEnabled()); |
| 38 EXPECT_STREQ("record-continuously", config.ToTraceOptionsString().c_str()); | 38 EXPECT_STREQ("record-continuously", config.ToTraceOptionsString().c_str()); |
| 39 | 39 |
| 40 config = TraceConfig("", "trace-to-console"); | 40 config = TraceConfig("", "trace-to-console"); |
| 41 EXPECT_EQ(ECHO_TO_CONSOLE, config.record_mode_); | 41 EXPECT_EQ(ECHO_TO_CONSOLE, config.GetTraceRecordMode()); |
| 42 EXPECT_FALSE(config.enable_sampling_); | 42 EXPECT_FALSE(config.IsSamplingEnabled()); |
| 43 EXPECT_FALSE(config.enable_systrace_); | 43 EXPECT_FALSE(config.IsSystraceEnabled()); |
| 44 EXPECT_FALSE(config.enable_argument_filter_); | 44 EXPECT_FALSE(config.IsArgumentFilterEnabled()); |
| 45 EXPECT_STREQ("trace-to-console", config.ToTraceOptionsString().c_str()); | 45 EXPECT_STREQ("trace-to-console", config.ToTraceOptionsString().c_str()); |
| 46 | 46 |
| 47 config = TraceConfig("", "record-as-much-as-possible"); | 47 config = TraceConfig("", "record-as-much-as-possible"); |
| 48 EXPECT_EQ(RECORD_AS_MUCH_AS_POSSIBLE, config.record_mode_); | 48 EXPECT_EQ(RECORD_AS_MUCH_AS_POSSIBLE, config.GetTraceRecordMode()); |
| 49 EXPECT_FALSE(config.enable_sampling_); | 49 EXPECT_FALSE(config.IsSamplingEnabled()); |
| 50 EXPECT_FALSE(config.enable_systrace_); | 50 EXPECT_FALSE(config.IsSystraceEnabled()); |
| 51 EXPECT_FALSE(config.enable_argument_filter_); | 51 EXPECT_FALSE(config.IsArgumentFilterEnabled()); |
| 52 EXPECT_STREQ("record-as-much-as-possible", | 52 EXPECT_STREQ("record-as-much-as-possible", |
| 53 config.ToTraceOptionsString().c_str()); | 53 config.ToTraceOptionsString().c_str()); |
| 54 | 54 |
| 55 config = TraceConfig("", "record-until-full, enable-sampling"); | 55 config = TraceConfig("", "record-until-full, enable-sampling"); |
| 56 EXPECT_EQ(RECORD_UNTIL_FULL, config.record_mode_); | 56 EXPECT_EQ(RECORD_UNTIL_FULL, config.GetTraceRecordMode()); |
| 57 EXPECT_TRUE(config.enable_sampling_); | 57 EXPECT_TRUE(config.IsSamplingEnabled()); |
| 58 EXPECT_FALSE(config.enable_systrace_); | 58 EXPECT_FALSE(config.IsSystraceEnabled()); |
| 59 EXPECT_FALSE(config.enable_argument_filter_); | 59 EXPECT_FALSE(config.IsArgumentFilterEnabled()); |
| 60 EXPECT_STREQ("record-until-full,enable-sampling", | 60 EXPECT_STREQ("record-until-full,enable-sampling", |
| 61 config.ToTraceOptionsString().c_str()); | 61 config.ToTraceOptionsString().c_str()); |
| 62 | 62 |
| 63 config = TraceConfig("", "enable-systrace, record-continuously"); | 63 config = TraceConfig("", "enable-systrace, record-continuously"); |
| 64 EXPECT_EQ(RECORD_CONTINUOUSLY, config.record_mode_); | 64 EXPECT_EQ(RECORD_CONTINUOUSLY, config.GetTraceRecordMode()); |
| 65 EXPECT_FALSE(config.enable_sampling_); | 65 EXPECT_FALSE(config.IsSamplingEnabled()); |
| 66 EXPECT_TRUE(config.enable_systrace_); | 66 EXPECT_TRUE(config.IsSystraceEnabled()); |
| 67 EXPECT_FALSE(config.enable_argument_filter_); | 67 EXPECT_FALSE(config.IsArgumentFilterEnabled()); |
| 68 EXPECT_STREQ("record-continuously,enable-systrace", | 68 EXPECT_STREQ("record-continuously,enable-systrace", |
| 69 config.ToTraceOptionsString().c_str()); | 69 config.ToTraceOptionsString().c_str()); |
| 70 | 70 |
| 71 config = TraceConfig("", "enable-argument-filter,record-as-much-as-possible"); | 71 config = TraceConfig("", "enable-argument-filter,record-as-much-as-possible"); |
| 72 EXPECT_EQ(RECORD_AS_MUCH_AS_POSSIBLE, config.record_mode_); | 72 EXPECT_EQ(RECORD_AS_MUCH_AS_POSSIBLE, config.GetTraceRecordMode()); |
| 73 EXPECT_FALSE(config.enable_sampling_); | 73 EXPECT_FALSE(config.IsSamplingEnabled()); |
| 74 EXPECT_FALSE(config.enable_systrace_); | 74 EXPECT_FALSE(config.IsSystraceEnabled()); |
| 75 EXPECT_TRUE(config.enable_argument_filter_); | 75 EXPECT_TRUE(config.IsArgumentFilterEnabled()); |
| 76 EXPECT_STREQ("record-as-much-as-possible,enable-argument-filter", | 76 EXPECT_STREQ("record-as-much-as-possible,enable-argument-filter", |
| 77 config.ToTraceOptionsString().c_str()); | 77 config.ToTraceOptionsString().c_str()); |
| 78 | 78 |
| 79 config = TraceConfig( | 79 config = TraceConfig( |
| 80 "", | 80 "", |
| 81 "enable-systrace,trace-to-console,enable-sampling,enable-argument-filter"); | 81 "enable-systrace,trace-to-console,enable-sampling,enable-argument-filter"); |
| 82 EXPECT_EQ(ECHO_TO_CONSOLE, config.record_mode_); | 82 EXPECT_EQ(ECHO_TO_CONSOLE, config.GetTraceRecordMode()); |
| 83 EXPECT_TRUE(config.enable_sampling_); | 83 EXPECT_TRUE(config.IsSamplingEnabled()); |
| 84 EXPECT_TRUE(config.enable_systrace_); | 84 EXPECT_TRUE(config.IsSystraceEnabled()); |
| 85 EXPECT_TRUE(config.enable_argument_filter_); | 85 EXPECT_TRUE(config.IsArgumentFilterEnabled()); |
| 86 EXPECT_STREQ( | 86 EXPECT_STREQ( |
| 87 "trace-to-console,enable-sampling,enable-systrace,enable-argument-filter", | 87 "trace-to-console,enable-sampling,enable-systrace,enable-argument-filter", |
| 88 config.ToTraceOptionsString().c_str()); | 88 config.ToTraceOptionsString().c_str()); |
| 89 | 89 |
| 90 config = TraceConfig( | 90 config = TraceConfig( |
| 91 "", "record-continuously, record-until-full, trace-to-console"); | 91 "", "record-continuously, record-until-full, trace-to-console"); |
| 92 EXPECT_EQ(ECHO_TO_CONSOLE, config.record_mode_); | 92 EXPECT_EQ(ECHO_TO_CONSOLE, config.GetTraceRecordMode()); |
| 93 EXPECT_FALSE(config.enable_systrace_); | 93 EXPECT_FALSE(config.IsSamplingEnabled()); |
| 94 EXPECT_FALSE(config.enable_sampling_); | 94 EXPECT_FALSE(config.IsSystraceEnabled()); |
| 95 EXPECT_FALSE(config.enable_argument_filter_); | 95 EXPECT_FALSE(config.IsArgumentFilterEnabled()); |
| 96 EXPECT_STREQ("trace-to-console", config.ToTraceOptionsString().c_str()); | 96 EXPECT_STREQ("trace-to-console", config.ToTraceOptionsString().c_str()); |
| 97 | 97 |
| 98 // From TraceRecordMode |
| 99 config = TraceConfig("", RECORD_UNTIL_FULL); |
| 100 EXPECT_EQ(RECORD_UNTIL_FULL, config.GetTraceRecordMode()); |
| 101 EXPECT_FALSE(config.IsSamplingEnabled()); |
| 102 EXPECT_FALSE(config.IsSystraceEnabled()); |
| 103 EXPECT_FALSE(config.IsArgumentFilterEnabled()); |
| 104 EXPECT_STREQ("record-until-full", config.ToTraceOptionsString().c_str()); |
| 105 |
| 106 config = TraceConfig("", RECORD_CONTINUOUSLY); |
| 107 EXPECT_EQ(RECORD_CONTINUOUSLY, config.GetTraceRecordMode()); |
| 108 EXPECT_FALSE(config.IsSamplingEnabled()); |
| 109 EXPECT_FALSE(config.IsSystraceEnabled()); |
| 110 EXPECT_FALSE(config.IsArgumentFilterEnabled()); |
| 111 EXPECT_STREQ("record-continuously", config.ToTraceOptionsString().c_str()); |
| 112 |
| 113 config = TraceConfig("", ECHO_TO_CONSOLE); |
| 114 EXPECT_EQ(ECHO_TO_CONSOLE, config.GetTraceRecordMode()); |
| 115 EXPECT_FALSE(config.IsSamplingEnabled()); |
| 116 EXPECT_FALSE(config.IsSystraceEnabled()); |
| 117 EXPECT_FALSE(config.IsArgumentFilterEnabled()); |
| 118 EXPECT_STREQ("trace-to-console", config.ToTraceOptionsString().c_str()); |
| 119 |
| 120 config = TraceConfig("", RECORD_AS_MUCH_AS_POSSIBLE); |
| 121 EXPECT_EQ(RECORD_AS_MUCH_AS_POSSIBLE, config.GetTraceRecordMode()); |
| 122 EXPECT_FALSE(config.IsSamplingEnabled()); |
| 123 EXPECT_FALSE(config.IsSystraceEnabled()); |
| 124 EXPECT_FALSE(config.IsArgumentFilterEnabled()); |
| 125 EXPECT_STREQ("record-as-much-as-possible", |
| 126 config.ToTraceOptionsString().c_str()); |
| 127 |
| 98 // From category filter strings | 128 // From category filter strings |
| 99 config = TraceConfig("-*Debug,-*Test", ""); | 129 config = TraceConfig("-*Debug,-*Test", ""); |
| 100 EXPECT_STREQ("-*Debug,-*Test", config.ToCategoryFilterString().c_str()); | 130 EXPECT_STREQ("-*Debug,-*Test", config.ToCategoryFilterString().c_str()); |
| 101 | 131 |
| 102 config = TraceConfig("included,-excluded,inc_pattern*,-exc_pattern*", ""); | 132 config = TraceConfig("included,-excluded,inc_pattern*,-exc_pattern*", ""); |
| 103 EXPECT_STREQ("included,inc_pattern*,-excluded,-exc_pattern*", | 133 EXPECT_STREQ("included,inc_pattern*,-excluded,-exc_pattern*", |
| 104 config.ToCategoryFilterString().c_str()); | 134 config.ToCategoryFilterString().c_str()); |
| 105 | 135 |
| 106 config = TraceConfig("only_inc_cat", ""); | 136 config = TraceConfig("only_inc_cat", ""); |
| 107 EXPECT_STREQ("only_inc_cat", config.ToCategoryFilterString().c_str()); | 137 EXPECT_STREQ("only_inc_cat", config.ToCategoryFilterString().c_str()); |
| 108 | 138 |
| 109 config = TraceConfig("-only_exc_cat", ""); | 139 config = TraceConfig("-only_exc_cat", ""); |
| 110 EXPECT_STREQ("-only_exc_cat", config.ToCategoryFilterString().c_str()); | 140 EXPECT_STREQ("-only_exc_cat", config.ToCategoryFilterString().c_str()); |
| 111 | 141 |
| 112 config = TraceConfig("disabled-by-default-cc,-excluded", ""); | 142 config = TraceConfig("disabled-by-default-cc,-excluded", ""); |
| 113 EXPECT_STREQ("disabled-by-default-cc,-excluded", | 143 EXPECT_STREQ("disabled-by-default-cc,-excluded", |
| 114 config.ToCategoryFilterString().c_str()); | 144 config.ToCategoryFilterString().c_str()); |
| 115 | 145 |
| 116 config = TraceConfig("disabled-by-default-cc,included", ""); | 146 config = TraceConfig("disabled-by-default-cc,included", ""); |
| 117 EXPECT_STREQ("included,disabled-by-default-cc", | 147 EXPECT_STREQ("included,disabled-by-default-cc", |
| 118 config.ToCategoryFilterString().c_str()); | 148 config.ToCategoryFilterString().c_str()); |
| 119 | 149 |
| 120 config = TraceConfig("DELAY(test.Delay1;16),included", ""); | 150 config = TraceConfig("DELAY(test.Delay1;16),included", ""); |
| 121 EXPECT_STREQ("included,DELAY(test.Delay1;16)", | 151 EXPECT_STREQ("included,DELAY(test.Delay1;16)", |
| 122 config.ToCategoryFilterString().c_str()); | 152 config.ToCategoryFilterString().c_str()); |
| 123 | 153 |
| 124 // From both trace options and category filter strings | 154 // From both trace options and category filter strings |
| 125 config = TraceConfig("", ""); | 155 config = TraceConfig("", ""); |
| 126 EXPECT_EQ(RECORD_UNTIL_FULL, config.record_mode_); | 156 EXPECT_EQ(RECORD_UNTIL_FULL, config.GetTraceRecordMode()); |
| 127 EXPECT_FALSE(config.enable_systrace_); | 157 EXPECT_FALSE(config.IsSamplingEnabled()); |
| 128 EXPECT_FALSE(config.enable_sampling_); | 158 EXPECT_FALSE(config.IsSystraceEnabled()); |
| 129 EXPECT_FALSE(config.enable_argument_filter_); | 159 EXPECT_FALSE(config.IsArgumentFilterEnabled()); |
| 130 EXPECT_STREQ("", config.ToCategoryFilterString().c_str()); | 160 EXPECT_STREQ("", config.ToCategoryFilterString().c_str()); |
| 131 EXPECT_STREQ("record-until-full", config.ToTraceOptionsString().c_str()); | 161 EXPECT_STREQ("record-until-full", config.ToTraceOptionsString().c_str()); |
| 132 | 162 |
| 133 config = TraceConfig("included,-excluded,inc_pattern*,-exc_pattern*", | 163 config = TraceConfig("included,-excluded,inc_pattern*,-exc_pattern*", |
| 134 "enable-systrace, trace-to-console, enable-sampling"); | 164 "enable-systrace, trace-to-console, enable-sampling"); |
| 165 EXPECT_EQ(ECHO_TO_CONSOLE, config.GetTraceRecordMode()); |
| 166 EXPECT_TRUE(config.IsSamplingEnabled()); |
| 167 EXPECT_TRUE(config.IsSystraceEnabled()); |
| 168 EXPECT_FALSE(config.IsArgumentFilterEnabled()); |
| 135 EXPECT_STREQ("included,inc_pattern*,-excluded,-exc_pattern*", | 169 EXPECT_STREQ("included,inc_pattern*,-excluded,-exc_pattern*", |
| 136 config.ToCategoryFilterString().c_str()); | 170 config.ToCategoryFilterString().c_str()); |
| 137 EXPECT_STREQ("trace-to-console,enable-sampling,enable-systrace", | 171 EXPECT_STREQ("trace-to-console,enable-sampling,enable-systrace", |
| 138 config.ToTraceOptionsString().c_str()); | 172 config.ToTraceOptionsString().c_str()); |
| 139 | 173 |
| 140 // From both trace options and category filter strings with spaces. | 174 // From both trace options and category filter strings with spaces. |
| 141 config = TraceConfig(" included , -excluded, inc_pattern*, ,-exc_pattern* ", | 175 config = TraceConfig(" included , -excluded, inc_pattern*, ,-exc_pattern* ", |
| 142 "enable-systrace, ,trace-to-console, enable-sampling "); | 176 "enable-systrace, ,trace-to-console, enable-sampling "); |
| 177 EXPECT_EQ(ECHO_TO_CONSOLE, config.GetTraceRecordMode()); |
| 178 EXPECT_TRUE(config.IsSamplingEnabled()); |
| 179 EXPECT_TRUE(config.IsSystraceEnabled()); |
| 180 EXPECT_FALSE(config.IsArgumentFilterEnabled()); |
| 143 EXPECT_STREQ("included,inc_pattern*,-excluded,-exc_pattern*", | 181 EXPECT_STREQ("included,inc_pattern*,-excluded,-exc_pattern*", |
| 144 config.ToCategoryFilterString().c_str()); | 182 config.ToCategoryFilterString().c_str()); |
| 145 EXPECT_STREQ("trace-to-console,enable-sampling,enable-systrace", | 183 EXPECT_STREQ("trace-to-console,enable-sampling,enable-systrace", |
| 146 config.ToTraceOptionsString().c_str()); | 184 config.ToTraceOptionsString().c_str()); |
| 185 |
| 186 // From category filter string and TraceRecordMode |
| 187 config = TraceConfig("included,-excluded,inc_pattern*,-exc_pattern*", |
| 188 RECORD_CONTINUOUSLY); |
| 189 EXPECT_EQ(RECORD_CONTINUOUSLY, config.GetTraceRecordMode()); |
| 190 EXPECT_FALSE(config.IsSystraceEnabled()); |
| 191 EXPECT_FALSE(config.IsSamplingEnabled()); |
| 192 EXPECT_FALSE(config.IsArgumentFilterEnabled()); |
| 193 EXPECT_STREQ("included,inc_pattern*,-excluded,-exc_pattern*", |
| 194 config.ToCategoryFilterString().c_str()); |
| 195 EXPECT_STREQ("record-continuously", config.ToTraceOptionsString().c_str()); |
| 147 } | 196 } |
| 148 | 197 |
| 149 TEST(TraceConfigTest, TraceConfigFromInvalidLegacyStrings) { | 198 TEST(TraceConfigTest, TraceConfigFromInvalidLegacyStrings) { |
| 150 TraceConfig config("", "foo-bar-baz"); | 199 TraceConfig config("", "foo-bar-baz"); |
| 151 EXPECT_EQ(RECORD_UNTIL_FULL, config.record_mode_); | 200 EXPECT_EQ(RECORD_UNTIL_FULL, config.GetTraceRecordMode()); |
| 152 EXPECT_FALSE(config.enable_systrace_); | 201 EXPECT_FALSE(config.IsSamplingEnabled()); |
| 153 EXPECT_FALSE(config.enable_sampling_); | 202 EXPECT_FALSE(config.IsSystraceEnabled()); |
| 154 EXPECT_FALSE(config.enable_argument_filter_); | 203 EXPECT_FALSE(config.IsArgumentFilterEnabled()); |
| 155 EXPECT_STREQ("", config.ToCategoryFilterString().c_str()); | 204 EXPECT_STREQ("", config.ToCategoryFilterString().c_str()); |
| 156 EXPECT_STREQ("record-until-full", config.ToTraceOptionsString().c_str()); | 205 EXPECT_STREQ("record-until-full", config.ToTraceOptionsString().c_str()); |
| 157 | 206 |
| 158 config = TraceConfig("arbitrary-category", "foo-bar-baz, enable-systrace"); | 207 config = TraceConfig("arbitrary-category", "foo-bar-baz, enable-systrace"); |
| 159 EXPECT_EQ(RECORD_UNTIL_FULL, config.record_mode_); | 208 EXPECT_EQ(RECORD_UNTIL_FULL, config.GetTraceRecordMode()); |
| 160 EXPECT_TRUE(config.enable_systrace_); | 209 EXPECT_FALSE(config.IsSamplingEnabled()); |
| 161 EXPECT_FALSE(config.enable_sampling_); | 210 EXPECT_TRUE(config.IsSystraceEnabled()); |
| 162 EXPECT_FALSE(config.enable_argument_filter_); | 211 EXPECT_FALSE(config.IsArgumentFilterEnabled()); |
| 163 EXPECT_STREQ("arbitrary-category", config.ToCategoryFilterString().c_str()); | 212 EXPECT_STREQ("arbitrary-category", config.ToCategoryFilterString().c_str()); |
| 164 EXPECT_STREQ("record-until-full,enable-systrace", | 213 EXPECT_STREQ("record-until-full,enable-systrace", |
| 165 config.ToTraceOptionsString().c_str()); | 214 config.ToTraceOptionsString().c_str()); |
| 166 | 215 |
| 167 const char* const configs[] = { | 216 const char* const configs[] = { |
| 168 "", | 217 "", |
| 169 "DELAY(", | 218 "DELAY(", |
| 170 "DELAY(;", | 219 "DELAY(;", |
| 171 "DELAY(;)", | 220 "DELAY(;)", |
| 172 "DELAY(test.Delay)", | 221 "DELAY(test.Delay)", |
| 173 "DELAY(test.Delay;)" | 222 "DELAY(test.Delay;)" |
| 174 }; | 223 }; |
| 175 for (size_t i = 0; i < arraysize(configs); i++) { | 224 for (size_t i = 0; i < arraysize(configs); i++) { |
| 176 TraceConfig tc(configs[i], ""); | 225 TraceConfig tc(configs[i], ""); |
| 177 EXPECT_EQ(0u, tc.GetSyntheticDelayValues().size()); | 226 EXPECT_EQ(0u, tc.GetSyntheticDelayValues().size()); |
| 178 } | 227 } |
| 179 } | 228 } |
| 180 | 229 |
| 181 TEST(TraceConfigTest, ConstructDefaultTraceConfig) { | 230 TEST(TraceConfigTest, ConstructDefaultTraceConfig) { |
| 182 // Make sure that upon an empty string, we fall back to the default config. | 231 // Make sure that upon an empty string, we fall back to the default config. |
| 183 TraceConfig tc; | 232 TraceConfig tc; |
| 184 EXPECT_STREQ(kDefaultTraceConfigString, tc.ToString().c_str()); | 233 EXPECT_STREQ(kDefaultTraceConfigString, tc.ToString().c_str()); |
| 185 EXPECT_TRUE(tc.record_mode_ == RECORD_UNTIL_FULL); | 234 EXPECT_EQ(RECORD_UNTIL_FULL, tc.GetTraceRecordMode()); |
| 186 EXPECT_FALSE(tc.enable_sampling_); | 235 EXPECT_FALSE(tc.IsSamplingEnabled()); |
| 187 EXPECT_FALSE(tc.enable_systrace_); | 236 EXPECT_FALSE(tc.IsSystraceEnabled()); |
| 188 EXPECT_FALSE(tc.enable_argument_filter_); | 237 EXPECT_FALSE(tc.IsArgumentFilterEnabled()); |
| 189 EXPECT_STREQ("-*Debug,-*Test", tc.ToCategoryFilterString().c_str()); | 238 EXPECT_STREQ("-*Debug,-*Test", tc.ToCategoryFilterString().c_str()); |
| 190 | 239 |
| 191 EXPECT_FALSE(tc.IsCategoryEnabled("Category1")); | 240 EXPECT_FALSE(tc.IsCategoryEnabled("Category1")); |
| 192 EXPECT_FALSE(tc.IsCategoryEnabled("not-excluded-category")); | 241 EXPECT_FALSE(tc.IsCategoryEnabled("not-excluded-category")); |
| 193 EXPECT_FALSE(tc.IsCategoryEnabled("CategoryTest")); | 242 EXPECT_FALSE(tc.IsCategoryEnabled("CategoryTest")); |
| 194 EXPECT_FALSE(tc.IsCategoryEnabled("CategoryDebug")); | 243 EXPECT_FALSE(tc.IsCategoryEnabled("CategoryDebug")); |
| 195 EXPECT_FALSE(tc.IsCategoryEnabled("disabled-by-default-cc")); | 244 EXPECT_FALSE(tc.IsCategoryEnabled("disabled-by-default-cc")); |
| 196 | 245 |
| 197 EXPECT_TRUE(tc.IsCategoryGroupEnabled("Category1")); | 246 EXPECT_TRUE(tc.IsCategoryGroupEnabled("Category1")); |
| 198 EXPECT_TRUE(tc.IsCategoryGroupEnabled("not-excluded-category")); | 247 EXPECT_TRUE(tc.IsCategoryGroupEnabled("not-excluded-category")); |
| (...skipping 17 matching lines...) Expand all Loading... |
| 216 "\"excluded_categories\":[\"excluded\",\"exc_pattern*\"]," | 265 "\"excluded_categories\":[\"excluded\",\"exc_pattern*\"]," |
| 217 "\"included_categories\":[\"included\"," | 266 "\"included_categories\":[\"included\"," |
| 218 "\"inc_pattern*\"," | 267 "\"inc_pattern*\"," |
| 219 "\"disabled-by-default-cc\"]," | 268 "\"disabled-by-default-cc\"]," |
| 220 "\"record_mode\":\"record-continuously\"," | 269 "\"record_mode\":\"record-continuously\"," |
| 221 "\"synthetic_delays\":[\"test.Delay1;16\",\"test.Delay2;32\"]" | 270 "\"synthetic_delays\":[\"test.Delay1;16\",\"test.Delay2;32\"]" |
| 222 "}"; | 271 "}"; |
| 223 TraceConfig tc(config_string); | 272 TraceConfig tc(config_string); |
| 224 | 273 |
| 225 EXPECT_STREQ(config_string, tc.ToString().c_str()); | 274 EXPECT_STREQ(config_string, tc.ToString().c_str()); |
| 226 EXPECT_TRUE(tc.record_mode_ == RECORD_CONTINUOUSLY); | 275 EXPECT_EQ(RECORD_CONTINUOUSLY, tc.GetTraceRecordMode()); |
| 227 EXPECT_TRUE(tc.enable_sampling_); | 276 EXPECT_TRUE(tc.IsSamplingEnabled()); |
| 228 EXPECT_TRUE(tc.enable_systrace_); | 277 EXPECT_TRUE(tc.IsSystraceEnabled()); |
| 229 EXPECT_TRUE(tc.enable_argument_filter_); | 278 EXPECT_TRUE(tc.IsArgumentFilterEnabled()); |
| 230 EXPECT_STREQ("included,inc_pattern*,disabled-by-default-cc,-excluded," | 279 EXPECT_STREQ("included,inc_pattern*,disabled-by-default-cc,-excluded," |
| 231 "-exc_pattern*,DELAY(test.Delay1;16),DELAY(test.Delay2;32)", | 280 "-exc_pattern*,DELAY(test.Delay1;16),DELAY(test.Delay2;32)", |
| 232 tc.ToCategoryFilterString().c_str()); | 281 tc.ToCategoryFilterString().c_str()); |
| 233 | 282 |
| 234 EXPECT_TRUE(tc.IsCategoryEnabled("included")); | 283 EXPECT_TRUE(tc.IsCategoryEnabled("included")); |
| 235 EXPECT_TRUE(tc.IsCategoryEnabled("inc_pattern_category")); | 284 EXPECT_TRUE(tc.IsCategoryEnabled("inc_pattern_category")); |
| 236 EXPECT_TRUE(tc.IsCategoryEnabled("disabled-by-default-cc")); | 285 EXPECT_TRUE(tc.IsCategoryEnabled("disabled-by-default-cc")); |
| 237 EXPECT_FALSE(tc.IsCategoryEnabled("excluded")); | 286 EXPECT_FALSE(tc.IsCategoryEnabled("excluded")); |
| 238 EXPECT_FALSE(tc.IsCategoryEnabled("exc_pattern_category")); | 287 EXPECT_FALSE(tc.IsCategoryEnabled("exc_pattern_category")); |
| 239 EXPECT_FALSE(tc.IsCategoryEnabled("disabled-by-default-others")); | 288 EXPECT_FALSE(tc.IsCategoryEnabled("disabled-by-default-others")); |
| (...skipping 32 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 272 "\"enable_systrace\":false," | 321 "\"enable_systrace\":false," |
| 273 "\"record_mode\":\"record-until-full\"" | 322 "\"record_mode\":\"record-until-full\"" |
| 274 "}"); | 323 "}"); |
| 275 } | 324 } |
| 276 | 325 |
| 277 TEST(TraceConfigTest, TraceConfigFromInvalidString) { | 326 TEST(TraceConfigTest, TraceConfigFromInvalidString) { |
| 278 // The config string needs to be a dictionary correctly formatted as a JSON | 327 // The config string needs to be a dictionary correctly formatted as a JSON |
| 279 // string. Otherwise, it will fall back to the default initialization. | 328 // string. Otherwise, it will fall back to the default initialization. |
| 280 TraceConfig tc(""); | 329 TraceConfig tc(""); |
| 281 EXPECT_STREQ(kDefaultTraceConfigString, tc.ToString().c_str()); | 330 EXPECT_STREQ(kDefaultTraceConfigString, tc.ToString().c_str()); |
| 282 EXPECT_TRUE(tc.record_mode_ == RECORD_UNTIL_FULL); | 331 EXPECT_EQ(RECORD_UNTIL_FULL, tc.GetTraceRecordMode()); |
| 283 EXPECT_FALSE(tc.enable_sampling_); | 332 EXPECT_FALSE(tc.IsSamplingEnabled()); |
| 284 EXPECT_FALSE(tc.enable_systrace_); | 333 EXPECT_FALSE(tc.IsSystraceEnabled()); |
| 285 EXPECT_FALSE(tc.enable_argument_filter_); | 334 EXPECT_FALSE(tc.IsArgumentFilterEnabled()); |
| 286 EXPECT_STREQ("-*Debug,-*Test", tc.ToCategoryFilterString().c_str()); | 335 EXPECT_STREQ("-*Debug,-*Test", tc.ToCategoryFilterString().c_str()); |
| 287 | 336 |
| 288 tc = TraceConfig("This is an invalid config string."); | 337 tc = TraceConfig("This is an invalid config string."); |
| 289 EXPECT_STREQ(kDefaultTraceConfigString, tc.ToString().c_str()); | 338 EXPECT_STREQ(kDefaultTraceConfigString, tc.ToString().c_str()); |
| 290 EXPECT_TRUE(tc.record_mode_ == RECORD_UNTIL_FULL); | 339 EXPECT_EQ(RECORD_UNTIL_FULL, tc.GetTraceRecordMode()); |
| 291 EXPECT_FALSE(tc.enable_sampling_); | 340 EXPECT_FALSE(tc.IsSamplingEnabled()); |
| 292 EXPECT_FALSE(tc.enable_systrace_); | 341 EXPECT_FALSE(tc.IsSystraceEnabled()); |
| 293 EXPECT_FALSE(tc.enable_argument_filter_); | 342 EXPECT_FALSE(tc.IsArgumentFilterEnabled()); |
| 294 EXPECT_STREQ("-*Debug,-*Test", tc.ToCategoryFilterString().c_str()); | 343 EXPECT_STREQ("-*Debug,-*Test", tc.ToCategoryFilterString().c_str()); |
| 295 | 344 |
| 296 tc = TraceConfig("[\"This\", \"is\", \"not\", \"a\", \"dictionary\"]"); | 345 tc = TraceConfig("[\"This\", \"is\", \"not\", \"a\", \"dictionary\"]"); |
| 297 EXPECT_STREQ(kDefaultTraceConfigString, tc.ToString().c_str()); | 346 EXPECT_STREQ(kDefaultTraceConfigString, tc.ToString().c_str()); |
| 298 EXPECT_TRUE(tc.record_mode_ == RECORD_UNTIL_FULL); | 347 EXPECT_EQ(RECORD_UNTIL_FULL, tc.GetTraceRecordMode()); |
| 299 EXPECT_FALSE(tc.enable_sampling_); | 348 EXPECT_FALSE(tc.IsSamplingEnabled()); |
| 300 EXPECT_FALSE(tc.enable_systrace_); | 349 EXPECT_FALSE(tc.IsSystraceEnabled()); |
| 301 EXPECT_FALSE(tc.enable_argument_filter_); | 350 EXPECT_FALSE(tc.IsArgumentFilterEnabled()); |
| 302 EXPECT_STREQ("-*Debug,-*Test", tc.ToCategoryFilterString().c_str()); | 351 EXPECT_STREQ("-*Debug,-*Test", tc.ToCategoryFilterString().c_str()); |
| 303 | 352 |
| 304 tc = TraceConfig("{\"record_mode\": invalid-value-needs-double-quote}"); | 353 tc = TraceConfig("{\"record_mode\": invalid-value-needs-double-quote}"); |
| 305 EXPECT_STREQ(kDefaultTraceConfigString, tc.ToString().c_str()); | 354 EXPECT_STREQ(kDefaultTraceConfigString, tc.ToString().c_str()); |
| 306 EXPECT_TRUE(tc.record_mode_ == RECORD_UNTIL_FULL); | 355 EXPECT_EQ(RECORD_UNTIL_FULL, tc.GetTraceRecordMode()); |
| 307 EXPECT_FALSE(tc.enable_sampling_); | 356 EXPECT_FALSE(tc.IsSamplingEnabled()); |
| 308 EXPECT_FALSE(tc.enable_systrace_); | 357 EXPECT_FALSE(tc.IsSystraceEnabled()); |
| 309 EXPECT_FALSE(tc.enable_argument_filter_); | 358 EXPECT_FALSE(tc.IsArgumentFilterEnabled()); |
| 310 EXPECT_STREQ("-*Debug,-*Test", tc.ToCategoryFilterString().c_str()); | 359 EXPECT_STREQ("-*Debug,-*Test", tc.ToCategoryFilterString().c_str()); |
| 311 | 360 |
| 312 // If the config string a dictionary formatted as a JSON string, it will | 361 // If the config string a dictionary formatted as a JSON string, it will |
| 313 // initialize TraceConfig with best effort. | 362 // initialize TraceConfig with best effort. |
| 314 tc = TraceConfig("{}"); | 363 tc = TraceConfig("{}"); |
| 315 EXPECT_TRUE(tc.record_mode_ == RECORD_UNTIL_FULL); | 364 EXPECT_EQ(RECORD_UNTIL_FULL, tc.GetTraceRecordMode()); |
| 316 EXPECT_FALSE(tc.enable_sampling_); | 365 EXPECT_FALSE(tc.IsSamplingEnabled()); |
| 317 EXPECT_FALSE(tc.enable_systrace_); | 366 EXPECT_FALSE(tc.IsSystraceEnabled()); |
| 318 EXPECT_FALSE(tc.enable_argument_filter_); | 367 EXPECT_FALSE(tc.IsArgumentFilterEnabled()); |
| 319 EXPECT_STREQ("", tc.ToCategoryFilterString().c_str()); | 368 EXPECT_STREQ("", tc.ToCategoryFilterString().c_str()); |
| 320 | 369 |
| 321 tc = TraceConfig("{\"arbitrary-key\":\"arbitrary-value\"}"); | 370 tc = TraceConfig("{\"arbitrary-key\":\"arbitrary-value\"}"); |
| 322 EXPECT_TRUE(tc.record_mode_ == RECORD_UNTIL_FULL); | 371 EXPECT_EQ(RECORD_UNTIL_FULL, tc.GetTraceRecordMode()); |
| 323 EXPECT_FALSE(tc.enable_sampling_); | 372 EXPECT_FALSE(tc.IsSamplingEnabled()); |
| 324 EXPECT_FALSE(tc.enable_systrace_); | 373 EXPECT_FALSE(tc.IsSystraceEnabled()); |
| 325 EXPECT_FALSE(tc.enable_argument_filter_); | 374 EXPECT_FALSE(tc.IsArgumentFilterEnabled()); |
| 326 EXPECT_STREQ("", tc.ToCategoryFilterString().c_str()); | 375 EXPECT_STREQ("", tc.ToCategoryFilterString().c_str()); |
| 327 | 376 |
| 328 const char invalid_config_string[] = | 377 const char invalid_config_string[] = |
| 329 "{" | 378 "{" |
| 330 "\"enable_sampling\":\"true\"," | 379 "\"enable_sampling\":\"true\"," |
| 331 "\"enable_systrace\":1," | 380 "\"enable_systrace\":1," |
| 332 "\"excluded_categories\":[\"excluded\"]," | 381 "\"excluded_categories\":[\"excluded\"]," |
| 333 "\"included_categories\":\"not a list\"," | 382 "\"included_categories\":\"not a list\"," |
| 334 "\"record_mode\":\"arbitrary-mode\"," | 383 "\"record_mode\":\"arbitrary-mode\"," |
| 335 "\"synthetic_delays\":[\"test.Delay1;16\"," | 384 "\"synthetic_delays\":[\"test.Delay1;16\"," |
| 336 "\"invalid-delay\"," | 385 "\"invalid-delay\"," |
| 337 "\"test.Delay2;32\"]" | 386 "\"test.Delay2;32\"]" |
| 338 "}"; | 387 "}"; |
| 339 tc = TraceConfig(invalid_config_string); | 388 tc = TraceConfig(invalid_config_string); |
| 340 EXPECT_TRUE(tc.record_mode_ == RECORD_UNTIL_FULL); | 389 EXPECT_EQ(RECORD_UNTIL_FULL, tc.GetTraceRecordMode()); |
| 341 EXPECT_FALSE(tc.enable_sampling_); | 390 EXPECT_FALSE(tc.IsSamplingEnabled()); |
| 342 EXPECT_FALSE(tc.enable_systrace_); | 391 EXPECT_FALSE(tc.IsSystraceEnabled()); |
| 343 EXPECT_FALSE(tc.enable_argument_filter_); | 392 EXPECT_FALSE(tc.IsArgumentFilterEnabled()); |
| 344 EXPECT_STREQ("-excluded,DELAY(test.Delay1;16),DELAY(test.Delay2;32)", | 393 EXPECT_STREQ("-excluded,DELAY(test.Delay1;16),DELAY(test.Delay2;32)", |
| 345 tc.ToCategoryFilterString().c_str()); | 394 tc.ToCategoryFilterString().c_str()); |
| 346 | 395 |
| 347 const char invalid_config_string_2[] = | 396 const char invalid_config_string_2[] = |
| 348 "{" | 397 "{" |
| 349 "\"included_categories\":[\"category\",\"disabled-by-default-pattern\"]," | 398 "\"included_categories\":[\"category\",\"disabled-by-default-pattern\"]," |
| 350 "\"excluded_categories\":[\"category\",\"disabled-by-default-pattern\"]" | 399 "\"excluded_categories\":[\"category\",\"disabled-by-default-pattern\"]" |
| 351 "}"; | 400 "}"; |
| 352 tc = TraceConfig(invalid_config_string_2); | 401 tc = TraceConfig(invalid_config_string_2); |
| 353 EXPECT_TRUE(tc.IsCategoryEnabled("category")); | 402 EXPECT_TRUE(tc.IsCategoryEnabled("category")); |
| (...skipping 62 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 416 EXPECT_TRUE(TraceConfig::IsEmptyOrContainsLeadingOrTrailingWhitespace( | 465 EXPECT_TRUE(TraceConfig::IsEmptyOrContainsLeadingOrTrailingWhitespace( |
| 417 "bad_category ")); | 466 "bad_category ")); |
| 418 EXPECT_TRUE(TraceConfig::IsEmptyOrContainsLeadingOrTrailingWhitespace( | 467 EXPECT_TRUE(TraceConfig::IsEmptyOrContainsLeadingOrTrailingWhitespace( |
| 419 " bad_category ")); | 468 " bad_category ")); |
| 420 EXPECT_TRUE(TraceConfig::IsEmptyOrContainsLeadingOrTrailingWhitespace( | 469 EXPECT_TRUE(TraceConfig::IsEmptyOrContainsLeadingOrTrailingWhitespace( |
| 421 "")); | 470 "")); |
| 422 EXPECT_FALSE(TraceConfig::IsEmptyOrContainsLeadingOrTrailingWhitespace( | 471 EXPECT_FALSE(TraceConfig::IsEmptyOrContainsLeadingOrTrailingWhitespace( |
| 423 "good_category")); | 472 "good_category")); |
| 424 } | 473 } |
| 425 | 474 |
| 475 TEST(TraceConfigTest, SetTraceOptionValues) { |
| 476 TraceConfig tc; |
| 477 EXPECT_FALSE(tc.IsSamplingEnabled()); |
| 478 EXPECT_FALSE(tc.IsSystraceEnabled()); |
| 479 |
| 480 tc.EnableSampling(); |
| 481 EXPECT_TRUE(tc.IsSamplingEnabled()); |
| 482 |
| 483 tc.EnableSystrace(); |
| 484 EXPECT_TRUE(tc.IsSystraceEnabled()); |
| 485 } |
| 486 |
| 426 } // namespace trace_event | 487 } // namespace trace_event |
| 427 } // namespace base | 488 } // namespace base |
| OLD | NEW |