| 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 <math.h> | 5 #include <math.h> |
| 6 #include <stddef.h> | 6 #include <stddef.h> |
| 7 #include <stdint.h> | 7 #include <stdint.h> |
| 8 | 8 |
| 9 #include <cstdlib> | 9 #include <cstdlib> |
| 10 | 10 |
| (...skipping 1219 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 1230 EndTraceAndFlush(); | 1230 EndTraceAndFlush(); |
| 1231 } | 1231 } |
| 1232 } | 1232 } |
| 1233 | 1233 |
| 1234 TEST_F(TraceEventTestFixture, AddMetadataEvent) { | 1234 TEST_F(TraceEventTestFixture, AddMetadataEvent) { |
| 1235 int num_calls = 0; | 1235 int num_calls = 0; |
| 1236 | 1236 |
| 1237 class Convertable : public ConvertableToTraceFormat { | 1237 class Convertable : public ConvertableToTraceFormat { |
| 1238 public: | 1238 public: |
| 1239 explicit Convertable(int* num_calls) : num_calls_(num_calls) {} | 1239 explicit Convertable(int* num_calls) : num_calls_(num_calls) {} |
| 1240 ~Convertable() override {} |
| 1240 void AppendAsTraceFormat(std::string* out) const override { | 1241 void AppendAsTraceFormat(std::string* out) const override { |
| 1241 (*num_calls_)++; | 1242 (*num_calls_)++; |
| 1242 out->append("\"metadata_value\""); | 1243 out->append("\"metadata_value\""); |
| 1243 } | 1244 } |
| 1244 | 1245 |
| 1245 private: | 1246 private: |
| 1246 ~Convertable() override {} | |
| 1247 int* num_calls_; | 1247 int* num_calls_; |
| 1248 }; | 1248 }; |
| 1249 | 1249 |
| 1250 scoped_refptr<ConvertableToTraceFormat> convertable = | 1250 scoped_ptr<ConvertableToTraceFormat> convertable(new Convertable(&num_calls)); |
| 1251 new Convertable(&num_calls); | |
| 1252 | 1251 |
| 1253 BeginTrace(); | 1252 BeginTrace(); |
| 1254 TRACE_EVENT_API_ADD_METADATA_EVENT("metadata_event_name", "metadata_arg_name", | 1253 TRACE_EVENT_API_ADD_METADATA_EVENT("metadata_event_name", "metadata_arg_name", |
| 1255 convertable); | 1254 std::move(convertable)); |
| 1256 | 1255 |
| 1257 // |AppendAsTraceFormat| should only be called on flush, not when the event | 1256 // |AppendAsTraceFormat| should only be called on flush, not when the event |
| 1258 // is added. | 1257 // is added. |
| 1259 ASSERT_EQ(0, num_calls); | 1258 ASSERT_EQ(0, num_calls); |
| 1260 EndTraceAndFlush(); | 1259 EndTraceAndFlush(); |
| 1261 ASSERT_EQ(1, num_calls); | 1260 ASSERT_EQ(1, num_calls); |
| 1262 EXPECT_TRUE(FindNamePhaseKeyValue("metadata_event_name", "M", | 1261 EXPECT_TRUE(FindNamePhaseKeyValue("metadata_event_name", "M", |
| 1263 "metadata_arg_name", "metadata_value")); | 1262 "metadata_arg_name", "metadata_value")); |
| 1264 | 1263 |
| 1265 // The metadata event should only be adde to the current trace. In this new | 1264 // The metadata event should only be adde to the current trace. In this new |
| (...skipping 776 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 2042 | 2041 |
| 2043 private: | 2042 private: |
| 2044 ~MyData() override {} | 2043 ~MyData() override {} |
| 2045 DISALLOW_COPY_AND_ASSIGN(MyData); | 2044 DISALLOW_COPY_AND_ASSIGN(MyData); |
| 2046 }; | 2045 }; |
| 2047 | 2046 |
| 2048 TEST_F(TraceEventTestFixture, ConvertableTypes) { | 2047 TEST_F(TraceEventTestFixture, ConvertableTypes) { |
| 2049 TraceLog::GetInstance()->SetEnabled(TraceConfig(kRecordAllCategoryFilter, ""), | 2048 TraceLog::GetInstance()->SetEnabled(TraceConfig(kRecordAllCategoryFilter, ""), |
| 2050 TraceLog::RECORDING_MODE); | 2049 TraceLog::RECORDING_MODE); |
| 2051 | 2050 |
| 2052 scoped_refptr<ConvertableToTraceFormat> data(new MyData()); | 2051 scoped_ptr<ConvertableToTraceFormat> data(new MyData()); |
| 2053 scoped_refptr<ConvertableToTraceFormat> data1(new MyData()); | 2052 scoped_ptr<ConvertableToTraceFormat> data1(new MyData()); |
| 2054 scoped_refptr<ConvertableToTraceFormat> data2(new MyData()); | 2053 scoped_ptr<ConvertableToTraceFormat> data2(new MyData()); |
| 2055 TRACE_EVENT1("foo", "bar", "data", data); | 2054 TRACE_EVENT1("foo", "bar", "data", std::move(data)); |
| 2056 TRACE_EVENT2("foo", "baz", | 2055 TRACE_EVENT2("foo", "baz", "data1", std::move(data1), "data2", |
| 2057 "data1", data1, | 2056 std::move(data2)); |
| 2058 "data2", data2); | |
| 2059 | 2057 |
| 2060 | 2058 scoped_ptr<ConvertableToTraceFormat> convertData1(new MyData()); |
| 2061 scoped_refptr<ConvertableToTraceFormat> convertData1(new MyData()); | 2059 scoped_ptr<ConvertableToTraceFormat> convertData2(new MyData()); |
| 2062 scoped_refptr<ConvertableToTraceFormat> convertData2(new MyData()); | 2060 TRACE_EVENT2("foo", "string_first", "str", "string value 1", "convert", |
| 2063 TRACE_EVENT2( | 2061 std::move(convertData1)); |
| 2064 "foo", | 2062 TRACE_EVENT2("foo", "string_second", "convert", std::move(convertData2), |
| 2065 "string_first", | 2063 "str", "string value 2"); |
| 2066 "str", | |
| 2067 "string value 1", | |
| 2068 "convert", | |
| 2069 convertData1); | |
| 2070 TRACE_EVENT2( | |
| 2071 "foo", | |
| 2072 "string_second", | |
| 2073 "convert", | |
| 2074 convertData2, | |
| 2075 "str", | |
| 2076 "string value 2"); | |
| 2077 EndTraceAndFlush(); | 2064 EndTraceAndFlush(); |
| 2078 | 2065 |
| 2079 // One arg version. | 2066 // One arg version. |
| 2080 DictionaryValue* dict = FindNamePhase("bar", "X"); | 2067 DictionaryValue* dict = FindNamePhase("bar", "X"); |
| 2081 ASSERT_TRUE(dict); | 2068 ASSERT_TRUE(dict); |
| 2082 | 2069 |
| 2083 const DictionaryValue* args_dict = NULL; | 2070 const DictionaryValue* args_dict = NULL; |
| 2084 dict->GetDictionary("args", &args_dict); | 2071 dict->GetDictionary("args", &args_dict); |
| 2085 ASSERT_TRUE(args_dict); | 2072 ASSERT_TRUE(args_dict); |
| 2086 | 2073 |
| (...skipping 979 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 3066 } | 3053 } |
| 3067 | 3054 |
| 3068 TEST_F(TraceEventTestFixture, SyntheticDelayConfigurationToString) { | 3055 TEST_F(TraceEventTestFixture, SyntheticDelayConfigurationToString) { |
| 3069 const char filter[] = "DELAY(test.Delay;16;oneshot)"; | 3056 const char filter[] = "DELAY(test.Delay;16;oneshot)"; |
| 3070 TraceConfig config(filter, ""); | 3057 TraceConfig config(filter, ""); |
| 3071 EXPECT_EQ(filter, config.ToCategoryFilterString()); | 3058 EXPECT_EQ(filter, config.ToCategoryFilterString()); |
| 3072 } | 3059 } |
| 3073 | 3060 |
| 3074 } // namespace trace_event | 3061 } // namespace trace_event |
| 3075 } // namespace base | 3062 } // namespace base |
| OLD | NEW |