Chromium Code Reviews| Index: base/metrics/statistics_recorder_unittest.cc |
| =================================================================== |
| --- base/metrics/statistics_recorder_unittest.cc (revision 0) |
| +++ base/metrics/statistics_recorder_unittest.cc (revision 0) |
| @@ -0,0 +1,244 @@ |
| +// 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/memory/scoped_ptr.h" |
| +#include "base/metrics/histogram.h" |
| +#include "base/metrics/statistics_recorder.h" |
| +#include "testing/gtest/include/gtest/gtest.h" |
| + |
| +namespace base { |
| + |
| +class StatisticsRecorderTest : public testing::Test { |
| + protected: |
| + virtual void SetUp() { |
| + // Each test will have a clean state (no Histogram / BucketRanges |
| + // registered). |
| + InitializeStatisticsRecorder(); |
| + } |
| + |
| + virtual void TearDown() { |
| + UninitializeStatisticsRecorder(); |
| + } |
| + |
| + void InitializeStatisticsRecorder() { |
| + statistics_recorder_ = new StatisticsRecorder(); |
| + } |
| + |
| + void UninitializeStatisticsRecorder() { |
| + delete statistics_recorder_; |
| + statistics_recorder_ = NULL; |
| + } |
| + |
| + StatisticsRecorder* statistics_recorder_; |
| +}; |
| + |
| +TEST_F(StatisticsRecorderTest, NotInitialized) { |
| + UninitializeStatisticsRecorder(); |
| + |
| + ASSERT_FALSE(StatisticsRecorder::IsActive()); |
| + |
| + StatisticsRecorder::Histograms registered_histograms; |
| + std::vector<const BucketRanges*> registered_ranges; |
| + |
| + // We can still create histograms, but it's not registered. |
| + // TODO(kaiwang): Do not depend on Histogram FactoryGet implementation. |
| + scoped_ptr<Histogram> histogram( |
| + Histogram::FactoryGet("StatisticsRecorderTest_NotInitialized", |
| + 1, 1000, 10, Histogram::kNoFlags)); |
| + StatisticsRecorder::GetHistograms(®istered_histograms); |
| + EXPECT_EQ(0u, registered_histograms.size()); |
| + |
| + // RegisterOrDeleteDuplicateRanges is a no-op. |
| + BucketRanges* ranges = new BucketRanges(3);; |
| + ranges->ResetChecksum(); |
| + EXPECT_EQ( |
| + static_cast<const BucketRanges*>(ranges), |
|
jar (doing other things)
2012/08/01 00:26:10
nit: you can push 58 back onto 57, and then align
kaiwang
2012/08/01 04:13:21
Done.
|
| + StatisticsRecorder::RegisterOrDeleteDuplicateRanges(ranges)); |
| + StatisticsRecorder::GetBucketRanges(®istered_ranges); |
| + EXPECT_EQ(0u, registered_ranges.size()); |
| +} |
| + |
| +TEST_F(StatisticsRecorderTest, RegisterBucketRanges) { |
| + std::vector<const BucketRanges*> registered_ranges; |
| + |
| + BucketRanges* ranges1 = new BucketRanges(3);; |
| + ranges1->ResetChecksum(); |
| + BucketRanges* ranges2 = new BucketRanges(4);; |
| + ranges2->ResetChecksum(); |
| + |
| + // Register new ranges. |
| + EXPECT_EQ( |
| + static_cast<const BucketRanges*>(ranges1), |
| + StatisticsRecorder::RegisterOrDeleteDuplicateRanges(ranges1)); |
| + EXPECT_EQ( |
| + static_cast<const BucketRanges*>(ranges2), |
| + StatisticsRecorder::RegisterOrDeleteDuplicateRanges(ranges2)); |
| + StatisticsRecorder::GetBucketRanges(®istered_ranges); |
| + ASSERT_EQ(2u, registered_ranges.size()); |
| + |
| + // Register some ranges again. |
| + EXPECT_EQ( |
| + static_cast<const BucketRanges*>(ranges1), |
| + StatisticsRecorder::RegisterOrDeleteDuplicateRanges(ranges1)); |
| + registered_ranges.clear(); |
| + StatisticsRecorder::GetBucketRanges(®istered_ranges); |
| + ASSERT_EQ(2u, registered_ranges.size()); |
| + // Make sure the ranges is still the one we know. |
| + EXPECT_EQ(3u, ranges1->size()); |
|
jar (doing other things)
2012/08/01 00:26:10
Assert
kaiwang
2012/08/01 04:13:21
Done.
|
| + EXPECT_EQ(0, ranges1->range(0)); |
| + EXPECT_EQ(0, ranges1->range(1)); |
| + EXPECT_EQ(0, ranges1->range(2)); |
| + |
| + // Register ranges with same values. |
| + BucketRanges* ranges3 = new BucketRanges(3);; |
| + ranges3->ResetChecksum(); |
| + EXPECT_EQ( |
| + static_cast<const BucketRanges*>(ranges1), // returning ranges1 |
|
jar (doing other things)
2012/08/01 00:26:10
nit: probably don't need cast to compare pointers.
kaiwang
2012/08/01 04:13:21
Done.
|
| + StatisticsRecorder::RegisterOrDeleteDuplicateRanges(ranges3)); |
| + registered_ranges.clear(); |
| + StatisticsRecorder::GetBucketRanges(®istered_ranges); |
| + ASSERT_EQ(2u, registered_ranges.size()); |
| +} |
| + |
| +TEST_F(StatisticsRecorderTest, RegisterHistogram) { |
| + // Create a Histogram that was not registered. |
| + // TODO(kaiwang): Do not depend on Histogram FactoryGet implementation. |
| + UninitializeStatisticsRecorder(); |
| + Histogram* histogram = Histogram::FactoryGet( |
| + "TestHistogram", 1, 1000, 10, Histogram::kNoFlags); |
| + |
| + // Clean StatisticsRecorder. |
| + InitializeStatisticsRecorder(); |
| + StatisticsRecorder::Histograms registered_histograms; |
| + StatisticsRecorder::GetHistograms(®istered_histograms); |
| + EXPECT_EQ(0u, registered_histograms.size()); |
| + |
| + // Register the Histogram. |
| + EXPECT_EQ(histogram, |
| + StatisticsRecorder::RegisterOrDeleteDuplicate(histogram)); |
| + StatisticsRecorder::GetHistograms(®istered_histograms); |
| + EXPECT_EQ(1u, registered_histograms.size()); |
| + |
| + // Register the same Histogram again. |
| + EXPECT_EQ(histogram, |
| + StatisticsRecorder::RegisterOrDeleteDuplicate(histogram)); |
| + registered_histograms.clear(); |
| + StatisticsRecorder::GetHistograms(®istered_histograms); |
| + EXPECT_EQ(1u, registered_histograms.size()); |
| +} |
| + |
| +TEST_F(StatisticsRecorderTest, FindHistogram) { |
| + Histogram* histogram1 = Histogram::FactoryGet( |
| + "TestHistogram1", 1, 1000, 10, Histogram::kNoFlags); |
| + Histogram* histogram2 = Histogram::FactoryGet( |
| + "TestHistogram2", 1, 1000, 10, Histogram::kNoFlags); |
| + |
| + EXPECT_EQ(histogram1, StatisticsRecorder::FindHistogram("TestHistogram1")); |
| + EXPECT_EQ(histogram2, StatisticsRecorder::FindHistogram("TestHistogram2")); |
| + EXPECT_TRUE(StatisticsRecorder::FindHistogram("TestHistogram") == NULL); |
| +} |
| + |
| +TEST_F(StatisticsRecorderTest, GetSnapshot) { |
| + Histogram::FactoryGet("TestHistogram1", 1, 1000, 10, Histogram::kNoFlags); |
| + Histogram::FactoryGet("TestHistogram2", 1, 1000, 10, Histogram::kNoFlags); |
| + Histogram::FactoryGet("TestHistogram3", 1, 1000, 10, Histogram::kNoFlags); |
| + |
| + StatisticsRecorder::Histograms snapshot; |
| + StatisticsRecorder::GetSnapshot("Test", &snapshot); |
| + EXPECT_EQ(3u, snapshot.size()); |
| + |
| + snapshot.clear(); |
| + StatisticsRecorder::GetSnapshot("1", &snapshot); |
| + EXPECT_EQ(1u, snapshot.size()); |
| + |
| + snapshot.clear(); |
| + StatisticsRecorder::GetSnapshot("hello", &snapshot); |
| + EXPECT_EQ(0u, snapshot.size()); |
| +} |
| + |
| +TEST_F(StatisticsRecorderTest, RegisterHistogramWithFactoryGet) { |
| + StatisticsRecorder::Histograms registered_histograms; |
| + |
| + StatisticsRecorder::GetHistograms(®istered_histograms); |
| + ASSERT_EQ(0u, registered_histograms.size()); |
| + |
| + // Create a Histogram. |
| + Histogram* histogram = Histogram::FactoryGet( |
| + "TestHistogram", 1, 1000, 10, Histogram::kNoFlags); |
| + registered_histograms.clear(); |
| + StatisticsRecorder::GetHistograms(®istered_histograms); |
| + EXPECT_EQ(1u, registered_histograms.size()); |
| + |
| + // Create a LinearHistogram. |
| + histogram = LinearHistogram::FactoryGet( |
| + "TestLinearHistogram", 1, 1000, 10, Histogram::kNoFlags); |
| + registered_histograms.clear(); |
| + StatisticsRecorder::GetHistograms(®istered_histograms); |
| + EXPECT_EQ(2u, registered_histograms.size()); |
| + |
| + // Create a BooleanHistogram. |
| + histogram = BooleanHistogram::FactoryGet( |
| + "TestBooleanHistogram", Histogram::kNoFlags); |
| + registered_histograms.clear(); |
| + StatisticsRecorder::GetHistograms(®istered_histograms); |
| + EXPECT_EQ(3u, registered_histograms.size()); |
| + |
| + // Create a CustomHistogram. |
| + std::vector<int> custom_ranges; |
| + custom_ranges.push_back(1); |
| + custom_ranges.push_back(5); |
| + histogram = CustomHistogram::FactoryGet( |
| + "TestCustomHistogram", custom_ranges, Histogram::kNoFlags); |
| + registered_histograms.clear(); |
| + StatisticsRecorder::GetHistograms(®istered_histograms); |
| + EXPECT_EQ(4u, registered_histograms.size()); |
| + |
| + // Get an existing histogram. |
| + histogram = Histogram::FactoryGet( |
|
jar (doing other things)
2012/08/01 00:26:10
Suggest using a separate variable, and verifying y
kaiwang
2012/08/01 04:13:21
Done.
|
| + "TestHistogram", 1, 1000, 10, Histogram::kNoFlags); |
| + registered_histograms.clear(); |
| + StatisticsRecorder::GetHistograms(®istered_histograms); |
| + EXPECT_EQ(4u, registered_histograms.size()); |
| +} |
| + |
| +TEST_F(StatisticsRecorderTest, RegisterHistogramWithMacros) { |
| + StatisticsRecorder::Histograms registered_histograms; |
|
jar (doing other things)
2012/08/01 00:26:10
Perhaps another comprare macro to a FactoryGet for
kaiwang
2012/08/01 04:13:21
Done.
|
| + |
| + HISTOGRAM_TIMES("TestHistogramTimes", TimeDelta::FromDays(1)); |
| + HISTOGRAM_COUNTS("TestHistogramCounts", 30); |
| + HISTOGRAM_ENUMERATION("TestHistogramEnumeration", 20, 200); |
| + |
| + StatisticsRecorder::GetHistograms(®istered_histograms); |
| + EXPECT_EQ(3u, registered_histograms.size()); |
| + |
| + // Debugging only macros. |
| + DHISTOGRAM_TIMES("TestHistogramDebugTimes", TimeDelta::FromDays(1)); |
| + DHISTOGRAM_COUNTS("TestHistogramDebugCounts", 30); |
| + registered_histograms.clear(); |
| + StatisticsRecorder::GetHistograms(®istered_histograms); |
| +#ifndef NDEBUG |
| + EXPECT_EQ(5u, registered_histograms.size()); |
| +#else |
| + EXPECT_EQ(3u, registered_histograms.size()); |
| +#endif |
| +} |
| + |
| +TEST_F(StatisticsRecorderTest, BucketRangesSharing) { |
| + Histogram* histogram1(Histogram::FactoryGet( |
| + "Histogram", 1, 64, 8, Histogram::kNoFlags)); |
| + Histogram* histogram2(Histogram::FactoryGet( |
| + "Histogram2", 1, 64, 8, Histogram::kNoFlags)); |
| + Histogram* histogram3(Histogram::FactoryGet( |
| + "Histogram3", 1, 64, 16, Histogram::kNoFlags)); |
| + |
| + const BucketRanges* bucket_ranges1 = histogram1->bucket_ranges(); |
| + const BucketRanges* bucket_ranges2 = histogram2->bucket_ranges(); |
| + const BucketRanges* bucket_ranges3 = histogram3->bucket_ranges(); |
| + EXPECT_EQ(bucket_ranges1, bucket_ranges2); |
| + EXPECT_FALSE(bucket_ranges1->Equals(bucket_ranges3)); |
| +} |
| + |
| +} // namespace base |
| Property changes on: base/metrics/statistics_recorder_unittest.cc |
| ___________________________________________________________________ |
| Added: svn:eol-style |
| + LF |