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

Side by Side Diff: chrome/browser/ui/panels/detached_panel_browsertest.cc

Issue 9616037: Change panel drag related methods to use mouse location in screen coordinates. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Fix mac trybot Created 8 years, 9 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 unified diff | Download patch | Annotate | Revision Log
OLDNEW
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be 2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file. 3 // found in the LICENSE file.
4 4
5 #include "chrome/browser/ui/panels/base_panel_browser_test.h" 5 #include "chrome/browser/ui/panels/base_panel_browser_test.h"
6 #include "chrome/browser/ui/panels/detached_panel_strip.h" 6 #include "chrome/browser/ui/panels/detached_panel_strip.h"
7 #include "chrome/browser/ui/panels/native_panel.h" 7 #include "chrome/browser/ui/panels/native_panel.h"
8 #include "chrome/browser/ui/panels/panel.h" 8 #include "chrome/browser/ui/panels/panel.h"
9 #include "chrome/browser/ui/panels/panel_drag_controller.h" 9 #include "chrome/browser/ui/panels/panel_drag_controller.h"
10 #include "chrome/browser/ui/panels/panel_manager.h" 10 #include "chrome/browser/ui/panels/panel_manager.h"
(...skipping 37 matching lines...) Expand 10 before | Expand all | Expand 10 after
48 panel_manager->MovePanelToStrip(panel, PanelStrip::DETACHED); 48 panel_manager->MovePanelToStrip(panel, PanelStrip::DETACHED);
49 49
50 // Test that the detached panel can be dragged anywhere. 50 // Test that the detached panel can be dragged anywhere.
51 scoped_ptr<NativePanelTesting> panel_testing( 51 scoped_ptr<NativePanelTesting> panel_testing(
52 NativePanelTesting::Create(panel->native_panel())); 52 NativePanelTesting::Create(panel->native_panel()));
53 gfx::Point origin = panel->GetBounds().origin(); 53 gfx::Point origin = panel->GetBounds().origin();
54 54
55 panel_testing->PressLeftMouseButtonTitlebar(origin); 55 panel_testing->PressLeftMouseButtonTitlebar(origin);
56 EXPECT_EQ(origin, panel->GetBounds().origin()); 56 EXPECT_EQ(origin, panel->GetBounds().origin());
57 57
58 panel_testing->DragTitlebar(-51, 102); 58 origin.Offset(-51, -102);
59 origin.Offset(-51, 102); 59 panel_testing->DragTitlebar(origin);
60 EXPECT_EQ(origin, panel->GetBounds().origin()); 60 EXPECT_EQ(origin, panel->GetBounds().origin());
61 61
62 panel_testing->DragTitlebar(37, -42); 62 origin.Offset(37, 45);
63 origin.Offset(37, -42); 63 panel_testing->DragTitlebar(origin);
64 EXPECT_EQ(origin, panel->GetBounds().origin()); 64 EXPECT_EQ(origin, panel->GetBounds().origin());
65 65
66 panel_testing->FinishDragTitlebar(); 66 panel_testing->FinishDragTitlebar();
67 EXPECT_EQ(origin, panel->GetBounds().origin()); 67 EXPECT_EQ(origin, panel->GetBounds().origin());
68 68
69 // Test that cancelling the drag will return the panel the the original 69 // Test that cancelling the drag will return the panel the the original
70 // position. 70 // position.
71 gfx::Point original_position = panel->GetBounds().origin(); 71 gfx::Point original_position = panel->GetBounds().origin();
72 origin = original_position; 72 origin = original_position;
73 73
74 panel_testing->PressLeftMouseButtonTitlebar(origin); 74 panel_testing->PressLeftMouseButtonTitlebar(origin);
75 EXPECT_EQ(origin, panel->GetBounds().origin()); 75 EXPECT_EQ(origin, panel->GetBounds().origin());
76 76
77 panel_testing->DragTitlebar(-51, 102); 77 origin.Offset(-51, -102);
78 origin.Offset(-51, 102); 78 panel_testing->DragTitlebar(origin);
79
79 EXPECT_EQ(origin, panel->GetBounds().origin()); 80 EXPECT_EQ(origin, panel->GetBounds().origin());
80 81
81 panel_testing->DragTitlebar(37, -42); 82 origin.Offset(37, 45);
82 origin.Offset(37, -42); 83 panel_testing->DragTitlebar(origin);
83 EXPECT_EQ(origin, panel->GetBounds().origin()); 84 EXPECT_EQ(origin, panel->GetBounds().origin());
84 85
85 panel_testing->CancelDragTitlebar(); 86 panel_testing->CancelDragTitlebar();
86 EXPECT_EQ(original_position, panel->GetBounds().origin()); 87 EXPECT_EQ(original_position, panel->GetBounds().origin());
87 88
88 panel_manager->CloseAll(); 89 panel_manager->CloseAll();
89 } 90 }
90 91
91 IN_PROC_BROWSER_TEST_F(DetachedPanelBrowserTest, CloseDetachedPanelOnDrag) { 92 IN_PROC_BROWSER_TEST_F(DetachedPanelBrowserTest, CloseDetachedPanelOnDrag) {
92 PanelManager* panel_manager = PanelManager::GetInstance(); 93 PanelManager* panel_manager = PanelManager::GetInstance();
(...skipping 18 matching lines...) Expand all
111 gfx::Point panel3_position = panel3->GetBounds().origin(); 112 gfx::Point panel3_position = panel3->GetBounds().origin();
112 gfx::Point panel4_position = panel4->GetBounds().origin(); 113 gfx::Point panel4_position = panel4->GetBounds().origin();
113 114
114 // Test the scenario: drag a panel, close another panel, cancel the drag. 115 // Test the scenario: drag a panel, close another panel, cancel the drag.
115 { 116 {
116 gfx::Point panel1_new_position = panel1_old_position; 117 gfx::Point panel1_new_position = panel1_old_position;
117 panel1_new_position.Offset(-51, -102); 118 panel1_new_position.Offset(-51, -102);
118 119
119 // Start dragging a panel. 120 // Start dragging a panel.
120 panel1_testing->PressLeftMouseButtonTitlebar(panel1->GetBounds().origin()); 121 panel1_testing->PressLeftMouseButtonTitlebar(panel1->GetBounds().origin());
121 panel1_testing->DragTitlebar(-51, -102); 122 panel1_testing->DragTitlebar(panel1_new_position);
122 EXPECT_TRUE(drag_controller->IsDragging()); 123 EXPECT_TRUE(drag_controller->IsDragging());
123 EXPECT_EQ(panel1, drag_controller->dragging_panel()); 124 EXPECT_EQ(panel1, drag_controller->dragging_panel());
124 125
125 ASSERT_EQ(4, detached_strip->num_panels()); 126 ASSERT_EQ(4, detached_strip->num_panels());
126 EXPECT_TRUE(detached_strip->HasPanel(panel1)); 127 EXPECT_TRUE(detached_strip->HasPanel(panel1));
127 EXPECT_TRUE(detached_strip->HasPanel(panel2)); 128 EXPECT_TRUE(detached_strip->HasPanel(panel2));
128 EXPECT_TRUE(detached_strip->HasPanel(panel3)); 129 EXPECT_TRUE(detached_strip->HasPanel(panel3));
129 EXPECT_TRUE(detached_strip->HasPanel(panel4)); 130 EXPECT_TRUE(detached_strip->HasPanel(panel4));
130 EXPECT_EQ(panel1_new_position, panel1->GetBounds().origin()); 131 EXPECT_EQ(panel1_new_position, panel1->GetBounds().origin());
131 EXPECT_EQ(panel2_position, panel2->GetBounds().origin()); 132 EXPECT_EQ(panel2_position, panel2->GetBounds().origin());
(...skipping 27 matching lines...) Expand all
159 EXPECT_EQ(panel4_position, panel4->GetBounds().origin()); 160 EXPECT_EQ(panel4_position, panel4->GetBounds().origin());
160 } 161 }
161 162
162 // Test the scenario: drag a panel, close another panel, end the drag. 163 // Test the scenario: drag a panel, close another panel, end the drag.
163 { 164 {
164 gfx::Point panel1_new_position = panel1_old_position; 165 gfx::Point panel1_new_position = panel1_old_position;
165 panel1_new_position.Offset(-51, -102); 166 panel1_new_position.Offset(-51, -102);
166 167
167 // Start dragging a panel. 168 // Start dragging a panel.
168 panel1_testing->PressLeftMouseButtonTitlebar(panel1->GetBounds().origin()); 169 panel1_testing->PressLeftMouseButtonTitlebar(panel1->GetBounds().origin());
169 panel1_testing->DragTitlebar(-51, -102); 170 panel1_testing->DragTitlebar(panel1_new_position);
170 EXPECT_TRUE(drag_controller->IsDragging()); 171 EXPECT_TRUE(drag_controller->IsDragging());
171 EXPECT_EQ(panel1, drag_controller->dragging_panel()); 172 EXPECT_EQ(panel1, drag_controller->dragging_panel());
172 173
173 ASSERT_EQ(3, detached_strip->num_panels()); 174 ASSERT_EQ(3, detached_strip->num_panels());
174 EXPECT_TRUE(detached_strip->HasPanel(panel1)); 175 EXPECT_TRUE(detached_strip->HasPanel(panel1));
175 EXPECT_TRUE(detached_strip->HasPanel(panel3)); 176 EXPECT_TRUE(detached_strip->HasPanel(panel3));
176 EXPECT_TRUE(detached_strip->HasPanel(panel4)); 177 EXPECT_TRUE(detached_strip->HasPanel(panel4));
177 EXPECT_EQ(panel1_new_position, panel1->GetBounds().origin()); 178 EXPECT_EQ(panel1_new_position, panel1->GetBounds().origin());
178 EXPECT_EQ(panel3_position, panel3->GetBounds().origin()); 179 EXPECT_EQ(panel3_position, panel3->GetBounds().origin());
179 EXPECT_EQ(panel4_position, panel4->GetBounds().origin()); 180 EXPECT_EQ(panel4_position, panel4->GetBounds().origin());
(...skipping 21 matching lines...) Expand all
201 EXPECT_EQ(panel4_position, panel4->GetBounds().origin()); 202 EXPECT_EQ(panel4_position, panel4->GetBounds().origin());
202 } 203 }
203 204
204 // Test the scenario: drag a panel and close the dragging panel. 205 // Test the scenario: drag a panel and close the dragging panel.
205 { 206 {
206 gfx::Point panel1_new_position = panel1->GetBounds().origin(); 207 gfx::Point panel1_new_position = panel1->GetBounds().origin();
207 panel1_new_position.Offset(-51, -102); 208 panel1_new_position.Offset(-51, -102);
208 209
209 // Start dragging a panel again. 210 // Start dragging a panel again.
210 panel1_testing->PressLeftMouseButtonTitlebar(panel1->GetBounds().origin()); 211 panel1_testing->PressLeftMouseButtonTitlebar(panel1->GetBounds().origin());
211 panel1_testing->DragTitlebar(-51, -102); 212 panel1_testing->DragTitlebar(panel1_new_position);
212 EXPECT_TRUE(drag_controller->IsDragging()); 213 EXPECT_TRUE(drag_controller->IsDragging());
213 EXPECT_EQ(panel1, drag_controller->dragging_panel()); 214 EXPECT_EQ(panel1, drag_controller->dragging_panel());
214 215
215 ASSERT_EQ(2, detached_strip->num_panels()); 216 ASSERT_EQ(2, detached_strip->num_panels());
216 EXPECT_TRUE(detached_strip->HasPanel(panel1)); 217 EXPECT_TRUE(detached_strip->HasPanel(panel1));
217 EXPECT_TRUE(detached_strip->HasPanel(panel4)); 218 EXPECT_TRUE(detached_strip->HasPanel(panel4));
218 EXPECT_EQ(panel1_new_position, panel1->GetBounds().origin()); 219 EXPECT_EQ(panel1_new_position, panel1->GetBounds().origin());
219 EXPECT_EQ(panel4_position, panel4->GetBounds().origin()); 220 EXPECT_EQ(panel4_position, panel4->GetBounds().origin());
220 221
221 // Closing the dragging panel should end the drag. 222 // Closing the dragging panel should end the drag.
222 CloseWindowAndWait(panel1->browser()); 223 CloseWindowAndWait(panel1->browser());
223 EXPECT_FALSE(drag_controller->IsDragging()); 224 EXPECT_FALSE(drag_controller->IsDragging());
224 225
225 ASSERT_EQ(1, detached_strip->num_panels()); 226 ASSERT_EQ(1, detached_strip->num_panels());
226 EXPECT_TRUE(detached_strip->HasPanel(panel4)); 227 EXPECT_TRUE(detached_strip->HasPanel(panel4));
227 EXPECT_EQ(panel4_position, panel4->GetBounds().origin()); 228 EXPECT_EQ(panel4_position, panel4->GetBounds().origin());
228 } 229 }
229 230
230 panel_manager->CloseAll(); 231 panel_manager->CloseAll();
231 } 232 }
OLDNEW
« no previous file with comments | « no previous file | chrome/browser/ui/panels/native_panel.h » ('j') | chrome/browser/ui/panels/panel_browsertest.cc » ('J')

Powered by Google App Engine
This is Rietveld 408576698