Index: base/metrics/histogram_unittest.cc |
diff --git a/base/metrics/histogram_unittest.cc b/base/metrics/histogram_unittest.cc |
index e7a01aa5af3d54bf1973f959822b1d989bd8417a..c6f0c8905ab3e399d1c2a51054ae79c4575e2b25 100644 |
--- a/base/metrics/histogram_unittest.cc |
+++ b/base/metrics/histogram_unittest.cc |
@@ -443,6 +443,54 @@ TEST_F(HistogramTest, CustomHistogramSerializeInfo) { |
EXPECT_FALSE(iter.SkipBytes(1)); |
} |
+TEST_F(HistogramTest, BadConstruction) { |
+ HistogramBase* histogram = Histogram::FactoryGet( |
+ "BadConstruction", 0, 100, 8, |
+ HistogramBase::kNoFlags); |
+ EXPECT_TRUE( |
+ histogram->HasConstructionArguments( |
+ 1, 100, 8)); |
+ histogram->Add(10); |
+ |
+ // Try to get the same histogram name with different arguments. |
+ HistogramBase* dummy_histogram = Histogram::FactoryGet( |
+ "BadConstruction", 0, 100, 7, |
+ HistogramBase::kNoFlags); |
+ dummy_histogram->Add(80); |
+ dummy_histogram = Histogram::FactoryGet( |
+ "BadConstruction", 0, 99, 8, |
+ HistogramBase::kNoFlags); |
+ dummy_histogram->Add(80); |
+ |
+ scoped_ptr<HistogramSamples> samples = histogram->SnapshotSamples(); |
+ EXPECT_EQ(1, samples->TotalCount()); |
+ EXPECT_EQ(1, samples->GetCount(10)); |
+ EXPECT_EQ(0, samples->GetCount(80)); |
+ |
+ HistogramBase* linear_histogram = LinearHistogram::FactoryGet( |
+ "BadConstructionLinear", 0, 100, 8, |
+ HistogramBase::kNoFlags); |
+ EXPECT_TRUE( |
+ linear_histogram->HasConstructionArguments( |
+ 1, 100, 8)); |
+ linear_histogram->Add(10); |
+ |
+ // Try to get the same histogram name with different arguments. |
+ dummy_histogram = LinearHistogram::FactoryGet( |
+ "BadConstructionLinear", 0, 100, 7, |
+ HistogramBase::kNoFlags); |
+ dummy_histogram->Add(80); |
+ dummy_histogram = LinearHistogram::FactoryGet( |
+ "BadConstructionLinear", 10, 100, 8, |
+ HistogramBase::kNoFlags); |
+ dummy_histogram->Add(80); |
+ |
+ scoped_ptr<HistogramSamples> l_samples = linear_histogram->SnapshotSamples(); |
+ EXPECT_EQ(1, l_samples->TotalCount()); |
+ EXPECT_EQ(1, l_samples->GetCount(10)); |
+ EXPECT_EQ(0, l_samples->GetCount(80)); |
+} |
+ |
#if GTEST_HAS_DEATH_TEST |
// For Histogram, LinearHistogram and CustomHistogram, the minimum for a |
// declared range is 1, while the maximum is (HistogramBase::kSampleType_MAX - |