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 <stddef.h> | 7 #include <stddef.h> |
8 | 8 |
9 #include <algorithm> | 9 #include <algorithm> |
10 | 10 |
(...skipping 19 matching lines...) Expand all Loading... |
30 #include "chrome/browser/ui/views/tabs/window_finder.h" | 30 #include "chrome/browser/ui/views/tabs/window_finder.h" |
31 #include "chrome/test/base/in_process_browser_test.h" | 31 #include "chrome/test/base/in_process_browser_test.h" |
32 #include "chrome/test/base/interactive_test_utils.h" | 32 #include "chrome/test/base/interactive_test_utils.h" |
33 #include "chrome/test/base/ui_test_utils.h" | 33 #include "chrome/test/base/ui_test_utils.h" |
34 #include "content/public/browser/notification_details.h" | 34 #include "content/public/browser/notification_details.h" |
35 #include "content/public/browser/notification_observer.h" | 35 #include "content/public/browser/notification_observer.h" |
36 #include "content/public/browser/notification_service.h" | 36 #include "content/public/browser/notification_service.h" |
37 #include "content/public/browser/notification_source.h" | 37 #include "content/public/browser/notification_source.h" |
38 #include "content/public/browser/web_contents.h" | 38 #include "content/public/browser/web_contents.h" |
39 #include "ui/base/test/ui_controls.h" | 39 #include "ui/base/test/ui_controls.h" |
40 #include "ui/gfx/screen.h" | 40 #include "ui/display/screen.h" |
41 #include "ui/views/view.h" | 41 #include "ui/views/view.h" |
42 #include "ui/views/widget/widget.h" | 42 #include "ui/views/widget/widget.h" |
43 | 43 |
44 #if defined(USE_AURA) | 44 #if defined(USE_AURA) |
45 #include "ui/aura/client/aura_constants.h" | 45 #include "ui/aura/client/aura_constants.h" |
46 #include "ui/aura/test/test_window_delegate.h" | 46 #include "ui/aura/test/test_window_delegate.h" |
47 #include "ui/aura/test/test_windows.h" | 47 #include "ui/aura/test/test_windows.h" |
48 #include "ui/aura/window_targeter.h" | 48 #include "ui/aura/window_targeter.h" |
49 #endif | 49 #endif |
50 | 50 |
(...skipping 125 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
176 ResetIDs(browser->tab_strip_model(), 0); | 176 ResetIDs(browser->tab_strip_model(), 0); |
177 } | 177 } |
178 | 178 |
179 Browser* TabDragControllerTest::CreateAnotherWindowBrowserAndRelayout() { | 179 Browser* TabDragControllerTest::CreateAnotherWindowBrowserAndRelayout() { |
180 // Create another browser. | 180 // Create another browser. |
181 Browser* browser2 = CreateBrowser(browser()->profile()); | 181 Browser* browser2 = CreateBrowser(browser()->profile()); |
182 ResetIDs(browser2->tab_strip_model(), 100); | 182 ResetIDs(browser2->tab_strip_model(), 100); |
183 | 183 |
184 // Resize the two windows so they're right next to each other. | 184 // Resize the two windows so they're right next to each other. |
185 gfx::Rect work_area = | 185 gfx::Rect work_area = |
186 gfx::Screen::GetScreen() | 186 display::Screen::GetScreen() |
187 ->GetDisplayNearestWindow(browser()->window()->GetNativeWindow()) | 187 ->GetDisplayNearestWindow(browser()->window()->GetNativeWindow()) |
188 .work_area(); | 188 .work_area(); |
189 gfx::Size half_size = | 189 gfx::Size half_size = |
190 gfx::Size(work_area.width() / 3 - 10, work_area.height() / 2 - 10); | 190 gfx::Size(work_area.width() / 3 - 10, work_area.height() / 2 - 10); |
191 browser()->window()->SetBounds(gfx::Rect(work_area.origin(), half_size)); | 191 browser()->window()->SetBounds(gfx::Rect(work_area.origin(), half_size)); |
192 browser2->window()->SetBounds(gfx::Rect( | 192 browser2->window()->SetBounds(gfx::Rect( |
193 work_area.x() + half_size.width(), work_area.y(), | 193 work_area.x() + half_size.width(), work_area.y(), |
194 half_size.width(), half_size.height())); | 194 half_size.width(), half_size.height())); |
195 return browser2; | 195 return browser2; |
196 } | 196 } |
(...skipping 661 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
858 #define MAYBE_DetachFromFullsizeWindow DISABLED_DetachFromFullsizeWindow | 858 #define MAYBE_DetachFromFullsizeWindow DISABLED_DetachFromFullsizeWindow |
859 #else | 859 #else |
860 #define MAYBE_DetachFromFullsizeWindow DetachFromFullsizeWindow | 860 #define MAYBE_DetachFromFullsizeWindow DetachFromFullsizeWindow |
861 #endif | 861 #endif |
862 // Tests that a tab can be dragged from a browser window that is resized to full | 862 // Tests that a tab can be dragged from a browser window that is resized to full |
863 // screen. | 863 // screen. |
864 IN_PROC_BROWSER_TEST_P(DetachToBrowserTabDragControllerTest, | 864 IN_PROC_BROWSER_TEST_P(DetachToBrowserTabDragControllerTest, |
865 MAYBE_DetachFromFullsizeWindow) { | 865 MAYBE_DetachFromFullsizeWindow) { |
866 // Resize the browser window so that it is as big as the work area. | 866 // Resize the browser window so that it is as big as the work area. |
867 gfx::Rect work_area = | 867 gfx::Rect work_area = |
868 gfx::Screen::GetScreen() | 868 display::Screen::GetScreen() |
869 ->GetDisplayNearestWindow(browser()->window()->GetNativeWindow()) | 869 ->GetDisplayNearestWindow(browser()->window()->GetNativeWindow()) |
870 .work_area(); | 870 .work_area(); |
871 browser()->window()->SetBounds(work_area); | 871 browser()->window()->SetBounds(work_area); |
872 const gfx::Rect initial_bounds(browser()->window()->GetBounds()); | 872 const gfx::Rect initial_bounds(browser()->window()->GetBounds()); |
873 // Add another tab. | 873 // Add another tab. |
874 AddTabAndResetBrowser(browser()); | 874 AddTabAndResetBrowser(browser()); |
875 TabStrip* tab_strip = GetTabStripForBrowser(browser()); | 875 TabStrip* tab_strip = GetTabStripForBrowser(browser()); |
876 | 876 |
877 // Move to the first tab and drag it enough so that it detaches. | 877 // Move to the first tab and drag it enough so that it detaches. |
878 gfx::Point tab_0_center(GetCenterInScreenCoordinates(tab_strip->tab_at(0))); | 878 gfx::Point tab_0_center(GetCenterInScreenCoordinates(tab_strip->tab_at(0))); |
(...skipping 945 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
1824 | 1824 |
1825 // Create another browser. | 1825 // Create another browser. |
1826 Browser* browser2 = CreateBrowser(browser()->profile()); | 1826 Browser* browser2 = CreateBrowser(browser()->profile()); |
1827 TabStrip* tab_strip2 = GetTabStripForBrowser(browser2); | 1827 TabStrip* tab_strip2 = GetTabStripForBrowser(browser2); |
1828 ResetIDs(browser2->tab_strip_model(), 100); | 1828 ResetIDs(browser2->tab_strip_model(), 100); |
1829 | 1829 |
1830 // Move the second browser to the second display. | 1830 // Move the second browser to the second display. |
1831 aura::Window::Windows roots = ash::Shell::GetAllRootWindows(); | 1831 aura::Window::Windows roots = ash::Shell::GetAllRootWindows(); |
1832 ASSERT_EQ(2u, roots.size()); | 1832 ASSERT_EQ(2u, roots.size()); |
1833 aura::Window* second_root = roots[1]; | 1833 aura::Window* second_root = roots[1]; |
1834 gfx::Rect work_area = gfx::Screen::GetScreen() | 1834 gfx::Rect work_area = display::Screen::GetScreen() |
1835 ->GetDisplayNearestWindow(second_root) | 1835 ->GetDisplayNearestWindow(second_root) |
1836 .work_area(); | 1836 .work_area(); |
1837 browser2->window()->SetBounds(work_area); | 1837 browser2->window()->SetBounds(work_area); |
1838 EXPECT_EQ(second_root, | 1838 EXPECT_EQ(second_root, |
1839 browser2->window()->GetNativeWindow()->GetRootWindow()); | 1839 browser2->window()->GetNativeWindow()->GetRootWindow()); |
1840 | 1840 |
1841 // Move to the first tab and drag it enough so that it detaches, but not | 1841 // Move to the first tab and drag it enough so that it detaches, but not |
1842 // enough that it attaches to browser2. | 1842 // enough that it attaches to browser2. |
1843 gfx::Point tab_0_center(GetCenterInScreenCoordinates(tab_strip->tab_at(0))); | 1843 gfx::Point tab_0_center(GetCenterInScreenCoordinates(tab_strip->tab_at(0))); |
1844 ASSERT_TRUE(PressInput(tab_0_center)); | 1844 ASSERT_TRUE(PressInput(tab_0_center)); |
(...skipping 30 matching lines...) Expand all Loading... |
1875 | 1875 |
1876 // Create another browser. | 1876 // Create another browser. |
1877 Browser* browser2 = CreateBrowser(browser()->profile()); | 1877 Browser* browser2 = CreateBrowser(browser()->profile()); |
1878 TabStrip* tab_strip2 = GetTabStripForBrowser(browser2); | 1878 TabStrip* tab_strip2 = GetTabStripForBrowser(browser2); |
1879 ResetIDs(browser2->tab_strip_model(), 100); | 1879 ResetIDs(browser2->tab_strip_model(), 100); |
1880 | 1880 |
1881 // Move both browsers to the second display. | 1881 // Move both browsers to the second display. |
1882 aura::Window::Windows roots = ash::Shell::GetAllRootWindows(); | 1882 aura::Window::Windows roots = ash::Shell::GetAllRootWindows(); |
1883 ASSERT_EQ(2u, roots.size()); | 1883 ASSERT_EQ(2u, roots.size()); |
1884 aura::Window* second_root = roots[1]; | 1884 aura::Window* second_root = roots[1]; |
1885 gfx::Rect work_area = gfx::Screen::GetScreen() | 1885 gfx::Rect work_area = display::Screen::GetScreen() |
1886 ->GetDisplayNearestWindow(second_root) | 1886 ->GetDisplayNearestWindow(second_root) |
1887 .work_area(); | 1887 .work_area(); |
1888 browser()->window()->SetBounds(work_area); | 1888 browser()->window()->SetBounds(work_area); |
1889 | 1889 |
1890 // position both browser windows side by side on the second screen. | 1890 // position both browser windows side by side on the second screen. |
1891 gfx::Rect work_area2(work_area); | 1891 gfx::Rect work_area2(work_area); |
1892 work_area.set_width(work_area.width()/2); | 1892 work_area.set_width(work_area.width()/2); |
1893 browser()->window()->SetBounds(work_area); | 1893 browser()->window()->SetBounds(work_area); |
1894 work_area2.set_x(work_area2.x() + work_area2.width()/2); | 1894 work_area2.set_x(work_area2.x() + work_area2.width()/2); |
1895 work_area2.set_width(work_area2.width()/2); | 1895 work_area2.set_width(work_area2.width()/2); |
(...skipping 40 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
1936 // Add another tab. | 1936 // Add another tab. |
1937 AddTabAndResetBrowser(browser()); | 1937 AddTabAndResetBrowser(browser()); |
1938 browser()->window()->Maximize(); | 1938 browser()->window()->Maximize(); |
1939 TabStrip* tab_strip = GetTabStripForBrowser(browser()); | 1939 TabStrip* tab_strip = GetTabStripForBrowser(browser()); |
1940 | 1940 |
1941 // Create another browser on the second display. | 1941 // Create another browser on the second display. |
1942 aura::Window::Windows roots = ash::Shell::GetAllRootWindows(); | 1942 aura::Window::Windows roots = ash::Shell::GetAllRootWindows(); |
1943 ASSERT_EQ(2u, roots.size()); | 1943 ASSERT_EQ(2u, roots.size()); |
1944 aura::Window* first_root = roots[0]; | 1944 aura::Window* first_root = roots[0]; |
1945 aura::Window* second_root = roots[1]; | 1945 aura::Window* second_root = roots[1]; |
1946 gfx::Rect work_area = gfx::Screen::GetScreen() | 1946 gfx::Rect work_area = display::Screen::GetScreen() |
1947 ->GetDisplayNearestWindow(second_root) | 1947 ->GetDisplayNearestWindow(second_root) |
1948 .work_area(); | 1948 .work_area(); |
1949 work_area.Inset(20, 20, 20, 60); | 1949 work_area.Inset(20, 20, 20, 60); |
1950 Browser::CreateParams params(browser()->profile()); | 1950 Browser::CreateParams params(browser()->profile()); |
1951 params.initial_show_state = ui::SHOW_STATE_NORMAL; | 1951 params.initial_show_state = ui::SHOW_STATE_NORMAL; |
1952 params.initial_bounds = work_area; | 1952 params.initial_bounds = work_area; |
1953 Browser* browser2 = new Browser(params); | 1953 Browser* browser2 = new Browser(params); |
1954 AddBlankTabAndShow(browser2); | 1954 AddBlankTabAndShow(browser2); |
1955 | 1955 |
1956 TabStrip* tab_strip2 = GetTabStripForBrowser(browser2); | 1956 TabStrip* tab_strip2 = GetTabStripForBrowser(browser2); |
(...skipping 49 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
2006 | 2006 |
2007 // Create another browser. | 2007 // Create another browser. |
2008 Browser* browser2 = CreateBrowser(browser()->profile()); | 2008 Browser* browser2 = CreateBrowser(browser()->profile()); |
2009 TabStrip* tab_strip2 = GetTabStripForBrowser(browser2); | 2009 TabStrip* tab_strip2 = GetTabStripForBrowser(browser2); |
2010 ResetIDs(browser2->tab_strip_model(), 100); | 2010 ResetIDs(browser2->tab_strip_model(), 100); |
2011 | 2011 |
2012 // Move the second browser to the second display. | 2012 // Move the second browser to the second display. |
2013 aura::Window::Windows roots = ash::Shell::GetAllRootWindows(); | 2013 aura::Window::Windows roots = ash::Shell::GetAllRootWindows(); |
2014 ASSERT_EQ(2u, roots.size()); | 2014 ASSERT_EQ(2u, roots.size()); |
2015 aura::Window* second_root = roots[1]; | 2015 aura::Window* second_root = roots[1]; |
2016 gfx::Rect work_area = gfx::Screen::GetScreen() | 2016 gfx::Rect work_area = display::Screen::GetScreen() |
2017 ->GetDisplayNearestWindow(second_root) | 2017 ->GetDisplayNearestWindow(second_root) |
2018 .work_area(); | 2018 .work_area(); |
2019 browser2->window()->SetBounds(work_area); | 2019 browser2->window()->SetBounds(work_area); |
2020 EXPECT_EQ(second_root, | 2020 EXPECT_EQ(second_root, |
2021 browser2->window()->GetNativeWindow()->GetRootWindow()); | 2021 browser2->window()->GetNativeWindow()->GetRootWindow()); |
2022 | 2022 |
2023 // Put the second browser into immersive fullscreen. | 2023 // Put the second browser into immersive fullscreen. |
2024 BrowserView* browser_view2 = BrowserView::GetBrowserViewForBrowser(browser2); | 2024 BrowserView* browser_view2 = BrowserView::GetBrowserViewForBrowser(browser2); |
2025 ImmersiveModeController* immersive_controller2 = | 2025 ImmersiveModeController* immersive_controller2 = |
2026 browser_view2->immersive_mode_controller(); | 2026 browser_view2->immersive_mode_controller(); |
(...skipping 226 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
2253 DISABLED_CancelDragTabToWindowIn2ndDisplay) { | 2253 DISABLED_CancelDragTabToWindowIn2ndDisplay) { |
2254 // Add another tab. | 2254 // Add another tab. |
2255 AddTabAndResetBrowser(browser()); | 2255 AddTabAndResetBrowser(browser()); |
2256 TabStrip* tab_strip = GetTabStripForBrowser(browser()); | 2256 TabStrip* tab_strip = GetTabStripForBrowser(browser()); |
2257 | 2257 |
2258 EXPECT_EQ("0 1", IDString(browser()->tab_strip_model())); | 2258 EXPECT_EQ("0 1", IDString(browser()->tab_strip_model())); |
2259 | 2259 |
2260 // Move the second browser to the second display. | 2260 // Move the second browser to the second display. |
2261 aura::Window::Windows roots = ash::Shell::GetAllRootWindows(); | 2261 aura::Window::Windows roots = ash::Shell::GetAllRootWindows(); |
2262 ASSERT_EQ(2u, roots.size()); | 2262 ASSERT_EQ(2u, roots.size()); |
2263 gfx::Point final_destination = gfx::Screen::GetScreen() | 2263 gfx::Point final_destination = display::Screen::GetScreen() |
2264 ->GetDisplayNearestWindow(roots[1]) | 2264 ->GetDisplayNearestWindow(roots[1]) |
2265 .work_area() | 2265 .work_area() |
2266 .CenterPoint(); | 2266 .CenterPoint(); |
2267 | 2267 |
2268 // Move to the first tab and drag it enough so that it detaches, but not | 2268 // Move to the first tab and drag it enough so that it detaches, but not |
2269 // enough to move to another display. | 2269 // enough to move to another display. |
2270 gfx::Point tab_0_dst(GetCenterInScreenCoordinates(tab_strip->tab_at(0))); | 2270 gfx::Point tab_0_dst(GetCenterInScreenCoordinates(tab_strip->tab_at(0))); |
2271 ASSERT_TRUE(Press(tab_0_dst)); | 2271 ASSERT_TRUE(Press(tab_0_dst)); |
2272 tab_0_dst.Offset(0, GetDetachY(tab_strip)); | 2272 tab_0_dst.Offset(0, GetDetachY(tab_strip)); |
2273 ASSERT_TRUE(DragTabAndExecuteTaskWhenDone( | 2273 ASSERT_TRUE(DragTabAndExecuteTaskWhenDone( |
(...skipping 19 matching lines...) Expand all Loading... |
2293 aura::Window::Windows roots = ash::Shell::GetAllRootWindows(); | 2293 aura::Window::Windows roots = ash::Shell::GetAllRootWindows(); |
2294 ASSERT_EQ(2u, roots.size()); | 2294 ASSERT_EQ(2u, roots.size()); |
2295 | 2295 |
2296 // Add another tab. | 2296 // Add another tab. |
2297 AddTabAndResetBrowser(browser()); | 2297 AddTabAndResetBrowser(browser()); |
2298 TabStrip* tab_strip = GetTabStripForBrowser(browser()); | 2298 TabStrip* tab_strip = GetTabStripForBrowser(browser()); |
2299 | 2299 |
2300 EXPECT_EQ("0 1", IDString(browser()->tab_strip_model())); | 2300 EXPECT_EQ("0 1", IDString(browser()->tab_strip_model())); |
2301 EXPECT_EQ(roots[0], browser()->window()->GetNativeWindow()->GetRootWindow()); | 2301 EXPECT_EQ(roots[0], browser()->window()->GetNativeWindow()->GetRootWindow()); |
2302 | 2302 |
2303 gfx::Rect work_area = | 2303 gfx::Rect work_area = display::Screen::GetScreen() |
2304 gfx::Screen::GetScreen()->GetDisplayNearestWindow(roots[1]).work_area(); | 2304 ->GetDisplayNearestWindow(roots[1]) |
| 2305 .work_area(); |
2305 browser()->window()->SetBounds(work_area); | 2306 browser()->window()->SetBounds(work_area); |
2306 EXPECT_EQ(roots[1], browser()->window()->GetNativeWindow()->GetRootWindow()); | 2307 EXPECT_EQ(roots[1], browser()->window()->GetNativeWindow()->GetRootWindow()); |
2307 | 2308 |
2308 // Move the second browser to the display. | 2309 // Move the second browser to the display. |
2309 gfx::Point final_destination = gfx::Screen::GetScreen() | 2310 gfx::Point final_destination = display::Screen::GetScreen() |
2310 ->GetDisplayNearestWindow(roots[0]) | 2311 ->GetDisplayNearestWindow(roots[0]) |
2311 .work_area() | 2312 .work_area() |
2312 .CenterPoint(); | 2313 .CenterPoint(); |
2313 | 2314 |
2314 // Move to the first tab and drag it enough so that it detaches, but not | 2315 // Move to the first tab and drag it enough so that it detaches, but not |
2315 // enough to move to another display. | 2316 // enough to move to another display. |
2316 gfx::Point tab_0_dst(GetCenterInScreenCoordinates(tab_strip->tab_at(0))); | 2317 gfx::Point tab_0_dst(GetCenterInScreenCoordinates(tab_strip->tab_at(0))); |
2317 ASSERT_TRUE(Press(tab_0_dst)); | 2318 ASSERT_TRUE(Press(tab_0_dst)); |
2318 tab_0_dst.Offset(0, GetDetachY(tab_strip)); | 2319 tab_0_dst.Offset(0, GetDetachY(tab_strip)); |
2319 ASSERT_TRUE(DragTabAndExecuteTaskWhenDone( | 2320 ASSERT_TRUE(DragTabAndExecuteTaskWhenDone( |
(...skipping 151 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
2471 DetachToBrowserTabDragControllerTest, | 2472 DetachToBrowserTabDragControllerTest, |
2472 ::testing::Values("mouse", "touch")); | 2473 ::testing::Values("mouse", "touch")); |
2473 INSTANTIATE_TEST_CASE_P(TabDragging, | 2474 INSTANTIATE_TEST_CASE_P(TabDragging, |
2474 DetachToBrowserTabDragControllerTestTouch, | 2475 DetachToBrowserTabDragControllerTestTouch, |
2475 ::testing::Values("touch")); | 2476 ::testing::Values("touch")); |
2476 #else | 2477 #else |
2477 INSTANTIATE_TEST_CASE_P(TabDragging, | 2478 INSTANTIATE_TEST_CASE_P(TabDragging, |
2478 DetachToBrowserTabDragControllerTest, | 2479 DetachToBrowserTabDragControllerTest, |
2479 ::testing::Values("mouse")); | 2480 ::testing::Values("mouse")); |
2480 #endif | 2481 #endif |
OLD | NEW |