blob: 3967ec8f51eb729b1fdb0dd8e310416e906b0212 [file] [log] [blame]
// Copyright 2016 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 "third_party/blink/renderer/platform/instrumentation/histogram.h"
#include "base/metrics/histogram_samples.h"
#include "base/test/test_mock_time_task_runner.h"
#include "testing/gtest/include/gtest/gtest.h"
namespace blink {
class TestCustomCountHistogram : public CustomCountHistogram {
public:
TestCustomCountHistogram(const char* name,
base::HistogramBase::Sample min,
base::HistogramBase::Sample max,
int32_t bucket_count)
: CustomCountHistogram(name, min, max, bucket_count) {}
base::HistogramBase* Histogram() { return histogram_; }
};
class ScopedUsHistogramTimerTest : public testing::Test {
public:
void SetUp() override {
test_task_runner_ = base::MakeRefCounted<base::TestMockTimeTaskRunner>();
}
protected:
scoped_refptr<base::TestMockTimeTaskRunner> test_task_runner_;
};
TEST_F(ScopedUsHistogramTimerTest, Basic) {
TestCustomCountHistogram scoped_us_counter("ScopedUsHistogramTimerTest.Basic",
0, 10000000, 50);
{
ScopedUsHistogramTimer timer(scoped_us_counter,
test_task_runner_->GetMockTickClock());
test_task_runner_->FastForwardBy(base::TimeDelta::FromMilliseconds(500));
}
// 500ms == 500000us
EXPECT_EQ(500000, scoped_us_counter.Histogram()->SnapshotSamples()->sum());
}
TEST_F(ScopedUsHistogramTimerTest, BasicHighRes) {
TestCustomCountHistogram scoped_us_counter(
"ScopedHighResUsHistogramTimerTest.Basic", 0, 10000000, 50);
{
ScopedHighResUsHistogramTimer timer(scoped_us_counter,
test_task_runner_->GetMockTickClock());
test_task_runner_->FastForwardBy(base::TimeDelta::FromMilliseconds(500));
}
int64_t expected = base::TimeTicks::IsHighResolution() ? 500000 : 0;
EXPECT_EQ(expected, scoped_us_counter.Histogram()->SnapshotSamples()->sum());
}
} // namespace blink