Index: chrome/browser/ui/panels/panel_drag_browsertest.cc |
diff --git a/chrome/browser/ui/panels/panel_drag_browsertest.cc b/chrome/browser/ui/panels/panel_drag_browsertest.cc |
new file mode 100644 |
index 0000000000000000000000000000000000000000..b0637b5f9af25d30bf9475e20378f8c540f468e4 |
--- /dev/null |
+++ b/chrome/browser/ui/panels/panel_drag_browsertest.cc |
@@ -0,0 +1,543 @@ |
+// 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 "chrome/browser/ui/panels/base_panel_browser_test.h" |
+#include "chrome/browser/ui/panels/detached_panel_strip.h" |
+#include "chrome/browser/ui/panels/docked_panel_strip.h" |
+#include "chrome/browser/ui/panels/overflow_panel_strip.h" |
+#include "chrome/browser/ui/panels/native_panel.h" |
+#include "chrome/browser/ui/panels/panel.h" |
+#include "chrome/browser/ui/panels/panel_drag_controller.h" |
+#include "chrome/browser/ui/panels/panel_manager.h" |
+ |
+class PanelDragBrowserTest : public BasePanelBrowserTest { |
jennb
2012/03/01 00:33:38
Is this file supposed to contain all panel draggin
jianli
2012/03/02 22:42:43
Yes. I will move other dragging related tests to t
|
+ public: |
+ PanelDragBrowserTest() : BasePanelBrowserTest() { |
+ } |
+ |
+ virtual ~PanelDragBrowserTest() { |
+ } |
+ |
+ virtual void SetUpOnMainThread() OVERRIDE { |
+ BasePanelBrowserTest::SetUpOnMainThread(); |
+ |
+ // All the tests here assume 800x600 work area. Do the check now. |
+ DCHECK(PanelManager::GetInstance()->work_area().width() == 800); |
+ DCHECK(PanelManager::GetInstance()->work_area().height() == 600); |
+ } |
+ |
+ Panel* CreateDockedPanel(const std::string& name, const gfx::Rect& bounds) { |
+ Panel* panel = CreatePanelWithBounds(name, bounds); |
+ EXPECT_EQ(PanelStrip::DOCKED, panel->panel_strip()->type()); |
+ return panel; |
+ } |
+ |
+ Panel* CreateDetachedPanel(const std::string& name, const gfx::Rect& bounds) { |
+ Panel* panel = CreatePanelWithBounds(name, bounds); |
+ panel->MoveToStrip(panel->manager()->detached_strip()); |
+ panel->SetPanelBounds(bounds); |
+ EXPECT_EQ(PanelStrip::DETACHED, panel->panel_strip()->type()); |
+ return panel; |
+ } |
+ |
+ Panel* CreateOverflowPanel(const std::string& name, const gfx::Rect& bounds) { |
+ CreatePanelParams params(name, bounds, SHOW_AS_INACTIVE); |
+ Panel* panel = CreatePanelWithParams(params); |
+ WaitForLayoutModeChanged(panel, PanelStrip::IN_OVERFLOW); |
+ EXPECT_EQ(PanelStrip::IN_OVERFLOW, panel->panel_strip()->type()); |
jennb
2012/03/01 00:33:38
Redundant as WaitForLayoutModeChanged already chec
jianli
2012/03/02 22:42:43
Just want to be safe because only after you read W
jennb
2012/03/03 02:19:33
Should be removed as it deviates from the pattern
|
+ return panel; |
+ } |
+ |
+ void DragPanelAndFinish(Panel* panel, const gfx::Point& delta) { |
+ scoped_ptr<NativePanelTesting> panel_testing( |
+ NativePanelTesting::Create(panel->native_panel())); |
+ gfx::Point mouse_location(panel->GetBounds().origin()); |
+ panel_testing->PressLeftMouseButtonTitlebar(mouse_location); |
+ panel_testing->DragTitlebar(mouse_location.Add(delta)); |
+ panel_testing->FinishDragTitlebar(); |
+ } |
+ |
+ void DragPanelAndCancel(Panel* panel, const gfx::Point& delta) { |
+ scoped_ptr<NativePanelTesting> panel_testing( |
+ NativePanelTesting::Create(panel->native_panel())); |
+ gfx::Point mouse_location(panel->GetBounds().origin()); |
+ panel_testing->PressLeftMouseButtonTitlebar(mouse_location); |
+ panel_testing->DragTitlebar(mouse_location.Add(delta)); |
+ panel_testing->CancelDragTitlebar(); |
+ } |
+}; |
+ |
+IN_PROC_BROWSER_TEST_F(PanelDragBrowserTest, Detach) { |
+ PanelManager* panel_manager = PanelManager::GetInstance(); |
+ DockedPanelStrip* docked_strip = panel_manager->docked_strip(); |
+ DetachedPanelStrip* detached_strip = panel_manager->detached_strip(); |
+ |
+ gfx::Point small_drag_delta(-5, -10); |
jennb
2012/03/01 00:33:38
Could you write these tests in such a way that the
jianli
2012/03/02 22:42:43
Done.
|
+ gfx::Point drag_delta_to_detach(-5, -150); |
+ |
+ // Create one docked panel. |
+ Panel* panel = CreateDockedPanel("1", gfx::Rect(0, 0, 100, 100)); |
+ ASSERT_EQ(1, docked_strip->num_panels()); |
+ ASSERT_EQ(0, detached_strip->num_panels()); |
+ |
+ gfx::Rect panel_old_bounds = panel->GetBounds(); |
+ |
+ // Press on title-bar. |
+ scoped_ptr<NativePanelTesting> panel_testing( |
+ NativePanelTesting::Create(panel->native_panel())); |
+ gfx::Point mouse_location(panel->GetBounds().origin()); |
+ panel_testing->PressLeftMouseButtonTitlebar(mouse_location); |
+ |
+ // Drag up the panel in a small offset that does not trigger the detach. |
+ // Expect that the panel is still docked and only x coordinate of its position |
+ // is changed. |
+ mouse_location = mouse_location.Add(small_drag_delta); |
+ panel_testing->DragTitlebar(mouse_location); |
+ ASSERT_EQ(1, docked_strip->num_panels()); |
+ ASSERT_EQ(0, detached_strip->num_panels()); |
+ EXPECT_EQ(PanelStrip::DOCKED, panel->panel_strip()->type()); |
+ gfx::Rect panel_new_bounds = panel_old_bounds; |
+ panel_new_bounds.Offset(small_drag_delta.x(), 0); |
+ EXPECT_EQ(panel_new_bounds, panel->GetBounds()); |
+ |
+ // Continue dragging up the panel in big offset that triggers the detach. |
+ // Expect that the panel is previewed as detached. |
+ mouse_location = mouse_location.Add(drag_delta_to_detach); |
+ panel_testing->DragTitlebar(mouse_location); |
+ ASSERT_EQ(0, docked_strip->num_panels()); |
+ ASSERT_EQ(1, detached_strip->num_panels()); |
+ EXPECT_EQ(PanelStrip::DETACHED, panel->panel_strip()->type()); |
+ panel_new_bounds.Offset(drag_delta_to_detach.x(), |
+ drag_delta_to_detach.y() + small_drag_delta.y()); |
+ EXPECT_EQ(panel_new_bounds, panel->GetBounds()); |
+ |
+ // Finish the drag. |
+ // Expect that the panel stays as detached. |
+ panel_testing->FinishDragTitlebar(); |
+ ASSERT_EQ(0, docked_strip->num_panels()); |
+ ASSERT_EQ(1, detached_strip->num_panels()); |
+ EXPECT_EQ(PanelStrip::DETACHED, panel->panel_strip()->type()); |
+ EXPECT_EQ(panel_new_bounds, panel->GetBounds()); |
+ |
+ panel_manager->CloseAll(); |
+} |
+ |
+IN_PROC_BROWSER_TEST_F(PanelDragBrowserTest, DetachAndCancel) { |
+ PanelManager* panel_manager = PanelManager::GetInstance(); |
+ DockedPanelStrip* docked_strip = panel_manager->docked_strip(); |
+ DetachedPanelStrip* detached_strip = panel_manager->detached_strip(); |
+ |
+ gfx::Point small_drag_delta(-5, -10); |
+ gfx::Point drag_delta_to_detach(-5, -150); |
+ |
+ // Create one docked panel. |
+ Panel* panel = CreateDockedPanel("1", gfx::Rect(0, 0, 100, 100)); |
+ ASSERT_EQ(1, docked_strip->num_panels()); |
+ ASSERT_EQ(0, detached_strip->num_panels()); |
+ |
+ gfx::Rect panel_old_bounds = panel->GetBounds(); |
+ |
+ // Press on title-bar. |
+ scoped_ptr<NativePanelTesting> panel_testing( |
+ NativePanelTesting::Create(panel->native_panel())); |
+ gfx::Point mouse_location(panel->GetBounds().origin()); |
+ panel_testing->PressLeftMouseButtonTitlebar(mouse_location); |
+ |
+ // Drag up the panel in a small offset that does not trigger the detach. |
+ // Expect that the panel is still docked and only x coordinate of its position |
+ // is changed. |
+ mouse_location = mouse_location.Add(small_drag_delta); |
+ panel_testing->DragTitlebar(mouse_location); |
+ ASSERT_EQ(1, docked_strip->num_panels()); |
+ ASSERT_EQ(0, detached_strip->num_panels()); |
+ EXPECT_EQ(PanelStrip::DOCKED, panel->panel_strip()->type()); |
+ gfx::Rect panel_new_bounds = panel_old_bounds; |
+ panel_new_bounds.Offset(small_drag_delta.x(), 0); |
+ EXPECT_EQ(panel_new_bounds, panel->GetBounds()); |
+ |
+ // Continue dragging up the panel in big offset that triggers the detach. |
+ // Expect that the panel is previewed as detached. |
+ mouse_location = mouse_location.Add(drag_delta_to_detach); |
+ panel_testing->DragTitlebar(mouse_location); |
+ ASSERT_EQ(0, docked_strip->num_panels()); |
+ ASSERT_EQ(1, detached_strip->num_panels()); |
+ EXPECT_EQ(PanelStrip::DETACHED, panel->panel_strip()->type()); |
+ panel_new_bounds.Offset(drag_delta_to_detach.x(), |
+ drag_delta_to_detach.y() + small_drag_delta.y()); |
+ EXPECT_EQ(panel_new_bounds, panel->GetBounds()); |
+ |
+ // Cancel the drag. |
+ // Expect that the panel is back as docked. |
+ panel_testing->CancelDragTitlebar(); |
+ ASSERT_EQ(1, docked_strip->num_panels()); |
+ ASSERT_EQ(0, detached_strip->num_panels()); |
+ EXPECT_EQ(PanelStrip::DOCKED, panel->panel_strip()->type()); |
+ EXPECT_EQ(panel_old_bounds, panel->GetBounds()); |
+ |
+ panel_manager->CloseAll(); |
+} |
+ |
+IN_PROC_BROWSER_TEST_F(PanelDragBrowserTest, Attach) { |
+ PanelManager* panel_manager = PanelManager::GetInstance(); |
+ DockedPanelStrip* docked_strip = panel_manager->docked_strip(); |
+ DetachedPanelStrip* detached_strip = panel_manager->detached_strip(); |
+ |
+ gfx::Point drag_delta_to_move_down(-5, 150); |
+ gfx::Point drag_delta_to_attach(-30, 45); |
+ |
+ // Create one detached panel. |
+ Panel* panel = CreateDetachedPanel("1", gfx::Rect(400, 300, 100, 100)); |
+ ASSERT_EQ(0, docked_strip->num_panels()); |
+ ASSERT_EQ(1, detached_strip->num_panels()); |
+ EXPECT_EQ(PanelStrip::DETACHED, panel->panel_strip()->type()); |
+ |
+ gfx::Rect panel_old_bounds = panel->GetBounds(); |
+ |
+ // Press on title-bar. |
+ scoped_ptr<NativePanelTesting> panel_testing( |
+ NativePanelTesting::Create(panel->native_panel())); |
+ gfx::Point mouse_location(panel->GetBounds().origin()); |
+ panel_testing->PressLeftMouseButtonTitlebar(mouse_location); |
+ |
+ // Drag down the panel but not close enough to the bottom of work area. |
+ // Expect that the panel is still detached. |
+ mouse_location = mouse_location.Add(drag_delta_to_move_down); |
+ panel_testing->DragTitlebar(mouse_location); |
+ ASSERT_EQ(0, docked_strip->num_panels()); |
+ ASSERT_EQ(1, detached_strip->num_panels()); |
+ EXPECT_EQ(PanelStrip::DETACHED, panel->panel_strip()->type()); |
+ gfx::Rect panel_new_bounds = panel_old_bounds; |
+ panel_new_bounds.Offset(drag_delta_to_move_down); |
+ EXPECT_EQ(panel_new_bounds, panel->GetBounds()); |
+ |
+ // Continue dragging down the panel to make it close enough to the bottom of |
+ // work area. |
+ // Expect that the panel is previewed as docked. |
+ mouse_location = mouse_location.Add(drag_delta_to_attach); |
+ panel_testing->DragTitlebar(mouse_location); |
+ ASSERT_EQ(1, docked_strip->num_panels()); |
+ ASSERT_EQ(0, detached_strip->num_panels()); |
+ EXPECT_EQ(PanelStrip::DOCKED, panel->panel_strip()->type()); |
+ panel_new_bounds.Offset(drag_delta_to_attach); |
+ EXPECT_EQ(panel_new_bounds, panel->GetBounds()); |
+ |
+ // Finish the drag. |
+ // Expect that the panel stays as docked and moves to the final position. |
+ panel_testing->FinishDragTitlebar(); |
+ ASSERT_EQ(1, docked_strip->num_panels()); |
+ ASSERT_EQ(0, detached_strip->num_panels()); |
+ EXPECT_EQ(PanelStrip::DOCKED, panel->panel_strip()->type()); |
+ panel_new_bounds.set_x( |
+ docked_strip->StartingRightPosition() - panel_new_bounds.width()); |
+ panel_new_bounds.set_y( |
+ docked_strip->display_area().bottom() - panel_new_bounds.height()); |
+ EXPECT_EQ(panel_new_bounds, panel->GetBounds()); |
+ |
+ panel_manager->CloseAll(); |
+} |
+ |
+IN_PROC_BROWSER_TEST_F(PanelDragBrowserTest, AttachAndCancel) { |
+ PanelManager* panel_manager = PanelManager::GetInstance(); |
+ DockedPanelStrip* docked_strip = panel_manager->docked_strip(); |
+ DetachedPanelStrip* detached_strip = panel_manager->detached_strip(); |
+ |
+ gfx::Point drag_delta_to_move_down(-5, 150); |
+ gfx::Point drag_delta_to_attach(-30, 45); |
+ |
+ // Create one detached panel. |
+ Panel* panel = CreateDetachedPanel("1", gfx::Rect(400, 300, 100, 100)); |
+ ASSERT_EQ(0, docked_strip->num_panels()); |
+ ASSERT_EQ(1, detached_strip->num_panels()); |
+ EXPECT_EQ(PanelStrip::DETACHED, panel->panel_strip()->type()); |
+ |
+ gfx::Rect panel_old_bounds = panel->GetBounds(); |
+ |
+ // Press on title-bar. |
+ scoped_ptr<NativePanelTesting> panel_testing( |
+ NativePanelTesting::Create(panel->native_panel())); |
+ gfx::Point mouse_location(panel->GetBounds().origin()); |
+ panel_testing->PressLeftMouseButtonTitlebar(mouse_location); |
+ |
+ // Drag down the panel but not close enough to the bottom of work area. |
+ // Expect that the panel is still detached. |
+ mouse_location = mouse_location.Add(drag_delta_to_move_down); |
+ panel_testing->DragTitlebar(mouse_location); |
+ ASSERT_EQ(0, docked_strip->num_panels()); |
+ ASSERT_EQ(1, detached_strip->num_panels()); |
+ EXPECT_EQ(PanelStrip::DETACHED, panel->panel_strip()->type()); |
+ gfx::Rect panel_new_bounds = panel_old_bounds; |
+ panel_new_bounds.Offset(drag_delta_to_move_down); |
+ EXPECT_EQ(panel_new_bounds, panel->GetBounds()); |
+ |
+ // Continue dragging down the panel to make it close enough to the bottom of |
+ // work area. |
+ // Expect that the panel is previewed as docked. |
+ mouse_location = mouse_location.Add(drag_delta_to_attach); |
+ panel_testing->DragTitlebar(mouse_location); |
+ ASSERT_EQ(1, docked_strip->num_panels()); |
+ ASSERT_EQ(0, detached_strip->num_panels()); |
+ EXPECT_EQ(PanelStrip::DOCKED, panel->panel_strip()->type()); |
+ panel_new_bounds.Offset(drag_delta_to_attach); |
+ EXPECT_EQ(panel_new_bounds, panel->GetBounds()); |
+ |
+ // Cancel the drag. |
+ // Expect that the panel is back as detached. |
+ panel_testing->CancelDragTitlebar(); |
+ ASSERT_EQ(0, docked_strip->num_panels()); |
+ ASSERT_EQ(1, detached_strip->num_panels()); |
+ EXPECT_EQ(PanelStrip::DETACHED, panel->panel_strip()->type()); |
+ EXPECT_EQ(panel_old_bounds, panel->GetBounds()); |
+ |
+ panel_manager->CloseAll(); |
+} |
+ |
+IN_PROC_BROWSER_TEST_F(PanelDragBrowserTest, DetachAttachAndCancel) { |
+ PanelManager* panel_manager = PanelManager::GetInstance(); |
+ DockedPanelStrip* docked_strip = panel_manager->docked_strip(); |
+ DetachedPanelStrip* detached_strip = panel_manager->detached_strip(); |
+ |
+ gfx::Point drag_delta_to_detach(-35, -150); |
+ gfx::Point drag_delta_to_reattach(-25, 145); |
+ gfx::Point drag_delta_to_detach_again(30, -200); |
+ |
+ // Create one docked panel. |
+ Panel* panel = CreateDockedPanel("1", gfx::Rect(0, 0, 100, 100)); |
+ ASSERT_EQ(1, docked_strip->num_panels()); |
+ ASSERT_EQ(0, detached_strip->num_panels()); |
+ |
+ gfx::Rect panel_old_bounds = panel->GetBounds(); |
+ |
+ // Press on title-bar. |
+ scoped_ptr<NativePanelTesting> panel_testing( |
+ NativePanelTesting::Create(panel->native_panel())); |
+ gfx::Point mouse_location(panel->GetBounds().origin()); |
+ panel_testing->PressLeftMouseButtonTitlebar(mouse_location); |
+ |
+ // Drag up the panel to trigger the detach. |
+ // Expect that the panel is previewed as detached. |
+ mouse_location = mouse_location.Add(drag_delta_to_detach); |
+ panel_testing->DragTitlebar(mouse_location); |
+ ASSERT_EQ(0, docked_strip->num_panels()); |
+ ASSERT_EQ(1, detached_strip->num_panels()); |
+ EXPECT_EQ(PanelStrip::DETACHED, panel->panel_strip()->type()); |
+ gfx::Rect panel_new_bounds = panel_old_bounds; |
+ panel_new_bounds.Offset(drag_delta_to_detach); |
+ EXPECT_EQ(panel_new_bounds, panel->GetBounds()); |
+ |
+ // Continue dragging down the panel to trigger the re-attach. |
+ mouse_location = mouse_location.Add(drag_delta_to_reattach); |
+ panel_testing->DragTitlebar(mouse_location); |
+ ASSERT_EQ(1, docked_strip->num_panels()); |
+ ASSERT_EQ(0, detached_strip->num_panels()); |
+ EXPECT_EQ(PanelStrip::DOCKED, panel->panel_strip()->type()); |
+ panel_new_bounds.Offset(drag_delta_to_reattach); |
+ EXPECT_EQ(panel_new_bounds, panel->GetBounds()); |
+ |
+ // Continue dragging up the panel to trigger the detach again. |
+ mouse_location = mouse_location.Add(drag_delta_to_detach_again); |
+ panel_testing->DragTitlebar(mouse_location); |
+ ASSERT_EQ(0, docked_strip->num_panels()); |
+ ASSERT_EQ(1, detached_strip->num_panels()); |
+ EXPECT_EQ(PanelStrip::DETACHED, panel->panel_strip()->type()); |
+ panel_new_bounds.Offset(drag_delta_to_detach_again); |
+ EXPECT_EQ(panel_new_bounds, panel->GetBounds()); |
+ |
+ // Cancel the drag. |
+ // Expect that the panel stays as docked. |
+ panel_testing->CancelDragTitlebar(); |
+ ASSERT_EQ(1, docked_strip->num_panels()); |
+ ASSERT_EQ(0, detached_strip->num_panels()); |
+ EXPECT_EQ(PanelStrip::DOCKED, panel->panel_strip()->type()); |
+ EXPECT_EQ(panel_old_bounds, panel->GetBounds()); |
+ |
+ panel_manager->CloseAll(); |
+} |
+ |
+IN_PROC_BROWSER_TEST_F(PanelDragBrowserTest, DetachInOverflow) { |
jennb
2012/03/01 00:33:38
s/InOverflow/WithOverflow ?
jianli
2012/03/02 22:42:43
Done.
|
+ PanelManager* panel_manager = PanelManager::GetInstance(); |
+ DockedPanelStrip* docked_strip = panel_manager->docked_strip(); |
+ DetachedPanelStrip* detached_strip = panel_manager->detached_strip(); |
+ OverflowPanelStrip* overflow_strip = panel_manager->overflow_strip(); |
+ |
+ gfx::Point drag_delta_to_detach(-5, -150); |
+ |
+ // Create some docked and overflow panels. |
+ // docked: P3 P2 P1 |
+ // overflow: P5 P4 |
+ Panel* panel1 = CreateDockedPanel("1", gfx::Rect(0, 0, 200, 100)); |
+ Panel* panel2 = CreateDockedPanel("2", gfx::Rect(0, 0, 200, 100)); |
+ Panel* panel3 = CreateDockedPanel("3", gfx::Rect(0, 0, 200, 100)); |
+ Panel* panel4 = CreateOverflowPanel("4", gfx::Rect(0, 0, 200, 100)); |
+ Panel* panel5 = CreateOverflowPanel("5", gfx::Rect(0, 0, 200, 100)); |
+ ASSERT_EQ(0, detached_strip->num_panels()); |
+ ASSERT_EQ(3, docked_strip->num_panels()); |
+ ASSERT_EQ(2, overflow_strip->num_panels()); |
+ |
+ gfx::Point docked_position1 = panel1->GetBounds().origin(); |
+ gfx::Point docked_position2 = panel2->GetBounds().origin(); |
+ gfx::Point docked_position3 = panel3->GetBounds().origin(); |
+ |
+ // Drag to detach the middle docked panel. |
+ // Expect to have: |
+ // detached: P2 |
+ // docked: P4 P3 P1 |
+ // overflow: P5 |
+ DragPanelAndFinish(panel2, drag_delta_to_detach); |
+ ASSERT_EQ(1, detached_strip->num_panels()); |
+ ASSERT_EQ(3, docked_strip->num_panels()); |
+ ASSERT_EQ(1, overflow_strip->num_panels()); |
+ EXPECT_EQ(PanelStrip::DOCKED, panel1->panel_strip()->type()); |
+ EXPECT_EQ(PanelStrip::DETACHED, panel2->panel_strip()->type()); |
+ EXPECT_EQ(PanelStrip::DOCKED, panel3->panel_strip()->type()); |
+ EXPECT_EQ(PanelStrip::DOCKED, panel4->panel_strip()->type()); |
+ EXPECT_EQ(PanelStrip::IN_OVERFLOW, panel5->panel_strip()->type()); |
+ EXPECT_EQ(docked_position1, panel1->GetBounds().origin()); |
+ gfx::Point panel2_new_position = docked_position2.Add(drag_delta_to_detach); |
+ EXPECT_EQ(panel2_new_position, panel2->GetBounds().origin()); |
+ EXPECT_EQ(docked_position2, panel3->GetBounds().origin()); |
+ EXPECT_EQ(docked_position3, panel4->GetBounds().origin()); |
+ |
+ // Drag to detach the left-most docked panel. |
+ // Expect to have: |
+ // detached: P2 P4 |
+ // docked: P5 P3 P1 |
+ DragPanelAndFinish(panel4, drag_delta_to_detach); |
+ ASSERT_EQ(2, detached_strip->num_panels()); |
+ ASSERT_EQ(3, docked_strip->num_panels()); |
+ ASSERT_EQ(0, overflow_strip->num_panels()); |
+ EXPECT_EQ(PanelStrip::DOCKED, panel1->panel_strip()->type()); |
+ EXPECT_EQ(PanelStrip::DETACHED, panel2->panel_strip()->type()); |
+ EXPECT_EQ(PanelStrip::DOCKED, panel3->panel_strip()->type()); |
+ EXPECT_EQ(PanelStrip::DETACHED, panel4->panel_strip()->type()); |
+ EXPECT_EQ(PanelStrip::DOCKED, panel5->panel_strip()->type()); |
+ EXPECT_EQ(docked_position1, panel1->GetBounds().origin()); |
+ EXPECT_EQ(panel2_new_position, panel2->GetBounds().origin()); |
+ EXPECT_EQ(docked_position2, panel3->GetBounds().origin()); |
+ gfx::Point panel4_new_position = docked_position3.Add(drag_delta_to_detach); |
+ EXPECT_EQ(panel4_new_position, panel4->GetBounds().origin()); |
+ EXPECT_EQ(docked_position3, panel5->GetBounds().origin()); |
+ |
+ // Drag to detach the right-most docked panel. |
+ // Expect to have: |
+ // detached: P1 P2 P4 |
+ // docked: P5 P3 |
+ DragPanelAndFinish(panel1, drag_delta_to_detach); |
+ ASSERT_EQ(3, detached_strip->num_panels()); |
+ ASSERT_EQ(2, docked_strip->num_panels()); |
+ ASSERT_EQ(0, overflow_strip->num_panels()); |
+ EXPECT_EQ(PanelStrip::DETACHED, panel1->panel_strip()->type()); |
+ EXPECT_EQ(PanelStrip::DETACHED, panel2->panel_strip()->type()); |
+ EXPECT_EQ(PanelStrip::DOCKED, panel3->panel_strip()->type()); |
+ EXPECT_EQ(PanelStrip::DETACHED, panel4->panel_strip()->type()); |
+ EXPECT_EQ(PanelStrip::DOCKED, panel5->panel_strip()->type()); |
+ gfx::Point panel1_new_position = docked_position1.Add(drag_delta_to_detach); |
+ EXPECT_EQ(panel1_new_position, panel1->GetBounds().origin()); |
+ EXPECT_EQ(panel2_new_position, panel2->GetBounds().origin()); |
+ EXPECT_EQ(docked_position1, panel3->GetBounds().origin()); |
+ EXPECT_EQ(panel4_new_position, panel4->GetBounds().origin()); |
+ EXPECT_EQ(docked_position2, panel5->GetBounds().origin()); |
+ |
+ panel_manager->CloseAll(); |
+} |
+ |
+IN_PROC_BROWSER_TEST_F(PanelDragBrowserTest, AttachInOverflow) { |
+ PanelManager* panel_manager = PanelManager::GetInstance(); |
+ DockedPanelStrip* docked_strip = panel_manager->docked_strip(); |
+ DetachedPanelStrip* detached_strip = panel_manager->detached_strip(); |
+ OverflowPanelStrip* overflow_strip = panel_manager->overflow_strip(); |
+ |
+ gfx::Point drag_delta_to_detach(-5, -150); |
+ |
+ // Create some detached, docked and overflow panels. |
+ // detached: P1 P2 P3 |
+ // docked: P6 P5 P4 |
+ // overflow: P7 |
+ Panel* panel1 = CreateDetachedPanel("1", gfx::Rect(100, 300, 200, 100)); |
+ Panel* panel2 = CreateDetachedPanel("2", gfx::Rect(200, 300, 200, 100)); |
+ Panel* panel3 = CreateDetachedPanel("3", gfx::Rect(400, 300, 200, 100)); |
+ Panel* panel4 = CreateDockedPanel("4", gfx::Rect(0, 0, 200, 100)); |
+ Panel* panel5 = CreateDockedPanel("5", gfx::Rect(0, 0, 200, 100)); |
+ Panel* panel6 = CreateDockedPanel("6", gfx::Rect(0, 0, 200, 100)); |
+ Panel* panel7 = CreateOverflowPanel("7", gfx::Rect(0, 0, 200, 100)); |
+ ASSERT_EQ(3, detached_strip->num_panels()); |
+ ASSERT_EQ(3, docked_strip->num_panels()); |
+ ASSERT_EQ(1, overflow_strip->num_panels()); |
+ |
+ gfx::Point detached_position1 = panel1->GetBounds().origin(); |
+ gfx::Point detached_position2 = panel2->GetBounds().origin(); |
+ gfx::Point detached_position3 = panel3->GetBounds().origin(); |
+ gfx::Point docked_position1 = panel4->GetBounds().origin(); |
+ gfx::Point docked_position2 = panel5->GetBounds().origin(); |
+ gfx::Point docked_position3 = panel6->GetBounds().origin(); |
+ |
+ // Drag to attach a detached panel between 2 docked panels. |
+ // Expect to have: |
+ // detached: P1 P2 |
+ // docked: P5 P3 P4 |
+ // overflow: P7 P6 |
+ gfx::Point drag_delta_to_attach( |
+ docked_position2.x() - detached_position3.x() + 10, 210); |
+ DragPanelAndFinish(panel3, drag_delta_to_attach); |
+ ASSERT_EQ(2, detached_strip->num_panels()); |
+ ASSERT_EQ(3, docked_strip->num_panels()); |
+ ASSERT_EQ(2, overflow_strip->num_panels()); |
+ EXPECT_EQ(PanelStrip::DETACHED, panel1->panel_strip()->type()); |
+ EXPECT_EQ(PanelStrip::DETACHED, panel2->panel_strip()->type()); |
+ EXPECT_EQ(PanelStrip::DOCKED, panel3->panel_strip()->type()); |
+ EXPECT_EQ(PanelStrip::DOCKED, panel4->panel_strip()->type()); |
+ EXPECT_EQ(PanelStrip::DOCKED, panel5->panel_strip()->type()); |
+ EXPECT_EQ(PanelStrip::IN_OVERFLOW, panel6->panel_strip()->type()); |
+ EXPECT_EQ(PanelStrip::IN_OVERFLOW, panel7->panel_strip()->type()); |
+ EXPECT_EQ(detached_position1, panel1->GetBounds().origin()); |
+ EXPECT_EQ(detached_position2, panel2->GetBounds().origin()); |
+ EXPECT_EQ(docked_position2, panel3->GetBounds().origin()); |
+ EXPECT_EQ(docked_position1, panel4->GetBounds().origin()); |
+ EXPECT_EQ(docked_position3, panel5->GetBounds().origin()); |
+ |
+ // Drag to attach a detached panel to most-right. |
+ // Expect to have: |
+ // detached: P1 |
+ // docked: P3 P4 P2 |
+ // overflow: P7 P6 P5 |
+ gfx::Point drag_delta_to_attach2( |
+ docked_position1.x() - detached_position2.x() + 10, 210); |
+ DragPanelAndFinish(panel2, drag_delta_to_attach2); |
+ ASSERT_EQ(1, detached_strip->num_panels()); |
+ ASSERT_EQ(3, docked_strip->num_panels()); |
+ ASSERT_EQ(3, overflow_strip->num_panels()); |
+ EXPECT_EQ(PanelStrip::DETACHED, panel1->panel_strip()->type()); |
+ EXPECT_EQ(PanelStrip::DOCKED, panel2->panel_strip()->type()); |
+ EXPECT_EQ(PanelStrip::DOCKED, panel3->panel_strip()->type()); |
+ EXPECT_EQ(PanelStrip::DOCKED, panel4->panel_strip()->type()); |
+ EXPECT_EQ(PanelStrip::IN_OVERFLOW, panel5->panel_strip()->type()); |
+ EXPECT_EQ(PanelStrip::IN_OVERFLOW, panel6->panel_strip()->type()); |
+ EXPECT_EQ(PanelStrip::IN_OVERFLOW, panel7->panel_strip()->type()); |
+ EXPECT_EQ(detached_position1, panel1->GetBounds().origin()); |
+ EXPECT_EQ(docked_position1, panel2->GetBounds().origin()); |
+ EXPECT_EQ(docked_position3, panel3->GetBounds().origin()); |
+ EXPECT_EQ(docked_position2, panel4->GetBounds().origin()); |
+ |
+ // Drag to attach a detached panel to most-left. |
+ // Expect to have: |
+ // docked: P1 P4 P2 |
+ // overflow: P7 P6 P5 P3 |
+ gfx::Point drag_delta_to_attach3( |
+ docked_position3.x() - detached_position1.x() - 50, 210); |
+ DragPanelAndFinish(panel1, drag_delta_to_attach3); |
+ ASSERT_EQ(0, detached_strip->num_panels()); |
+ ASSERT_EQ(3, docked_strip->num_panels()); |
+ ASSERT_EQ(4, overflow_strip->num_panels()); |
+ EXPECT_EQ(PanelStrip::DOCKED, panel1->panel_strip()->type()); |
+ EXPECT_EQ(PanelStrip::DOCKED, panel2->panel_strip()->type()); |
+ EXPECT_EQ(PanelStrip::IN_OVERFLOW, panel3->panel_strip()->type()); |
+ EXPECT_EQ(PanelStrip::DOCKED, panel4->panel_strip()->type()); |
+ EXPECT_EQ(PanelStrip::IN_OVERFLOW, panel5->panel_strip()->type()); |
+ EXPECT_EQ(PanelStrip::IN_OVERFLOW, panel6->panel_strip()->type()); |
+ EXPECT_EQ(PanelStrip::IN_OVERFLOW, panel7->panel_strip()->type()); |
+ EXPECT_EQ(docked_position3, panel1->GetBounds().origin()); |
+ EXPECT_EQ(docked_position1, panel2->GetBounds().origin()); |
+ EXPECT_EQ(docked_position2, panel4->GetBounds().origin()); |
+ |
+ panel_manager->CloseAll(); |
+} |