diff options
author | mazda@chromium.org <mazda@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2012-08-26 11:59:04 +0000 |
---|---|---|
committer | mazda@chromium.org <mazda@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2012-08-26 11:59:04 +0000 |
commit | 0518d0dde990e5382c94bde61e10cd3f3bbf7c27 (patch) | |
tree | 7bbe180593b3f2456ae4c4c842a1575a3e3b7cf1 /ash/drag_drop/drag_drop_tracker_unittest.cc | |
parent | 7f219e315a3b6e6b262f75313f52b555632d9317 (diff) | |
download | chromium_src-0518d0dde990e5382c94bde61e10cd3f3bbf7c27.zip chromium_src-0518d0dde990e5382c94bde61e10cd3f3bbf7c27.tar.gz chromium_src-0518d0dde990e5382c94bde61e10cd3f3bbf7c27.tar.bz2 |
Support Drag and Drop across displays.
This CL introduces DragDropTracker, which
- Makes a dummy window capture events while dragging an item, and
- Dispatches mouse events to the window at the pointer location in DragDropController::PreHandleMouseEvent.
BUG=136817
Review URL: https://chromiumcodereview.appspot.com/10855159
git-svn-id: svn://svn.chromium.org/chrome/trunk/src@153401 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'ash/drag_drop/drag_drop_tracker_unittest.cc')
-rw-r--r-- | ash/drag_drop/drag_drop_tracker_unittest.cc | 212 |
1 files changed, 212 insertions, 0 deletions
diff --git a/ash/drag_drop/drag_drop_tracker_unittest.cc b/ash/drag_drop/drag_drop_tracker_unittest.cc new file mode 100644 index 0000000..ddc75ba --- /dev/null +++ b/ash/drag_drop/drag_drop_tracker_unittest.cc @@ -0,0 +1,212 @@ +// Copyright (c) 2012 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 "ash/drag_drop/drag_drop_tracker.h" + +#include "ash/shell.h" +#include "ash/shell_window_ids.h" +#include "ash/test/ash_test_base.h" +#include "base/memory/scoped_ptr.h" +#include "ui/aura/root_window.h" +#include "ui/aura/test/test_windows.h" +#include "ui/aura/window.h" + +namespace ash { +namespace test { + +class DragDropTrackerTest : public test::AshTestBase { + public: + virtual void SetUp() OVERRIDE { + AshTestBase::SetUp(); + UpdateDisplay("0+0-200x200,0+201-200x200"); + } + + static aura::Window* CreateTestWindow(const gfx::Rect& bounds, + aura::Window* parent) { + static int window_id = 0; + return aura::test::CreateTestWindowWithDelegate( + new aura::test::TestWindowDelegate, + window_id++, + bounds, + parent); + } + + static aura::Window* GetTarget(aura::RootWindow* root_window, + const gfx::Point& location) { + scoped_ptr<internal::DragDropTracker> tracker( + new internal::DragDropTracker(root_window)); + ui::MouseEvent e(ui::ET_MOUSE_DRAGGED, + location, + location, + ui::EF_NONE); + aura::Window* target = tracker->GetTarget(e); + return target; + } + + static ui::MouseEvent* ConvertMouseEvent(aura::RootWindow* root_window, + aura::Window* target, + const ui::MouseEvent& event) { + scoped_ptr<internal::DragDropTracker> tracker( + new internal::DragDropTracker(root_window)); + ui::MouseEvent* converted = tracker->ConvertMouseEvent(target, event); + return converted; + } +}; + +// TODO(mazda): Remove this once ash/wm/coordinate_conversion.h supports +// non-X11 platforms. +#if defined(USE_X11) +#define MAYBE_GetTarget GetTarget +#else +#define MAYBE_GetTarget DISABLED_GetTarget +#endif + +TEST_F(DragDropTrackerTest, MAYBE_GetTarget) { + Shell::RootWindowList root_windows = Shell::GetAllRootWindows(); + EXPECT_EQ(2U, root_windows.size()); + + aura::Window* default_container0 = + ash::Shell::GetContainer(root_windows[0], + ash::internal::kShellWindowId_DefaultContainer); + EXPECT_TRUE(NULL != default_container0); + + scoped_ptr<aura::Window> window0( + CreateTestWindow(gfx::Rect(0, 0, 100, 100), default_container0)); + window0->Show(); + + aura::Window* default_container1 = + ash::Shell::GetContainer(root_windows[1], + ash::internal::kShellWindowId_DefaultContainer); + EXPECT_TRUE(NULL != default_container1); + + scoped_ptr<aura::Window> window1( + CreateTestWindow(gfx::Rect(100, 100, 100, 100), default_container1)); + window1->Show(); + + // Start tracking from the RootWindow0 and check the point on RootWindow0 that + // |window0| covers. + EXPECT_EQ(window0.get(), GetTarget(root_windows[0], gfx::Point(50, 50))); + + // Start tracking from the RootWindow0 and check the point on RootWindow0 that + // neither |window0| nor |window1| covers. + EXPECT_NE(window0.get(), GetTarget(root_windows[0], gfx::Point(150, 150))); + EXPECT_NE(window1.get(), GetTarget(root_windows[0], gfx::Point(150, 150))); + + // Start tracking from the RootWindow0 and check the point on RootWindow1 that + // |window1| covers. + EXPECT_EQ(window1.get(), GetTarget(root_windows[0], gfx::Point(150, 350))); + + // Start tracking from the RootWindow0 and check the point on RootWindow1 that + // neither |window0| nor |window1| covers. + EXPECT_NE(window0.get(), GetTarget(root_windows[0], gfx::Point(50, 250))); + EXPECT_NE(window1.get(), GetTarget(root_windows[0], gfx::Point(50, 250))); + + // Start tracking from the RootWindow1 and check the point on RootWindow0 that + // |window0| covers. + EXPECT_EQ(window0.get(), GetTarget(root_windows[1], gfx::Point(50, -150))); + + // Start tracking from the RootWindow1 and check the point on RootWindow0 that + // neither |window0| nor |window1| covers. + EXPECT_NE(window0.get(), GetTarget(root_windows[1], gfx::Point(150, -50))); + EXPECT_NE(window1.get(), GetTarget(root_windows[1], gfx::Point(150, -50))); + + // Start tracking from the RootWindow1 and check the point on RootWindow1 that + // |window1| covers. + EXPECT_EQ(window1.get(), GetTarget(root_windows[1], gfx::Point(150, 150))); + + // Start tracking from the RootWindow1 and check the point on RootWindow1 that + // neither |window0| nor |window1| covers. + EXPECT_NE(window0.get(), GetTarget(root_windows[1], gfx::Point(50, 50))); + EXPECT_NE(window1.get(), GetTarget(root_windows[1], gfx::Point(50, 50))); +} + +// TODO(mazda): Remove this once ash/wm/coordinate_conversion.h supports +// non-X11 platforms. +#if defined(USE_X11) +#define MAYBE_ConvertMouseEvent ConvertMouseEvent +#else +#define MAYBE_ConvertMouseEvent DISABLED_ConvertMouseEvent +#endif + +TEST_F(DragDropTrackerTest, MAYBE_ConvertMouseEvent) { + Shell::RootWindowList root_windows = Shell::GetAllRootWindows(); + EXPECT_EQ(2U, root_windows.size()); + + aura::Window* default_container0 = + ash::Shell::GetContainer(root_windows[0], + ash::internal::kShellWindowId_DefaultContainer); + EXPECT_TRUE(NULL != default_container0); + + scoped_ptr<aura::Window> window0( + CreateTestWindow(gfx::Rect(0, 0, 100, 100), default_container0)); + window0->Show(); + + aura::Window* default_container1 = + ash::Shell::GetContainer(root_windows[1], + ash::internal::kShellWindowId_DefaultContainer); + EXPECT_TRUE(NULL != default_container1); + + scoped_ptr<aura::Window> window1( + CreateTestWindow(gfx::Rect(100, 100, 100, 100), default_container1)); + window1->Show(); + + // Start tracking from the RootWindow0 and converts the mouse event into + // |window0|'s coodinates. + ui::MouseEvent original00(ui::ET_MOUSE_DRAGGED, + gfx::Point(50, 50), + gfx::Point(50, 50), + ui::EF_NONE); + scoped_ptr<ui::MouseEvent> converted00(ConvertMouseEvent(root_windows[0], + window0.get(), + original00)); + EXPECT_EQ(original00.type(), converted00->type()); + EXPECT_EQ(gfx::Point(50, 50), converted00->location()); + EXPECT_EQ(gfx::Point(50, 50), converted00->root_location()); + EXPECT_EQ(original00.flags(), converted00->flags()); + + // Start tracking from the RootWindow0 and converts the mouse event into + // |window1|'s coodinates. + ui::MouseEvent original01(ui::ET_MOUSE_DRAGGED, + gfx::Point(150, 350), + gfx::Point(150, 350), + ui::EF_NONE); + scoped_ptr<ui::MouseEvent> converted01(ConvertMouseEvent(root_windows[0], + window1.get(), + original01)); + EXPECT_EQ(original01.type(), converted01->type()); + EXPECT_EQ(gfx::Point(50, 50), converted01->location()); + EXPECT_EQ(gfx::Point(150, 150), converted01->root_location()); + EXPECT_EQ(original01.flags(), converted01->flags()); + + // Start tracking from the RootWindow1 and converts the mouse event into + // |window0|'s coodinates. + ui::MouseEvent original10(ui::ET_MOUSE_DRAGGED, + gfx::Point(50, -150), + gfx::Point(50, -150), + ui::EF_NONE); + scoped_ptr<ui::MouseEvent> converted10(ConvertMouseEvent(root_windows[1], + window0.get(), + original10)); + EXPECT_EQ(original10.type(), converted10->type()); + EXPECT_EQ(gfx::Point(50, 50), converted10->location()); + EXPECT_EQ(gfx::Point(50, 50), converted10->root_location()); + EXPECT_EQ(original10.flags(), converted10->flags()); + + // Start tracking from the RootWindow1 and converts the mouse event into + // |window1|'s coodinates. + ui::MouseEvent original11(ui::ET_MOUSE_DRAGGED, + gfx::Point(150, 150), + gfx::Point(150, 150), + ui::EF_NONE); + scoped_ptr<ui::MouseEvent> converted11(ConvertMouseEvent(root_windows[1], + window1.get(), + original11)); + EXPECT_EQ(original11.type(), converted11->type()); + EXPECT_EQ(gfx::Point(50, 50), converted11->location()); + EXPECT_EQ(gfx::Point(150, 150), converted11->root_location()); + EXPECT_EQ(original11.flags(), converted11->flags()); +} + +} // namespace test +} // namespace aura |