You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
85 lines
2.3 KiB
85 lines
2.3 KiB
4 months ago
|
// 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
|