| OLD | NEW |
| 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/views/tabs/tab_drag_controller_interactive_uitest.h" | 5 #include "chrome/browser/ui/views/tabs/tab_drag_controller_interactive_uitest.h" |
| 6 | 6 |
| 7 #include "base/bind.h" | 7 #include "base/bind.h" |
| 8 #include "base/callback.h" | 8 #include "base/callback.h" |
| 9 #include "base/command_line.h" | 9 #include "base/command_line.h" |
| 10 #include "base/strings/string_number_conversions.h" | 10 #include "base/strings/string_number_conversions.h" |
| 11 #include "chrome/browser/ui/browser.h" | 11 #include "chrome/browser/ui/browser.h" |
| 12 #include "chrome/browser/ui/browser_list.h" | 12 #include "chrome/browser/ui/browser_list_impl.h" |
| 13 #include "chrome/browser/ui/browser_window.h" | 13 #include "chrome/browser/ui/browser_window.h" |
| 14 #include "chrome/browser/ui/tabs/tab_strip_model.h" | 14 #include "chrome/browser/ui/tabs/tab_strip_model.h" |
| 15 #include "chrome/browser/ui/views/frame/browser_view.h" | 15 #include "chrome/browser/ui/views/frame/browser_view.h" |
| 16 #include "chrome/browser/ui/views/tabs/tab.h" | 16 #include "chrome/browser/ui/views/tabs/tab.h" |
| 17 #include "chrome/browser/ui/views/tabs/tab_drag_controller.h" | 17 #include "chrome/browser/ui/views/tabs/tab_drag_controller.h" |
| 18 #include "chrome/browser/ui/views/tabs/tab_strip.h" | 18 #include "chrome/browser/ui/views/tabs/tab_strip.h" |
| 19 #include "chrome/common/chrome_notification_types.h" | 19 #include "chrome/common/chrome_notification_types.h" |
| 20 #include "chrome/common/chrome_switches.h" | 20 #include "chrome/common/chrome_switches.h" |
| 21 #include "chrome/test/base/in_process_browser_test.h" | 21 #include "chrome/test/base/in_process_browser_test.h" |
| 22 #include "chrome/test/base/interactive_test_utils.h" | 22 #include "chrome/test/base/interactive_test_utils.h" |
| (...skipping 99 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 122 ASSERT_TRUE(ui_controls::SendMouseMove( | 122 ASSERT_TRUE(ui_controls::SendMouseMove( |
| 123 tab_0_center.x(), tab_0_center.y() + tab_strip->height() + 20)); | 123 tab_0_center.x(), tab_0_center.y() + tab_strip->height() + 20)); |
| 124 ASSERT_TRUE(ui_test_utils::SendMouseEventsSync( | 124 ASSERT_TRUE(ui_test_utils::SendMouseEventsSync( |
| 125 ui_controls::LEFT, ui_controls::UP)); | 125 ui_controls::LEFT, ui_controls::UP)); |
| 126 | 126 |
| 127 // Should no longer be dragging. | 127 // Should no longer be dragging. |
| 128 ASSERT_FALSE(tab_strip->IsDragSessionActive()); | 128 ASSERT_FALSE(tab_strip->IsDragSessionActive()); |
| 129 ASSERT_FALSE(TabDragController::IsActive()); | 129 ASSERT_FALSE(TabDragController::IsActive()); |
| 130 | 130 |
| 131 // There should now be another browser. | 131 // There should now be another browser. |
| 132 ASSERT_EQ(2u, BrowserList::size()); | 132 ASSERT_EQ(2u, native_browser_list->size()); |
| 133 Browser* new_browser = *(++BrowserList::begin()); | 133 Browser* new_browser = native_browser_list->get(1); |
| 134 ASSERT_TRUE(new_browser->window()->IsActive()); | 134 ASSERT_TRUE(new_browser->window()->IsActive()); |
| 135 TabStrip* tab_strip2 = GetTabStripForBrowser(new_browser); | 135 TabStrip* tab_strip2 = GetTabStripForBrowser(new_browser); |
| 136 ASSERT_FALSE(tab_strip2->IsDragSessionActive()); | 136 ASSERT_FALSE(tab_strip2->IsDragSessionActive()); |
| 137 | 137 |
| 138 EXPECT_EQ("0", IDString(new_browser->tab_strip_model())); | 138 EXPECT_EQ("0", IDString(new_browser->tab_strip_model())); |
| 139 EXPECT_EQ("1", IDString(browser()->tab_strip_model())); | 139 EXPECT_EQ("1", IDString(browser()->tab_strip_model())); |
| 140 } | 140 } |
| 141 | 141 |
| 142 // Deletes a tab being dragged before the user moved enough to start a drag. | 142 // Deletes a tab being dragged before the user moved enough to start a drag. |
| 143 IN_PROC_BROWSER_TEST_F(TabDragControllerTest, DeleteBeforeStartedDragging) { | 143 IN_PROC_BROWSER_TEST_F(TabDragControllerTest, DeleteBeforeStartedDragging) { |
| (...skipping 96 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 240 // Should still be dragging. | 240 // Should still be dragging. |
| 241 ASSERT_TRUE(tab_strip->IsDragSessionActive()); | 241 ASSERT_TRUE(tab_strip->IsDragSessionActive()); |
| 242 ASSERT_TRUE(TabDragController::IsActive()); | 242 ASSERT_TRUE(TabDragController::IsActive()); |
| 243 | 243 |
| 244 // Release the mouse. | 244 // Release the mouse. |
| 245 ASSERT_TRUE(ui_test_utils::SendMouseEventsSync( | 245 ASSERT_TRUE(ui_test_utils::SendMouseEventsSync( |
| 246 ui_controls::LEFT, ui_controls::UP)); | 246 ui_controls::LEFT, ui_controls::UP)); |
| 247 | 247 |
| 248 // Releasing the mouse should destroy the existing browser and create a new | 248 // Releasing the mouse should destroy the existing browser and create a new |
| 249 // one. | 249 // one. |
| 250 ASSERT_EQ(1u, BrowserList::size()); | 250 ASSERT_EQ(1u, native_browser_list->size()); |
| 251 Browser* new_browser = *BrowserList::begin(); | 251 Browser* new_browser = native_browser_list->get(0); |
| 252 EXPECT_NE(new_browser, browser()); | 252 EXPECT_NE(new_browser, browser()); |
| 253 | 253 |
| 254 ASSERT_FALSE(GetTabStripForBrowser(new_browser)->IsDragSessionActive()); | 254 ASSERT_FALSE(GetTabStripForBrowser(new_browser)->IsDragSessionActive()); |
| 255 ASSERT_FALSE(TabDragController::IsActive()); | 255 ASSERT_FALSE(TabDragController::IsActive()); |
| 256 | 256 |
| 257 EXPECT_EQ("0", IDString(new_browser->tab_strip_model())); | 257 EXPECT_EQ("0", IDString(new_browser->tab_strip_model())); |
| 258 } | 258 } |
| 259 | 259 |
| 260 // Creates two browsers, selects all tabs in first and drags into second. | 260 // Creates two browsers, selects all tabs in first and drags into second. |
| 261 IN_PROC_BROWSER_TEST_F(TabDragControllerTest, DragAllToSeparateWindow) { | 261 IN_PROC_BROWSER_TEST_F(TabDragControllerTest, DragAllToSeparateWindow) { |
| (...skipping 16 matching lines...) Expand all Loading... |
| 278 ASSERT_TRUE(ui_test_utils::SendMouseMoveSync(tab_0_center)); | 278 ASSERT_TRUE(ui_test_utils::SendMouseMoveSync(tab_0_center)); |
| 279 ASSERT_TRUE(ui_test_utils::SendMouseEventsSync( | 279 ASSERT_TRUE(ui_test_utils::SendMouseEventsSync( |
| 280 ui_controls::LEFT, ui_controls::DOWN)); | 280 ui_controls::LEFT, ui_controls::DOWN)); |
| 281 ASSERT_TRUE(ui_test_utils::SendMouseMoveSync( | 281 ASSERT_TRUE(ui_test_utils::SendMouseMoveSync( |
| 282 gfx::Point(tab_0_center.x(), | 282 gfx::Point(tab_0_center.x(), |
| 283 tab_0_center.y() + tab_strip->height() + 20))); | 283 tab_0_center.y() + tab_strip->height() + 20))); |
| 284 | 284 |
| 285 ASSERT_TRUE(tab_strip->IsDragSessionActive()); | 285 ASSERT_TRUE(tab_strip->IsDragSessionActive()); |
| 286 ASSERT_FALSE(tab_strip2->IsDragSessionActive()); | 286 ASSERT_FALSE(tab_strip2->IsDragSessionActive()); |
| 287 ASSERT_TRUE(TabDragController::IsActive()); | 287 ASSERT_TRUE(TabDragController::IsActive()); |
| 288 ASSERT_EQ(2u, BrowserList::size()); | 288 ASSERT_EQ(2u, native_browser_list->size()); |
| 289 | 289 |
| 290 // Drag to tab_strip2. | 290 // Drag to tab_strip2. |
| 291 gfx::Point target_point(tab_strip2->width() - 1, | 291 gfx::Point target_point(tab_strip2->width() - 1, |
| 292 tab_strip2->height() / 2); | 292 tab_strip2->height() / 2); |
| 293 views::View::ConvertPointToScreen(tab_strip2, &target_point); | 293 views::View::ConvertPointToScreen(tab_strip2, &target_point); |
| 294 ASSERT_TRUE(ui_controls::SendMouseMove(target_point.x(), target_point.y())); | 294 ASSERT_TRUE(ui_controls::SendMouseMove(target_point.x(), target_point.y())); |
| 295 | 295 |
| 296 // Should now be attached to tab_strip2. | 296 // Should now be attached to tab_strip2. |
| 297 ASSERT_TRUE(tab_strip->IsDragSessionActive()); | 297 ASSERT_TRUE(tab_strip->IsDragSessionActive()); |
| 298 ASSERT_TRUE(TabDragController::IsActive()); | 298 ASSERT_TRUE(TabDragController::IsActive()); |
| (...skipping 27 matching lines...) Expand all Loading... |
| 326 GetCenterInScreenCoordinates(tab_strip->tab_at(0))); | 326 GetCenterInScreenCoordinates(tab_strip->tab_at(0))); |
| 327 ASSERT_TRUE(ui_test_utils::SendMouseMoveSync(tab_0_center)); | 327 ASSERT_TRUE(ui_test_utils::SendMouseMoveSync(tab_0_center)); |
| 328 ASSERT_TRUE(ui_test_utils::SendMouseEventsSync( | 328 ASSERT_TRUE(ui_test_utils::SendMouseEventsSync( |
| 329 ui_controls::LEFT, ui_controls::DOWN)); | 329 ui_controls::LEFT, ui_controls::DOWN)); |
| 330 ASSERT_TRUE(ui_test_utils::SendMouseMoveSync( | 330 ASSERT_TRUE(ui_test_utils::SendMouseMoveSync( |
| 331 gfx::Point(tab_0_center.x(), | 331 gfx::Point(tab_0_center.x(), |
| 332 tab_0_center.y() + tab_strip->height() + 20))); | 332 tab_0_center.y() + tab_strip->height() + 20))); |
| 333 ASSERT_TRUE(tab_strip->IsDragSessionActive()); | 333 ASSERT_TRUE(tab_strip->IsDragSessionActive()); |
| 334 ASSERT_FALSE(tab_strip2->IsDragSessionActive()); | 334 ASSERT_FALSE(tab_strip2->IsDragSessionActive()); |
| 335 ASSERT_TRUE(TabDragController::IsActive()); | 335 ASSERT_TRUE(TabDragController::IsActive()); |
| 336 ASSERT_EQ(2u, BrowserList::size()); | 336 ASSERT_EQ(2u, native_browser_list->size()); |
| 337 | 337 |
| 338 // Drag to tab_strip2. | 338 // Drag to tab_strip2. |
| 339 gfx::Point target_point(tab_strip2->width() - 1, | 339 gfx::Point target_point(tab_strip2->width() - 1, |
| 340 tab_strip2->height() / 2); | 340 tab_strip2->height() / 2); |
| 341 views::View::ConvertPointToScreen(tab_strip2, &target_point); | 341 views::View::ConvertPointToScreen(tab_strip2, &target_point); |
| 342 ASSERT_TRUE(ui_controls::SendMouseMove(target_point.x(), target_point.y())); | 342 ASSERT_TRUE(ui_controls::SendMouseMove(target_point.x(), target_point.y())); |
| 343 | 343 |
| 344 ASSERT_TRUE(tab_strip->IsDragSessionActive()); | 344 ASSERT_TRUE(tab_strip->IsDragSessionActive()); |
| 345 ASSERT_TRUE(TabDragController::IsActive()); | 345 ASSERT_TRUE(TabDragController::IsActive()); |
| 346 ASSERT_EQ(2u, BrowserList::size()); | 346 ASSERT_EQ(2u, native_browser_list->size()); |
| 347 | 347 |
| 348 // Cancel the drag. | 348 // Cancel the drag. |
| 349 ASSERT_TRUE(ui_test_utils::SendKeyPressSync( | 349 ASSERT_TRUE(ui_test_utils::SendKeyPressSync( |
| 350 browser2, ui::VKEY_ESCAPE, false, false, false, false)); | 350 browser2, ui::VKEY_ESCAPE, false, false, false, false)); |
| 351 | 351 |
| 352 ASSERT_FALSE(tab_strip->IsDragSessionActive()); | 352 ASSERT_FALSE(tab_strip->IsDragSessionActive()); |
| 353 ASSERT_FALSE(tab_strip2->IsDragSessionActive()); | 353 ASSERT_FALSE(tab_strip2->IsDragSessionActive()); |
| 354 ASSERT_FALSE(TabDragController::IsActive()); | 354 ASSERT_FALSE(TabDragController::IsActive()); |
| 355 ASSERT_EQ(2u, BrowserList::size()); | 355 ASSERT_EQ(2u, native_browser_list->size()); |
| 356 EXPECT_EQ("0 1", IDString(browser()->tab_strip_model())); | 356 EXPECT_EQ("0 1", IDString(browser()->tab_strip_model())); |
| 357 EXPECT_EQ("100", IDString(browser2->tab_strip_model())); | 357 EXPECT_EQ("100", IDString(browser2->tab_strip_model())); |
| 358 } | 358 } |
| OLD | NEW |