Chromium Code Reviews| 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 |