OLD | NEW |
(Empty) | |
| 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 |
| 3 // found in the LICENSE file. |
| 4 |
| 5 #include "base/trace_event/trace_config.h" |
| 6 #include "testing/gtest/include/gtest/gtest.h" |
| 7 |
| 8 namespace base { |
| 9 namespace trace_event { |
| 10 |
| 11 namespace { |
| 12 |
| 13 const char kDefaultTraceConfigString[] = |
| 14 "{" |
| 15 "\"enable_argument_filter\":false," |
| 16 "\"enable_sampling\":false," |
| 17 "\"enable_systrace\":false," |
| 18 "\"excluded_categories\":[\"*Debug\",\"*Test\"]," |
| 19 "\"record_mode\":\"record-until-full\"" |
| 20 "}"; |
| 21 |
| 22 } // namespace |
| 23 |
| 24 TEST(TraceConfigTest, TraceConfigFromValidLegacyFormat) { |
| 25 // From trace options strings |
| 26 TraceConfig config("", "record-until-full"); |
| 27 EXPECT_EQ(RECORD_UNTIL_FULL, config.GetTraceRecordMode()); |
| 28 EXPECT_FALSE(config.IsSamplingEnabled()); |
| 29 EXPECT_FALSE(config.IsSystraceEnabled()); |
| 30 EXPECT_FALSE(config.IsArgumentFilterEnabled()); |
| 31 EXPECT_STREQ("record-until-full", config.ToTraceOptionsString().c_str()); |
| 32 |
| 33 config = TraceConfig("", "record-continuously"); |
| 34 EXPECT_EQ(RECORD_CONTINUOUSLY, config.GetTraceRecordMode()); |
| 35 EXPECT_FALSE(config.IsSamplingEnabled()); |
| 36 EXPECT_FALSE(config.IsSystraceEnabled()); |
| 37 EXPECT_FALSE(config.IsArgumentFilterEnabled()); |
| 38 EXPECT_STREQ("record-continuously", config.ToTraceOptionsString().c_str()); |
| 39 |
| 40 config = TraceConfig("", "trace-to-console"); |
| 41 EXPECT_EQ(ECHO_TO_CONSOLE, config.GetTraceRecordMode()); |
| 42 EXPECT_FALSE(config.IsSamplingEnabled()); |
| 43 EXPECT_FALSE(config.IsSystraceEnabled()); |
| 44 EXPECT_FALSE(config.IsArgumentFilterEnabled()); |
| 45 EXPECT_STREQ("trace-to-console", config.ToTraceOptionsString().c_str()); |
| 46 |
| 47 config = TraceConfig("", "record-as-much-as-possible"); |
| 48 EXPECT_EQ(RECORD_AS_MUCH_AS_POSSIBLE, config.GetTraceRecordMode()); |
| 49 EXPECT_FALSE(config.IsSamplingEnabled()); |
| 50 EXPECT_FALSE(config.IsSystraceEnabled()); |
| 51 EXPECT_FALSE(config.IsArgumentFilterEnabled()); |
| 52 EXPECT_STREQ("record-as-much-as-possible", |
| 53 config.ToTraceOptionsString().c_str()); |
| 54 |
| 55 config = TraceConfig("", "record-until-full, enable-sampling"); |
| 56 EXPECT_EQ(RECORD_UNTIL_FULL, config.GetTraceRecordMode()); |
| 57 EXPECT_TRUE(config.IsSamplingEnabled()); |
| 58 EXPECT_FALSE(config.IsSystraceEnabled()); |
| 59 EXPECT_FALSE(config.IsArgumentFilterEnabled()); |
| 60 EXPECT_STREQ("record-until-full,enable-sampling", |
| 61 config.ToTraceOptionsString().c_str()); |
| 62 |
| 63 config = TraceConfig("", "enable-systrace, record-continuously"); |
| 64 EXPECT_EQ(RECORD_CONTINUOUSLY, config.GetTraceRecordMode()); |
| 65 EXPECT_FALSE(config.IsSamplingEnabled()); |
| 66 EXPECT_TRUE(config.IsSystraceEnabled()); |
| 67 EXPECT_FALSE(config.IsArgumentFilterEnabled()); |
| 68 EXPECT_STREQ("record-continuously,enable-systrace", |
| 69 config.ToTraceOptionsString().c_str()); |
| 70 |
| 71 config = TraceConfig("", "enable-argument-filter,record-as-much-as-possible"); |
| 72 EXPECT_EQ(RECORD_AS_MUCH_AS_POSSIBLE, config.GetTraceRecordMode()); |
| 73 EXPECT_FALSE(config.IsSamplingEnabled()); |
| 74 EXPECT_FALSE(config.IsSystraceEnabled()); |
| 75 EXPECT_TRUE(config.IsArgumentFilterEnabled()); |
| 76 EXPECT_STREQ("record-as-much-as-possible,enable-argument-filter", |
| 77 config.ToTraceOptionsString().c_str()); |
| 78 |
| 79 config = TraceConfig( |
| 80 "", |
| 81 "enable-systrace,trace-to-console,enable-sampling,enable-argument-filter"); |
| 82 EXPECT_EQ(ECHO_TO_CONSOLE, config.GetTraceRecordMode()); |
| 83 EXPECT_TRUE(config.IsSamplingEnabled()); |
| 84 EXPECT_TRUE(config.IsSystraceEnabled()); |
| 85 EXPECT_TRUE(config.IsArgumentFilterEnabled()); |
| 86 EXPECT_STREQ( |
| 87 "trace-to-console,enable-sampling,enable-systrace,enable-argument-filter", |
| 88 config.ToTraceOptionsString().c_str()); |
| 89 |
| 90 config = TraceConfig( |
| 91 "", "record-continuously, record-until-full, trace-to-console"); |
| 92 EXPECT_EQ(ECHO_TO_CONSOLE, config.GetTraceRecordMode()); |
| 93 EXPECT_FALSE(config.IsSamplingEnabled()); |
| 94 EXPECT_FALSE(config.IsSystraceEnabled()); |
| 95 EXPECT_FALSE(config.IsArgumentFilterEnabled()); |
| 96 EXPECT_STREQ("trace-to-console", config.ToTraceOptionsString().c_str()); |
| 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 |
| 128 // From category filter strings |
| 129 config = TraceConfig("-*Debug,-*Test", ""); |
| 130 EXPECT_STREQ("-*Debug,-*Test", config.ToCategoryFilterString().c_str()); |
| 131 |
| 132 config = TraceConfig("included,-excluded,inc_pattern*,-exc_pattern*", ""); |
| 133 EXPECT_STREQ("included,inc_pattern*,-excluded,-exc_pattern*", |
| 134 config.ToCategoryFilterString().c_str()); |
| 135 |
| 136 config = TraceConfig("only_inc_cat", ""); |
| 137 EXPECT_STREQ("only_inc_cat", config.ToCategoryFilterString().c_str()); |
| 138 |
| 139 config = TraceConfig("-only_exc_cat", ""); |
| 140 EXPECT_STREQ("-only_exc_cat", config.ToCategoryFilterString().c_str()); |
| 141 |
| 142 config = TraceConfig("disabled-by-default-cc,-excluded", ""); |
| 143 EXPECT_STREQ("disabled-by-default-cc,-excluded", |
| 144 config.ToCategoryFilterString().c_str()); |
| 145 |
| 146 config = TraceConfig("disabled-by-default-cc,included", ""); |
| 147 EXPECT_STREQ("included,disabled-by-default-cc", |
| 148 config.ToCategoryFilterString().c_str()); |
| 149 |
| 150 config = TraceConfig("DELAY(test.Delay1;16),included", ""); |
| 151 EXPECT_STREQ("included,DELAY(test.Delay1;16)", |
| 152 config.ToCategoryFilterString().c_str()); |
| 153 |
| 154 // From both trace options and category filter strings |
| 155 config = TraceConfig("", ""); |
| 156 EXPECT_EQ(RECORD_UNTIL_FULL, config.GetTraceRecordMode()); |
| 157 EXPECT_FALSE(config.IsSamplingEnabled()); |
| 158 EXPECT_FALSE(config.IsSystraceEnabled()); |
| 159 EXPECT_FALSE(config.IsArgumentFilterEnabled()); |
| 160 EXPECT_STREQ("", config.ToCategoryFilterString().c_str()); |
| 161 EXPECT_STREQ("record-until-full", config.ToTraceOptionsString().c_str()); |
| 162 |
| 163 config = TraceConfig("included,-excluded,inc_pattern*,-exc_pattern*", |
| 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()); |
| 169 EXPECT_STREQ("included,inc_pattern*,-excluded,-exc_pattern*", |
| 170 config.ToCategoryFilterString().c_str()); |
| 171 EXPECT_STREQ("trace-to-console,enable-sampling,enable-systrace", |
| 172 config.ToTraceOptionsString().c_str()); |
| 173 |
| 174 // From both trace options and category filter strings with spaces. |
| 175 config = TraceConfig(" included , -excluded, inc_pattern*, ,-exc_pattern* ", |
| 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()); |
| 181 EXPECT_STREQ("included,inc_pattern*,-excluded,-exc_pattern*", |
| 182 config.ToCategoryFilterString().c_str()); |
| 183 EXPECT_STREQ("trace-to-console,enable-sampling,enable-systrace", |
| 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()); |
| 196 } |
| 197 |
| 198 TEST(TraceConfigTest, TraceConfigFromInvalidLegacyStrings) { |
| 199 TraceConfig config("", "foo-bar-baz"); |
| 200 EXPECT_EQ(RECORD_UNTIL_FULL, config.GetTraceRecordMode()); |
| 201 EXPECT_FALSE(config.IsSamplingEnabled()); |
| 202 EXPECT_FALSE(config.IsSystraceEnabled()); |
| 203 EXPECT_FALSE(config.IsArgumentFilterEnabled()); |
| 204 EXPECT_STREQ("", config.ToCategoryFilterString().c_str()); |
| 205 EXPECT_STREQ("record-until-full", config.ToTraceOptionsString().c_str()); |
| 206 |
| 207 config = TraceConfig("arbitrary-category", "foo-bar-baz, enable-systrace"); |
| 208 EXPECT_EQ(RECORD_UNTIL_FULL, config.GetTraceRecordMode()); |
| 209 EXPECT_FALSE(config.IsSamplingEnabled()); |
| 210 EXPECT_TRUE(config.IsSystraceEnabled()); |
| 211 EXPECT_FALSE(config.IsArgumentFilterEnabled()); |
| 212 EXPECT_STREQ("arbitrary-category", config.ToCategoryFilterString().c_str()); |
| 213 EXPECT_STREQ("record-until-full,enable-systrace", |
| 214 config.ToTraceOptionsString().c_str()); |
| 215 |
| 216 const char* const configs[] = { |
| 217 "", |
| 218 "DELAY(", |
| 219 "DELAY(;", |
| 220 "DELAY(;)", |
| 221 "DELAY(test.Delay)", |
| 222 "DELAY(test.Delay;)" |
| 223 }; |
| 224 for (size_t i = 0; i < arraysize(configs); i++) { |
| 225 TraceConfig tc(configs[i], ""); |
| 226 EXPECT_EQ(0u, tc.GetSyntheticDelayValues().size()); |
| 227 } |
| 228 } |
| 229 |
| 230 TEST(TraceConfigTest, ConstructDefaultTraceConfig) { |
| 231 // Make sure that upon an empty string, we fall back to the default config. |
| 232 TraceConfig tc; |
| 233 EXPECT_STREQ(kDefaultTraceConfigString, tc.ToString().c_str()); |
| 234 EXPECT_EQ(RECORD_UNTIL_FULL, tc.GetTraceRecordMode()); |
| 235 EXPECT_FALSE(tc.IsSamplingEnabled()); |
| 236 EXPECT_FALSE(tc.IsSystraceEnabled()); |
| 237 EXPECT_FALSE(tc.IsArgumentFilterEnabled()); |
| 238 EXPECT_STREQ("-*Debug,-*Test", tc.ToCategoryFilterString().c_str()); |
| 239 |
| 240 EXPECT_FALSE(tc.IsCategoryEnabled("Category1")); |
| 241 EXPECT_FALSE(tc.IsCategoryEnabled("not-excluded-category")); |
| 242 EXPECT_FALSE(tc.IsCategoryEnabled("CategoryTest")); |
| 243 EXPECT_FALSE(tc.IsCategoryEnabled("CategoryDebug")); |
| 244 EXPECT_FALSE(tc.IsCategoryEnabled("disabled-by-default-cc")); |
| 245 |
| 246 EXPECT_TRUE(tc.IsCategoryGroupEnabled("Category1")); |
| 247 EXPECT_TRUE(tc.IsCategoryGroupEnabled("not-excluded-category")); |
| 248 EXPECT_FALSE(tc.IsCategoryGroupEnabled("CategoryTest")); |
| 249 EXPECT_FALSE(tc.IsCategoryGroupEnabled("CategoryDebug")); |
| 250 EXPECT_FALSE(tc.IsCategoryGroupEnabled("disabled-by-default-cc")); |
| 251 |
| 252 EXPECT_TRUE(tc.IsCategoryGroupEnabled("Category1,CategoryDebug")); |
| 253 EXPECT_TRUE(tc.IsCategoryGroupEnabled("CategoryDebug,Category1")); |
| 254 EXPECT_TRUE(tc.IsCategoryGroupEnabled("CategoryTest,not-excluded-category")); |
| 255 EXPECT_FALSE(tc.IsCategoryGroupEnabled("CategoryDebug,CategoryTest")); |
| 256 } |
| 257 |
| 258 TEST(TraceConfigTest, TraceConfigFromValidString) { |
| 259 // Using some non-empty config string. |
| 260 const char config_string[] = |
| 261 "{" |
| 262 "\"enable_argument_filter\":true," |
| 263 "\"enable_sampling\":true," |
| 264 "\"enable_systrace\":true," |
| 265 "\"excluded_categories\":[\"excluded\",\"exc_pattern*\"]," |
| 266 "\"included_categories\":[\"included\"," |
| 267 "\"inc_pattern*\"," |
| 268 "\"disabled-by-default-cc\"]," |
| 269 "\"record_mode\":\"record-continuously\"," |
| 270 "\"synthetic_delays\":[\"test.Delay1;16\",\"test.Delay2;32\"]" |
| 271 "}"; |
| 272 TraceConfig tc(config_string); |
| 273 |
| 274 EXPECT_STREQ(config_string, tc.ToString().c_str()); |
| 275 EXPECT_EQ(RECORD_CONTINUOUSLY, tc.GetTraceRecordMode()); |
| 276 EXPECT_TRUE(tc.IsSamplingEnabled()); |
| 277 EXPECT_TRUE(tc.IsSystraceEnabled()); |
| 278 EXPECT_TRUE(tc.IsArgumentFilterEnabled()); |
| 279 EXPECT_STREQ("included,inc_pattern*,disabled-by-default-cc,-excluded," |
| 280 "-exc_pattern*,DELAY(test.Delay1;16),DELAY(test.Delay2;32)", |
| 281 tc.ToCategoryFilterString().c_str()); |
| 282 |
| 283 EXPECT_TRUE(tc.IsCategoryEnabled("included")); |
| 284 EXPECT_TRUE(tc.IsCategoryEnabled("inc_pattern_category")); |
| 285 EXPECT_TRUE(tc.IsCategoryEnabled("disabled-by-default-cc")); |
| 286 EXPECT_FALSE(tc.IsCategoryEnabled("excluded")); |
| 287 EXPECT_FALSE(tc.IsCategoryEnabled("exc_pattern_category")); |
| 288 EXPECT_FALSE(tc.IsCategoryEnabled("disabled-by-default-others")); |
| 289 EXPECT_FALSE(tc.IsCategoryEnabled("not-excluded-nor-included")); |
| 290 |
| 291 EXPECT_TRUE(tc.IsCategoryGroupEnabled("included")); |
| 292 EXPECT_TRUE(tc.IsCategoryGroupEnabled("inc_pattern_category")); |
| 293 EXPECT_TRUE(tc.IsCategoryGroupEnabled("disabled-by-default-cc")); |
| 294 EXPECT_FALSE(tc.IsCategoryGroupEnabled("excluded")); |
| 295 EXPECT_FALSE(tc.IsCategoryGroupEnabled("exc_pattern_category")); |
| 296 EXPECT_FALSE(tc.IsCategoryGroupEnabled("disabled-by-default-others")); |
| 297 EXPECT_FALSE(tc.IsCategoryGroupEnabled("not-excluded-nor-included")); |
| 298 |
| 299 EXPECT_TRUE(tc.IsCategoryGroupEnabled("included,excluded")); |
| 300 EXPECT_FALSE(tc.IsCategoryGroupEnabled("excluded,exc_pattern_category")); |
| 301 EXPECT_TRUE(tc.IsCategoryGroupEnabled("included,DELAY(test.Delay1;16)")); |
| 302 EXPECT_FALSE(tc.IsCategoryGroupEnabled("DELAY(test.Delay1;16)")); |
| 303 |
| 304 EXPECT_EQ(2u, tc.GetSyntheticDelayValues().size()); |
| 305 EXPECT_STREQ("test.Delay1;16", tc.GetSyntheticDelayValues()[0].c_str()); |
| 306 EXPECT_STREQ("test.Delay2;32", tc.GetSyntheticDelayValues()[1].c_str()); |
| 307 |
| 308 const char config_string_2[] = "{\"included_categories\":[\"*\"]}"; |
| 309 TraceConfig tc2(config_string_2); |
| 310 EXPECT_TRUE(tc2.IsCategoryEnabled("non-disabled-by-default-pattern")); |
| 311 EXPECT_FALSE(tc2.IsCategoryEnabled("disabled-by-default-pattern")); |
| 312 EXPECT_TRUE(tc2.IsCategoryGroupEnabled("non-disabled-by-default-pattern")); |
| 313 EXPECT_FALSE(tc2.IsCategoryGroupEnabled("disabled-by-default-pattern")); |
| 314 |
| 315 // Clear |
| 316 tc.Clear(); |
| 317 EXPECT_STREQ(tc.ToString().c_str(), |
| 318 "{" |
| 319 "\"enable_argument_filter\":false," |
| 320 "\"enable_sampling\":false," |
| 321 "\"enable_systrace\":false," |
| 322 "\"record_mode\":\"record-until-full\"" |
| 323 "}"); |
| 324 } |
| 325 |
| 326 TEST(TraceConfigTest, TraceConfigFromInvalidString) { |
| 327 // The config string needs to be a dictionary correctly formatted as a JSON |
| 328 // string. Otherwise, it will fall back to the default initialization. |
| 329 TraceConfig tc(""); |
| 330 EXPECT_STREQ(kDefaultTraceConfigString, tc.ToString().c_str()); |
| 331 EXPECT_EQ(RECORD_UNTIL_FULL, tc.GetTraceRecordMode()); |
| 332 EXPECT_FALSE(tc.IsSamplingEnabled()); |
| 333 EXPECT_FALSE(tc.IsSystraceEnabled()); |
| 334 EXPECT_FALSE(tc.IsArgumentFilterEnabled()); |
| 335 EXPECT_STREQ("-*Debug,-*Test", tc.ToCategoryFilterString().c_str()); |
| 336 |
| 337 tc = TraceConfig("This is an invalid config string."); |
| 338 EXPECT_STREQ(kDefaultTraceConfigString, tc.ToString().c_str()); |
| 339 EXPECT_EQ(RECORD_UNTIL_FULL, tc.GetTraceRecordMode()); |
| 340 EXPECT_FALSE(tc.IsSamplingEnabled()); |
| 341 EXPECT_FALSE(tc.IsSystraceEnabled()); |
| 342 EXPECT_FALSE(tc.IsArgumentFilterEnabled()); |
| 343 EXPECT_STREQ("-*Debug,-*Test", tc.ToCategoryFilterString().c_str()); |
| 344 |
| 345 tc = TraceConfig("[\"This\", \"is\", \"not\", \"a\", \"dictionary\"]"); |
| 346 EXPECT_STREQ(kDefaultTraceConfigString, tc.ToString().c_str()); |
| 347 EXPECT_EQ(RECORD_UNTIL_FULL, tc.GetTraceRecordMode()); |
| 348 EXPECT_FALSE(tc.IsSamplingEnabled()); |
| 349 EXPECT_FALSE(tc.IsSystraceEnabled()); |
| 350 EXPECT_FALSE(tc.IsArgumentFilterEnabled()); |
| 351 EXPECT_STREQ("-*Debug,-*Test", tc.ToCategoryFilterString().c_str()); |
| 352 |
| 353 tc = TraceConfig("{\"record_mode\": invalid-value-needs-double-quote}"); |
| 354 EXPECT_STREQ(kDefaultTraceConfigString, tc.ToString().c_str()); |
| 355 EXPECT_EQ(RECORD_UNTIL_FULL, tc.GetTraceRecordMode()); |
| 356 EXPECT_FALSE(tc.IsSamplingEnabled()); |
| 357 EXPECT_FALSE(tc.IsSystraceEnabled()); |
| 358 EXPECT_FALSE(tc.IsArgumentFilterEnabled()); |
| 359 EXPECT_STREQ("-*Debug,-*Test", tc.ToCategoryFilterString().c_str()); |
| 360 |
| 361 // If the config string a dictionary formatted as a JSON string, it will |
| 362 // initialize TraceConfig with best effort. |
| 363 tc = TraceConfig("{}"); |
| 364 EXPECT_EQ(RECORD_UNTIL_FULL, tc.GetTraceRecordMode()); |
| 365 EXPECT_FALSE(tc.IsSamplingEnabled()); |
| 366 EXPECT_FALSE(tc.IsSystraceEnabled()); |
| 367 EXPECT_FALSE(tc.IsArgumentFilterEnabled()); |
| 368 EXPECT_STREQ("", tc.ToCategoryFilterString().c_str()); |
| 369 |
| 370 tc = TraceConfig("{\"arbitrary-key\":\"arbitrary-value\"}"); |
| 371 EXPECT_EQ(RECORD_UNTIL_FULL, tc.GetTraceRecordMode()); |
| 372 EXPECT_FALSE(tc.IsSamplingEnabled()); |
| 373 EXPECT_FALSE(tc.IsSystraceEnabled()); |
| 374 EXPECT_FALSE(tc.IsArgumentFilterEnabled()); |
| 375 EXPECT_STREQ("", tc.ToCategoryFilterString().c_str()); |
| 376 |
| 377 const char invalid_config_string[] = |
| 378 "{" |
| 379 "\"enable_sampling\":\"true\"," |
| 380 "\"enable_systrace\":1," |
| 381 "\"excluded_categories\":[\"excluded\"]," |
| 382 "\"included_categories\":\"not a list\"," |
| 383 "\"record_mode\":\"arbitrary-mode\"," |
| 384 "\"synthetic_delays\":[\"test.Delay1;16\"," |
| 385 "\"invalid-delay\"," |
| 386 "\"test.Delay2;32\"]" |
| 387 "}"; |
| 388 tc = TraceConfig(invalid_config_string); |
| 389 EXPECT_EQ(RECORD_UNTIL_FULL, tc.GetTraceRecordMode()); |
| 390 EXPECT_FALSE(tc.IsSamplingEnabled()); |
| 391 EXPECT_FALSE(tc.IsSystraceEnabled()); |
| 392 EXPECT_FALSE(tc.IsArgumentFilterEnabled()); |
| 393 EXPECT_STREQ("-excluded,DELAY(test.Delay1;16),DELAY(test.Delay2;32)", |
| 394 tc.ToCategoryFilterString().c_str()); |
| 395 |
| 396 const char invalid_config_string_2[] = |
| 397 "{" |
| 398 "\"included_categories\":[\"category\",\"disabled-by-default-pattern\"]," |
| 399 "\"excluded_categories\":[\"category\",\"disabled-by-default-pattern\"]" |
| 400 "}"; |
| 401 tc = TraceConfig(invalid_config_string_2); |
| 402 EXPECT_TRUE(tc.IsCategoryEnabled("category")); |
| 403 EXPECT_TRUE(tc.IsCategoryEnabled("disabled-by-default-pattern")); |
| 404 EXPECT_TRUE(tc.IsCategoryGroupEnabled("category")); |
| 405 EXPECT_TRUE(tc.IsCategoryGroupEnabled("disabled-by-default-pattern")); |
| 406 } |
| 407 |
| 408 TEST(TraceConfigTest, MergingTraceConfigs) { |
| 409 // Merge |
| 410 TraceConfig tc; |
| 411 TraceConfig tc2("included,-excluded,inc_pattern*,-exc_pattern*", ""); |
| 412 tc.Merge(tc2); |
| 413 EXPECT_STREQ("{" |
| 414 "\"enable_argument_filter\":false," |
| 415 "\"enable_sampling\":false," |
| 416 "\"enable_systrace\":false," |
| 417 "\"excluded_categories\":[" |
| 418 "\"*Debug\",\"*Test\",\"excluded\",\"exc_pattern*\"" |
| 419 "]," |
| 420 "\"record_mode\":\"record-until-full\"" |
| 421 "}", |
| 422 tc.ToString().c_str()); |
| 423 |
| 424 tc = TraceConfig("DELAY(test.Delay1;16)", ""); |
| 425 tc2 = TraceConfig("DELAY(test.Delay2;32)", ""); |
| 426 tc.Merge(tc2); |
| 427 EXPECT_EQ(2u, tc.GetSyntheticDelayValues().size()); |
| 428 EXPECT_STREQ("test.Delay1;16", tc.GetSyntheticDelayValues()[0].c_str()); |
| 429 EXPECT_STREQ("test.Delay2;32", tc.GetSyntheticDelayValues()[1].c_str()); |
| 430 } |
| 431 |
| 432 TEST(TraceConfigTest, IsCategoryGroupEnabled) { |
| 433 // Enabling a disabled- category does not require all categories to be traced |
| 434 // to be included. |
| 435 TraceConfig tc("disabled-by-default-cc,-excluded", ""); |
| 436 EXPECT_STREQ("disabled-by-default-cc,-excluded", |
| 437 tc.ToCategoryFilterString().c_str()); |
| 438 EXPECT_TRUE(tc.IsCategoryGroupEnabled("disabled-by-default-cc")); |
| 439 EXPECT_TRUE(tc.IsCategoryGroupEnabled("some_other_group")); |
| 440 EXPECT_FALSE(tc.IsCategoryGroupEnabled("excluded")); |
| 441 |
| 442 // Enabled a disabled- category and also including makes all categories to |
| 443 // be traced require including. |
| 444 tc = TraceConfig("disabled-by-default-cc,included", ""); |
| 445 EXPECT_STREQ("included,disabled-by-default-cc", |
| 446 tc.ToCategoryFilterString().c_str()); |
| 447 EXPECT_TRUE(tc.IsCategoryGroupEnabled("disabled-by-default-cc")); |
| 448 EXPECT_TRUE(tc.IsCategoryGroupEnabled("included")); |
| 449 EXPECT_FALSE(tc.IsCategoryGroupEnabled("other_included")); |
| 450 } |
| 451 |
| 452 TEST(TraceConfigTest, IsEmptyOrContainsLeadingOrTrailingWhitespace) { |
| 453 // Test that IsEmptyOrContainsLeadingOrTrailingWhitespace actually catches |
| 454 // categories that are explicitly forbidden. |
| 455 // This method is called in a DCHECK to assert that we don't have these types |
| 456 // of strings as categories. |
| 457 EXPECT_TRUE(TraceConfig::IsEmptyOrContainsLeadingOrTrailingWhitespace( |
| 458 " bad_category ")); |
| 459 EXPECT_TRUE(TraceConfig::IsEmptyOrContainsLeadingOrTrailingWhitespace( |
| 460 " bad_category")); |
| 461 EXPECT_TRUE(TraceConfig::IsEmptyOrContainsLeadingOrTrailingWhitespace( |
| 462 "bad_category ")); |
| 463 EXPECT_TRUE(TraceConfig::IsEmptyOrContainsLeadingOrTrailingWhitespace( |
| 464 " bad_category")); |
| 465 EXPECT_TRUE(TraceConfig::IsEmptyOrContainsLeadingOrTrailingWhitespace( |
| 466 "bad_category ")); |
| 467 EXPECT_TRUE(TraceConfig::IsEmptyOrContainsLeadingOrTrailingWhitespace( |
| 468 " bad_category ")); |
| 469 EXPECT_TRUE(TraceConfig::IsEmptyOrContainsLeadingOrTrailingWhitespace( |
| 470 "")); |
| 471 EXPECT_FALSE(TraceConfig::IsEmptyOrContainsLeadingOrTrailingWhitespace( |
| 472 "good_category")); |
| 473 } |
| 474 |
| 475 TEST(TraceConfigTest, SetTraceOptionValues) { |
| 476 TraceConfig tc; |
| 477 EXPECT_EQ(RECORD_UNTIL_FULL, tc.GetTraceRecordMode()); |
| 478 EXPECT_FALSE(tc.IsSamplingEnabled()); |
| 479 EXPECT_FALSE(tc.IsSystraceEnabled()); |
| 480 |
| 481 tc.SetTraceRecordMode(RECORD_AS_MUCH_AS_POSSIBLE); |
| 482 EXPECT_EQ(RECORD_AS_MUCH_AS_POSSIBLE, tc.GetTraceRecordMode()); |
| 483 |
| 484 tc.EnableSampling(); |
| 485 EXPECT_TRUE(tc.IsSamplingEnabled()); |
| 486 |
| 487 tc.EnableSystrace(); |
| 488 EXPECT_TRUE(tc.IsSystraceEnabled()); |
| 489 } |
| 490 |
| 491 } // namespace trace_event |
| 492 } // namespace base |
OLD | NEW |