1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
|
// 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
|