|  | // Copyright (c) 2017 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 "base/metrics/histogram_samples.h" | 
|  |  | 
|  | #include <limits> | 
|  |  | 
|  | #include "base/test/gtest_util.h" | 
|  | #include "testing/gtest/include/gtest/gtest.h" | 
|  |  | 
|  | namespace base { | 
|  |  | 
|  | using SingleSample = HistogramSamples::SingleSample; | 
|  | using AtomicSingleSample = HistogramSamples::AtomicSingleSample; | 
|  |  | 
|  | TEST(SingleSampleTest, Load) { | 
|  | AtomicSingleSample sample; | 
|  | ASSERT_TRUE(sample.Accumulate(9, 1)); | 
|  |  | 
|  | SingleSample s = sample.Load(); | 
|  | EXPECT_EQ(9U, s.bucket); | 
|  | EXPECT_EQ(1U, s.count); | 
|  |  | 
|  | s = sample.Load(); | 
|  | EXPECT_EQ(9U, s.bucket); | 
|  | EXPECT_EQ(1U, s.count); | 
|  | } | 
|  |  | 
|  | TEST(SingleSampleTest, Extract) { | 
|  | AtomicSingleSample sample; | 
|  | ASSERT_TRUE(sample.Accumulate(9, 1)); | 
|  |  | 
|  | SingleSample s = sample.Extract(/*disable=*/false); | 
|  | EXPECT_EQ(9U, s.bucket); | 
|  | EXPECT_EQ(1U, s.count); | 
|  |  | 
|  | s = sample.Extract(/*disable=*/false); | 
|  | EXPECT_EQ(0U, s.bucket); | 
|  | EXPECT_EQ(0U, s.count); | 
|  | } | 
|  |  | 
|  | TEST(SingleSampleTest, Disable) { | 
|  | AtomicSingleSample sample; | 
|  | EXPECT_EQ(0U, sample.Extract(/*disable=*/false).count); | 
|  | EXPECT_FALSE(sample.IsDisabled()); | 
|  |  | 
|  | ASSERT_TRUE(sample.Accumulate(9, 1)); | 
|  | EXPECT_EQ(1U, sample.Extract(/*disable=*/true).count); | 
|  | EXPECT_TRUE(sample.IsDisabled()); | 
|  |  | 
|  | ASSERT_FALSE(sample.Accumulate(9, 1)); | 
|  | EXPECT_EQ(0U, sample.Extract(/*disable=*/false).count); | 
|  | EXPECT_FALSE(sample.IsDisabled()); | 
|  | } | 
|  |  | 
|  | TEST(SingleSampleTest, Accumulate) { | 
|  | AtomicSingleSample sample; | 
|  |  | 
|  | ASSERT_TRUE(sample.Accumulate(9, 1)); | 
|  | ASSERT_TRUE(sample.Accumulate(9, 2)); | 
|  | ASSERT_TRUE(sample.Accumulate(9, 4)); | 
|  | EXPECT_EQ(7U, sample.Extract(/*disable=*/false).count); | 
|  |  | 
|  | ASSERT_TRUE(sample.Accumulate(9, 4)); | 
|  | ASSERT_TRUE(sample.Accumulate(9, -2)); | 
|  | ASSERT_TRUE(sample.Accumulate(9, 1)); | 
|  | EXPECT_EQ(3U, sample.Extract(/*disable=*/false).count); | 
|  | } | 
|  |  | 
|  | TEST(SingleSampleTest, Overflow) { | 
|  | AtomicSingleSample sample; | 
|  |  | 
|  | ASSERT_TRUE(sample.Accumulate(9, 1)); | 
|  | ASSERT_FALSE(sample.Accumulate(9, -2)); | 
|  | EXPECT_EQ(1U, sample.Extract(/*disable=*/false).count); | 
|  |  | 
|  | ASSERT_TRUE(sample.Accumulate(9, std::numeric_limits<uint16_t>::max())); | 
|  | ASSERT_FALSE(sample.Accumulate(9, 1)); | 
|  | EXPECT_EQ(std::numeric_limits<uint16_t>::max(), | 
|  | sample.Extract(/*disable=*/false).count); | 
|  | } | 
|  |  | 
|  | }  // namespace base |