Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(8165)

Unified Diff: chrome/browser/ui/panels/panel_drag_browsertest.cc

Issue 9546001: Support detaching/attaching panels via inter-strip drags. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Created 8 years, 10 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
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();
+}

Powered by Google App Engine
This is Rietveld 408576698