| Index: components/tracing/child_trace_message_filter_unittest.cc
|
| diff --git a/components/tracing/child_trace_message_filter_unittest.cc b/components/tracing/child_trace_message_filter_unittest.cc
|
| new file mode 100644
|
| index 0000000000000000000000000000000000000000..75d1ad811a59af27fa389d020965ceb732c07bd9
|
| --- /dev/null
|
| +++ b/components/tracing/child_trace_message_filter_unittest.cc
|
| @@ -0,0 +1,87 @@
|
| +// Copyright 2015 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 "components/tracing/child_trace_message_filter.h"
|
| +
|
| +#include "base/memory/ref_counted.h"
|
| +#include "base/memory/scoped_ptr.h"
|
| +#include "base/message_loop/message_loop.h"
|
| +#include "components/tracing/tracing_messages.h"
|
| +#include "ipc/ipc_message.h"
|
| +#include "ipc/ipc_sender.h"
|
| +#include "testing/gmock/include/gmock/gmock.h"
|
| +#include "testing/gtest/include/gtest/gtest.h"
|
| +
|
| +namespace tracing {
|
| +
|
| +class FakeSender : public IPC::Sender {
|
| + public:
|
| + FakeSender() {}
|
| +
|
| + ~FakeSender() override {}
|
| +
|
| + bool Send(IPC::Message* msg) override {
|
| + last_message_.reset(msg);
|
| + return true;
|
| + }
|
| +
|
| + scoped_ptr<IPC::Message> last_message_;
|
| +};
|
| +
|
| +class ChildTraceMessageFilterTest : public testing::Test {
|
| + public:
|
| + ChildTraceMessageFilterTest() {
|
| + message_filter_ =
|
| + new tracing::ChildTraceMessageFilter(message_loop_.task_runner().get());
|
| + message_filter_->SetSenderForTesting(&fake_sender_);
|
| + }
|
| +
|
| + void OnSetUMACallback(const std::string& histogram,
|
| + int low,
|
| + int high,
|
| + bool repeat) {
|
| + fake_sender_.last_message_.reset();
|
| + message_filter_->OnSetUMACallback(histogram, low, high, repeat);
|
| + }
|
| +
|
| + base::MessageLoop message_loop_;
|
| + FakeSender fake_sender_;
|
| + scoped_refptr<tracing::ChildTraceMessageFilter> message_filter_;
|
| +};
|
| +
|
| +TEST_F(ChildTraceMessageFilterTest, TestHistogramDoesNotTrigger) {
|
| + LOCAL_HISTOGRAM_COUNTS("foo1", 10);
|
| +
|
| + OnSetUMACallback("foo1", 20000, 25000, true);
|
| +
|
| + message_loop_.RunUntilIdle();
|
| +
|
| + EXPECT_FALSE(fake_sender_.last_message_);
|
| +}
|
| +
|
| +TEST_F(ChildTraceMessageFilterTest, TestHistogramTriggers) {
|
| + LOCAL_HISTOGRAM_COUNTS("foo2", 2);
|
| +
|
| + OnSetUMACallback("foo2", 1, 3, true);
|
| +
|
| + message_loop_.RunUntilIdle();
|
| +
|
| + EXPECT_TRUE(fake_sender_.last_message_);
|
| + EXPECT_EQ(fake_sender_.last_message_->type(),
|
| + TracingHostMsg_TriggerBackgroundTrace::ID);
|
| +}
|
| +
|
| +TEST_F(ChildTraceMessageFilterTest, TestHistogramAborts) {
|
| + LOCAL_HISTOGRAM_COUNTS("foo3", 10);
|
| +
|
| + OnSetUMACallback("foo3", 1, 3, false);
|
| +
|
| + message_loop_.RunUntilIdle();
|
| +
|
| + EXPECT_TRUE(fake_sender_.last_message_);
|
| + EXPECT_EQ(fake_sender_.last_message_->type(),
|
| + TracingHostMsg_AbortBackgroundTrace::ID);
|
| +}
|
| +
|
| +} // namespace tracing
|
|
|