Index: base/metrics/histogram_base_unittest.cc |
diff --git a/base/metrics/histogram_base_unittest.cc b/base/metrics/histogram_base_unittest.cc |
new file mode 100644 |
index 0000000000000000000000000000000000000000..19723688e6403aa1525c144bfc92c9afbcf67946 |
--- /dev/null |
+++ b/base/metrics/histogram_base_unittest.cc |
@@ -0,0 +1,138 @@ |
+// Copyright (c) 2012 The Chromium Authors. All rights reserved. |
+// Use of this source code is governed by a BSD-style license that can be |
+// found in the LICENSE file. |
+ |
+#include <vector> |
+ |
+#include "base/metrics/histogram.h" |
+#include "base/metrics/histogram_base.h" |
+#include "base/metrics/sparse_histogram.h" |
+#include "base/metrics/statistics_recorder.h" |
+#include "base/pickle.h" |
+#include "testing/gtest/include/gtest/gtest.h" |
+ |
+namespace base { |
+ |
+class HistogramBaseTest : public testing::Test { |
+ protected: |
+ virtual void SetUp() { |
Ilya Sherman
2012/12/29 00:17:30
nit: OVERRIDE
kaiwang
2013/01/08 00:51:40
changed to constructor
|
+ // Each test will have a clean state (no Histogram / BucketRanges |
+ // registered). |
+ statistics_recorder_ = NULL; |
+ ResetStatisticsRecorder(); |
+ } |
Ilya Sherman
2012/12/29 00:17:30
nit: Why not do this in the constructor?
kaiwang
2013/01/08 00:51:40
Done.
|
+ |
+ virtual void TearDown() { |
Ilya Sherman
2012/12/29 00:17:30
nit: OVERRIDE
kaiwang
2013/01/08 00:51:40
changed to destructor
|
+ delete statistics_recorder_; |
+ } |
+ |
+ void ResetStatisticsRecorder() { |
+ delete statistics_recorder_; |
+ statistics_recorder_ = new StatisticsRecorder(); |
+ } |
+ |
+ private: |
+ StatisticsRecorder* statistics_recorder_; |
Ilya Sherman
2012/12/29 00:17:30
nit: Please make this a scoped_ptr<>
kaiwang
2013/01/08 00:51:40
StatisticsRecorder constructor is private...
Ilya Sherman
2013/01/08 22:31:53
Yuck. Ok.
|
+}; |
+ |
+TEST_F(HistogramBaseTest, DeserializeHistogram) { |
+ HistogramBase* histogram = Histogram::FactoryGet( |
+ "TestHistogram", 1, 1000, 10, |
+ (HistogramBase::kUmaTargetedHistogramFlag | |
+ HistogramBase::kIPCSerializationSourceFlag)); |
+ |
+ Pickle pickle; |
+ ASSERT_TRUE(histogram->SerializeInfo(&pickle)); |
+ |
+ PickleIterator iter(pickle); |
+ HistogramBase* deserialized = HistogramBase::DeserializeHistogramInfo(&iter); |
+ EXPECT_EQ(histogram, deserialized); |
+ |
+ ResetStatisticsRecorder(); |
+ |
+ PickleIterator iter2(pickle); |
+ deserialized = HistogramBase::DeserializeHistogramInfo(&iter2); |
+ EXPECT_TRUE(deserialized); |
+ EXPECT_NE(histogram, deserialized); |
+ EXPECT_EQ("TestHistogram", deserialized->histogram_name()); |
+ EXPECT_TRUE(deserialized->HasConstructionArguments(1, 1000, 10)); |
+ |
+ // kIPCSerializationSourceFlag will be cleared. |
+ EXPECT_EQ(HistogramBase::kUmaTargetedHistogramFlag, deserialized->flags()); |
+} |
+ |
+TEST_F(HistogramBaseTest, DeserializeLinearHistogram) { |
+ HistogramBase* histogram = LinearHistogram::FactoryGet( |
+ "TestHistogram", 1, 1000, 10, |
+ HistogramBase::kIPCSerializationSourceFlag); |
+ |
+ Pickle pickle; |
+ ASSERT_TRUE(histogram->SerializeInfo(&pickle)); |
+ |
+ PickleIterator iter(pickle); |
+ HistogramBase* deserialized = HistogramBase::DeserializeHistogramInfo(&iter); |
+ EXPECT_EQ(histogram, deserialized); |
+ |
+ ResetStatisticsRecorder(); |
+ |
+ PickleIterator iter2(pickle); |
+ deserialized = HistogramBase::DeserializeHistogramInfo(&iter2); |
+ EXPECT_TRUE(deserialized); |
+ EXPECT_NE(histogram, deserialized); |
+ EXPECT_EQ("TestHistogram", deserialized->histogram_name()); |
+ EXPECT_TRUE(deserialized->HasConstructionArguments(1, 1000, 10)); |
+ EXPECT_EQ(0, deserialized->flags()); |
+} |
+ |
+TEST_F(HistogramBaseTest, DeserializeBooleanHistogram) { |
+ HistogramBase* histogram = BooleanHistogram::FactoryGet( |
+ "TestHistogram", HistogramBase::kIPCSerializationSourceFlag); |
+ |
+ Pickle pickle; |
+ ASSERT_TRUE(histogram->SerializeInfo(&pickle)); |
+ |
+ PickleIterator iter(pickle); |
+ HistogramBase* deserialized = HistogramBase::DeserializeHistogramInfo(&iter); |
+ EXPECT_EQ(histogram, deserialized); |
+ |
+ ResetStatisticsRecorder(); |
+ |
+ PickleIterator iter2(pickle); |
+ deserialized = HistogramBase::DeserializeHistogramInfo(&iter2); |
+ EXPECT_TRUE(deserialized); |
+ EXPECT_NE(histogram, deserialized); |
+ EXPECT_EQ("TestHistogram", deserialized->histogram_name()); |
+ EXPECT_TRUE(deserialized->HasConstructionArguments(1, 2, 3)); |
+ EXPECT_EQ(0, deserialized->flags()); |
+} |
+ |
+TEST_F(HistogramBaseTest, DeserializeCustomHistogram) { |
+ std::vector<HistogramBase::Sample> ranges; |
+ ranges.push_back(13); |
+ ranges.push_back(5); |
+ ranges.push_back(9); |
+ |
+ HistogramBase* histogram = CustomHistogram::FactoryGet( |
+ "TestHistogram", ranges, HistogramBase::kIPCSerializationSourceFlag); |
+ |
+ Pickle pickle; |
+ ASSERT_TRUE(histogram->SerializeInfo(&pickle)); |
+ |
+ PickleIterator iter(pickle); |
+ HistogramBase* deserialized = HistogramBase::DeserializeHistogramInfo(&iter); |
+ EXPECT_EQ(histogram, deserialized); |
+ |
+ ResetStatisticsRecorder(); |
+ |
+ PickleIterator iter2(pickle); |
+ deserialized = HistogramBase::DeserializeHistogramInfo(&iter2); |
+ EXPECT_TRUE(deserialized); |
+ EXPECT_NE(histogram, deserialized); |
+ EXPECT_EQ("TestHistogram", deserialized->histogram_name()); |
+ EXPECT_TRUE(deserialized->HasConstructionArguments(5, 13, 4)); |
+ EXPECT_EQ(0, deserialized->flags()); |
+} |
+ |
+// TODO(kaiwang): Add SparseHistogram test. |
+ |
+} // namespace base |