| Index: media/base/user_input_monitor_unittest.cc
|
| diff --git a/media/base/user_input_monitor_unittest.cc b/media/base/user_input_monitor_unittest.cc
|
| new file mode 100644
|
| index 0000000000000000000000000000000000000000..1b0fb2d5a84990272b02d34262a70b776d36f9fb
|
| --- /dev/null
|
| +++ b/media/base/user_input_monitor_unittest.cc
|
| @@ -0,0 +1,116 @@
|
| +// Copyright 2013 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/basictypes.h"
|
| +#include "base/logging.h"
|
| +#include "base/memory/scoped_ptr.h"
|
| +#include "base/message_loop/message_loop.h"
|
| +#include "base/run_loop.h"
|
| +#include "media/base/keyboard_event_counter.h"
|
| +#include "media/base/user_input_monitor.h"
|
| +#include "testing/gmock/include/gmock/gmock.h"
|
| +#include "testing/gtest/include/gtest/gtest.h"
|
| +#include "third_party/skia/include/core/SkPoint.h"
|
| +
|
| +namespace media {
|
| +
|
| +class MockMouseListener : public UserInputMonitor::MouseEventListener {
|
| + public:
|
| + MOCK_METHOD1(OnMouseMoved, void(const SkIPoint& position));
|
| +
|
| + virtual ~MockMouseListener() {}
|
| +};
|
| +
|
| +class UserInputMonitorForTest : public UserInputMonitor {
|
| + public:
|
| + UserInputMonitorForTest() {}
|
| + virtual ~UserInputMonitorForTest() {}
|
| +
|
| + virtual size_t GetKeyPressCount() const OVERRIDE {
|
| + return counter_.GetKeyPressCount();
|
| + }
|
| +
|
| + void EmulateMouseEvent(const SkIPoint& position) {
|
| + UserInputMonitor::OnMouseEvent(position);
|
| + }
|
| +
|
| + void EmulateKeyboardEvent(ui::EventType event, ui::KeyboardCode key_code) {
|
| + counter_.OnKeyboardEvent(event, key_code);
|
| + }
|
| +
|
| + private:
|
| + virtual void StartMouseMonitoring() OVERRIDE {}
|
| + virtual void StopMouseMonitoring() OVERRIDE {}
|
| + virtual void StartKeyboardMonitoring() OVERRIDE { counter_.Reset(); }
|
| + virtual void StopKeyboardMonitoring() OVERRIDE {}
|
| +
|
| + KeyboardEventCounter counter_;
|
| +};
|
| +
|
| +TEST(UserInputMonitorTest, MouseEvent) {
|
| + UserInputMonitorForTest monitor;
|
| + MockMouseListener listener;
|
| +
|
| + monitor.AddMouseListener(&listener);
|
| +
|
| + SkIPoint pos(SkIPoint::Make(100, 100));
|
| + EXPECT_CALL(listener, OnMouseMoved(pos));
|
| + monitor.EmulateMouseEvent(pos);
|
| +
|
| + monitor.RemoveMouseListener(&listener);
|
| +}
|
| +
|
| +TEST(UserInputMonitorTest, KeyPressCounter) {
|
| + UserInputMonitorForTest monitor;
|
| +
|
| + monitor.EnableKeyPressMonitoring();
|
| + EXPECT_EQ(0u, monitor.GetKeyPressCount());
|
| +
|
| + monitor.EmulateKeyboardEvent(ui::ET_KEY_PRESSED, ui::VKEY_0);
|
| + EXPECT_EQ(1u, monitor.GetKeyPressCount());
|
| +
|
| + // Holding the same key without releasing it does not increase the count.
|
| + monitor.EmulateKeyboardEvent(ui::ET_KEY_PRESSED, ui::VKEY_0);
|
| + EXPECT_EQ(1u, monitor.GetKeyPressCount());
|
| +
|
| + // Releasing the key does not affect the total count.
|
| + monitor.EmulateKeyboardEvent(ui::ET_KEY_RELEASED, ui::VKEY_0);
|
| + EXPECT_EQ(1u, monitor.GetKeyPressCount());
|
| +
|
| + monitor.EmulateKeyboardEvent(ui::ET_KEY_PRESSED, ui::VKEY_0);
|
| + monitor.EmulateKeyboardEvent(ui::ET_KEY_RELEASED, ui::VKEY_0);
|
| + EXPECT_EQ(2u, monitor.GetKeyPressCount());
|
| + monitor.DisableKeyPressMonitoring();
|
| +}
|
| +
|
| +#ifndef DISABLE_USER_INPUT_MONITOR
|
| +TEST(UserInputMonitorTest, CreatePlatformSpecific) {
|
| +#if defined(OS_LINUX)
|
| + base::MessageLoop message_loop(base::MessageLoop::TYPE_IO);
|
| +#else
|
| + base::MessageLoop message_loop(base::MessageLoop::TYPE_UI);
|
| +#endif // defined(OS_LINUX)
|
| +
|
| + base::RunLoop run_loop_;
|
| + scoped_ptr<UserInputMonitor> monitor = UserInputMonitor::Create(
|
| + message_loop.message_loop_proxy(), message_loop.message_loop_proxy());
|
| +
|
| + MockMouseListener listener;
|
| + // Ignore any callbacks.
|
| + EXPECT_CALL(listener, OnMouseMoved(testing::_)).Times(testing::AnyNumber());
|
| +
|
| +#if !defined(OS_MACOSX)
|
| + monitor->AddMouseListener(&listener);
|
| + monitor->RemoveMouseListener(&listener);
|
| +#endif // !define(OS_MACOSX)
|
| +
|
| + monitor->EnableKeyPressMonitoring();
|
| + monitor->DisableKeyPressMonitoring();
|
| +
|
| + // Must wait for all tasks to finish before destroying |monitor|.
|
| + run_loop_.RunUntilIdle();
|
| +}
|
| +#endif // DISABLE_USER_INPUT_MONITOR
|
| +
|
| +} // namespace media
|
|
|