Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(107)

Side by Side Diff: base/trace_event/trace_event_unittest.cc

Issue 1717283003: tracing: Make ConvertableToTraceFormat move-only scoped_ptr (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: . Created 4 years, 10 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
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
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
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
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
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698