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 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124
|
// Copyright 2017 The Chromium Authors
// 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);
ASSERT_TRUE(sample.Accumulate(9, 1));
s = sample.Load();
EXPECT_EQ(9U, s.bucket);
EXPECT_EQ(2U, s.count);
}
TEST(SingleSampleTest, Extract) {
AtomicSingleSample sample;
ASSERT_TRUE(sample.Accumulate(9, 1));
SingleSample s = sample.Extract();
EXPECT_EQ(9U, s.bucket);
EXPECT_EQ(1U, s.count);
s = sample.Extract();
EXPECT_EQ(0U, s.bucket);
EXPECT_EQ(0U, s.count);
ASSERT_TRUE(sample.Accumulate(1, 2));
s = sample.Extract();
EXPECT_EQ(1U, s.bucket);
EXPECT_EQ(2U, s.count);
}
TEST(SingleSampleTest, Disable) {
AtomicSingleSample sample;
EXPECT_EQ(0U, sample.Extract().count);
EXPECT_FALSE(sample.IsDisabled());
ASSERT_TRUE(sample.Accumulate(9, 1));
EXPECT_EQ(1U, sample.ExtractAndDisable().count);
EXPECT_TRUE(sample.IsDisabled());
ASSERT_FALSE(sample.Accumulate(9, 1));
EXPECT_EQ(0U, sample.Extract().count);
// The sample should still be disabled.
EXPECT_TRUE(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));
ASSERT_FALSE(sample.Accumulate(10, 1));
EXPECT_EQ(7U, sample.Extract().count);
ASSERT_TRUE(sample.Accumulate(9, 4));
ASSERT_TRUE(sample.Accumulate(9, -2));
ASSERT_TRUE(sample.Accumulate(9, 1));
ASSERT_FALSE(sample.Accumulate(10, 1));
EXPECT_EQ(3U, sample.Extract().count);
}
TEST(SingleSampleTest, Overflow) {
AtomicSingleSample sample;
ASSERT_TRUE(sample.Accumulate(9, 1));
ASSERT_FALSE(sample.Accumulate(9, -2));
EXPECT_EQ(1U, sample.Extract().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().count);
}
TEST(HistogramSamplesTest, WriteAsciiBucketGraph) {
constexpr int kLineLength = 72;
constexpr size_t kOutputSize = kLineLength + 1;
std::string output;
HistogramSamples::WriteAsciiBucketGraph(0.0, kLineLength, &output);
ASSERT_EQ(output.size(), kOutputSize);
output.clear();
HistogramSamples::WriteAsciiBucketGraph(-1.0, kLineLength, &output);
ASSERT_EQ(output.size(), kOutputSize);
output.clear();
HistogramSamples::WriteAsciiBucketGraph(kLineLength - 1, kLineLength,
&output);
ASSERT_EQ(output.size(), kOutputSize);
output.clear();
HistogramSamples::WriteAsciiBucketGraph(kLineLength, kLineLength, &output);
ASSERT_EQ(output.size(), kOutputSize);
output.clear();
HistogramSamples::WriteAsciiBucketGraph(kLineLength + 1, kLineLength,
&output);
ASSERT_EQ(output.size(), kOutputSize + 1);
}
} // namespace base
|