| 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 "ash/root_window_controller.h" | 5 #include "ash/root_window_controller.h" |
| 6 | 6 |
| 7 #include <memory> | 7 #include <memory> |
| 8 | 8 |
| 9 #include "ash/display/display_manager.h" | 9 #include "ash/display/display_manager.h" |
| 10 #include "ash/session/session_state_delegate.h" | 10 #include "ash/session/session_state_delegate.h" |
| 11 #include "ash/shelf/shelf_layout_manager.h" | |
| 12 #include "ash/shell.h" | 11 #include "ash/shell.h" |
| 13 #include "ash/shell_window_ids.h" | 12 #include "ash/shell_window_ids.h" |
| 14 #include "ash/system/tray/system_tray_delegate.h" | 13 #include "ash/system/tray/system_tray_delegate.h" |
| 15 #include "ash/test/ash_test_base.h" | 14 #include "ash/test/ash_test_base.h" |
| 16 #include "ash/test/display_manager_test_api.h" | 15 #include "ash/test/display_manager_test_api.h" |
| 17 #include "ash/wm/common/window_state.h" | 16 #include "ash/wm/common/window_state.h" |
| 18 #include "ash/wm/system_modal_container_layout_manager.h" | 17 #include "ash/wm/system_modal_container_layout_manager.h" |
| 19 #include "ash/wm/window_properties.h" | 18 #include "ash/wm/window_properties.h" |
| 20 #include "ash/wm/window_state_aura.h" | 19 #include "ash/wm/window_state_aura.h" |
| 21 #include "ash/wm/window_util.h" | 20 #include "ash/wm/window_util.h" |
| 22 #include "base/command_line.h" | 21 #include "base/command_line.h" |
| 23 #include "ui/aura/client/focus_change_observer.h" | 22 #include "ui/aura/client/focus_change_observer.h" |
| 24 #include "ui/aura/client/focus_client.h" | 23 #include "ui/aura/client/focus_client.h" |
| 25 #include "ui/aura/client/window_tree_client.h" | 24 #include "ui/aura/client/window_tree_client.h" |
| 26 #include "ui/aura/env.h" | 25 #include "ui/aura/env.h" |
| 27 #include "ui/aura/test/test_window_delegate.h" | 26 #include "ui/aura/test/test_window_delegate.h" |
| 28 #include "ui/aura/test/test_windows.h" | 27 #include "ui/aura/test/test_windows.h" |
| 29 #include "ui/aura/window.h" | 28 #include "ui/aura/window.h" |
| 30 #include "ui/aura/window_event_dispatcher.h" | 29 #include "ui/aura/window_event_dispatcher.h" |
| 31 #include "ui/aura/window_tracker.h" | 30 #include "ui/aura/window_tracker.h" |
| 32 #include "ui/base/ime/dummy_text_input_client.h" | 31 #include "ui/base/ime/dummy_text_input_client.h" |
| 33 #include "ui/base/ime/input_method.h" | 32 #include "ui/base/ime/input_method.h" |
| 34 #include "ui/base/ime/text_input_client.h" | 33 #include "ui/base/ime/text_input_client.h" |
| 35 #include "ui/events/test/event_generator.h" | 34 #include "ui/events/test/event_generator.h" |
| 36 #include "ui/events/test/test_event_handler.h" | 35 #include "ui/events/test/test_event_handler.h" |
| 36 #include "ui/keyboard/keyboard_controller.h" |
| 37 #include "ui/keyboard/keyboard_switches.h" | 37 #include "ui/keyboard/keyboard_switches.h" |
| 38 #include "ui/keyboard/keyboard_ui.h" | 38 #include "ui/keyboard/keyboard_ui.h" |
| 39 #include "ui/keyboard/keyboard_util.h" | 39 #include "ui/keyboard/keyboard_util.h" |
| 40 #include "ui/views/controls/menu/menu_controller.h" | 40 #include "ui/views/controls/menu/menu_controller.h" |
| 41 #include "ui/views/widget/widget.h" | 41 #include "ui/views/widget/widget.h" |
| 42 #include "ui/views/widget/widget_delegate.h" | 42 #include "ui/views/widget/widget_delegate.h" |
| 43 | 43 |
| 44 using aura::Window; | 44 using aura::Window; |
| 45 using views::Widget; | 45 using views::Widget; |
| 46 | 46 |
| (...skipping 80 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 127 ash::kShellWindowId_SystemModalContainer); | 127 ash::kShellWindowId_SystemModalContainer); |
| 128 } | 128 } |
| 129 }; | 129 }; |
| 130 | 130 |
| 131 TEST_F(RootWindowControllerTest, MoveWindows_Basic) { | 131 TEST_F(RootWindowControllerTest, MoveWindows_Basic) { |
| 132 if (!SupportsMultipleDisplays()) | 132 if (!SupportsMultipleDisplays()) |
| 133 return; | 133 return; |
| 134 // Windows origin should be doubled when moved to the 1st display. | 134 // Windows origin should be doubled when moved to the 1st display. |
| 135 UpdateDisplay("600x600,300x300"); | 135 UpdateDisplay("600x600,300x300"); |
| 136 aura::Window::Windows root_windows = Shell::GetAllRootWindows(); | 136 aura::Window::Windows root_windows = Shell::GetAllRootWindows(); |
| 137 RootWindowController* controller = Shell::GetPrimaryRootWindowController(); | |
| 138 ShelfLayoutManager* shelf_layout_manager = | |
| 139 controller->GetShelfLayoutManager(); | |
| 140 shelf_layout_manager->SetAutoHideBehavior( | |
| 141 ash::SHELF_AUTO_HIDE_BEHAVIOR_ALWAYS); | |
| 142 | 137 |
| 143 views::Widget* normal = CreateTestWidget(gfx::Rect(650, 10, 100, 100)); | 138 views::Widget* normal = CreateTestWidget(gfx::Rect(650, 10, 100, 100)); |
| 144 EXPECT_EQ(root_windows[1], normal->GetNativeView()->GetRootWindow()); | 139 EXPECT_EQ(root_windows[1], normal->GetNativeView()->GetRootWindow()); |
| 145 EXPECT_EQ("650,10 100x100", normal->GetWindowBoundsInScreen().ToString()); | 140 EXPECT_EQ("650,10 100x100", normal->GetWindowBoundsInScreen().ToString()); |
| 146 EXPECT_EQ("50,10 100x100", | 141 EXPECT_EQ("50,10 100x100", |
| 147 normal->GetNativeView()->GetBoundsInRootWindow().ToString()); | 142 normal->GetNativeView()->GetBoundsInRootWindow().ToString()); |
| 148 | 143 |
| 149 views::Widget* maximized = CreateTestWidget(gfx::Rect(700, 10, 100, 100)); | 144 views::Widget* maximized = CreateTestWidget(gfx::Rect(700, 10, 100, 100)); |
| 150 maximized->Maximize(); | 145 maximized->Maximize(); |
| 151 EXPECT_EQ(root_windows[1], maximized->GetNativeView()->GetRootWindow()); | 146 EXPECT_EQ(root_windows[1], maximized->GetNativeView()->GetRootWindow()); |
| (...skipping 45 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 197 UpdateDisplay("600x600"); | 192 UpdateDisplay("600x600"); |
| 198 | 193 |
| 199 // d2 must have been deleted. | 194 // d2 must have been deleted. |
| 200 EXPECT_FALSE(tracker.Contains(d2)); | 195 EXPECT_FALSE(tracker.Contains(d2)); |
| 201 | 196 |
| 202 EXPECT_EQ(root_windows[0], normal->GetNativeView()->GetRootWindow()); | 197 EXPECT_EQ(root_windows[0], normal->GetNativeView()->GetRootWindow()); |
| 203 EXPECT_EQ("100,20 100x100", normal->GetWindowBoundsInScreen().ToString()); | 198 EXPECT_EQ("100,20 100x100", normal->GetWindowBoundsInScreen().ToString()); |
| 204 EXPECT_EQ("100,20 100x100", | 199 EXPECT_EQ("100,20 100x100", |
| 205 normal->GetNativeView()->GetBoundsInRootWindow().ToString()); | 200 normal->GetNativeView()->GetBoundsInRootWindow().ToString()); |
| 206 | 201 |
| 207 // Maximized area on primary display has 3px (given as | 202 // Maximized area on primary display has 47px (ash::kShelfSize) inset at the |
| 208 // kAutoHideSize in shelf_layout_manager.cc) inset at the bottom. | 203 // bottom. |
| 209 | 204 |
| 210 // First clear fullscreen status, since both fullscreen and maximized windows | 205 // First clear fullscreen status, since both fullscreen and maximized windows |
| 211 // share the same desktop workspace, which cancels the shelf status. | 206 // share the same desktop workspace, which cancels the shelf status. |
| 212 fullscreen->SetFullscreen(false); | 207 fullscreen->SetFullscreen(false); |
| 213 EXPECT_EQ(root_windows[0], maximized->GetNativeView()->GetRootWindow()); | 208 EXPECT_EQ(root_windows[0], maximized->GetNativeView()->GetRootWindow()); |
| 214 EXPECT_EQ("0,0 600x597", | 209 EXPECT_EQ("0,0 600x553", maximized->GetWindowBoundsInScreen().ToString()); |
| 215 maximized->GetWindowBoundsInScreen().ToString()); | 210 EXPECT_EQ("0,0 600x553", |
| 216 EXPECT_EQ("0,0 600x597", | |
| 217 maximized->GetNativeView()->GetBoundsInRootWindow().ToString()); | 211 maximized->GetNativeView()->GetBoundsInRootWindow().ToString()); |
| 218 | 212 |
| 219 // Set fullscreen to true, but maximized window's size won't change because | 213 // Set fullscreen to true, but maximized window's size won't change because |
| 220 // it's not visible. see crbug.com/504299. | 214 // it's not visible. see crbug.com/504299. |
| 221 fullscreen->SetFullscreen(true); | 215 fullscreen->SetFullscreen(true); |
| 222 EXPECT_EQ(root_windows[0], maximized->GetNativeView()->GetRootWindow()); | 216 EXPECT_EQ(root_windows[0], maximized->GetNativeView()->GetRootWindow()); |
| 223 EXPECT_EQ("0,0 600x597", maximized->GetWindowBoundsInScreen().ToString()); | 217 EXPECT_EQ("0,0 600x553", maximized->GetWindowBoundsInScreen().ToString()); |
| 224 EXPECT_EQ("0,0 600x597", | 218 EXPECT_EQ("0,0 600x553", |
| 225 maximized->GetNativeView()->GetBoundsInRootWindow().ToString()); | 219 maximized->GetNativeView()->GetBoundsInRootWindow().ToString()); |
| 226 | 220 |
| 227 EXPECT_EQ(root_windows[0], minimized->GetNativeView()->GetRootWindow()); | 221 EXPECT_EQ(root_windows[0], minimized->GetNativeView()->GetRootWindow()); |
| 228 EXPECT_EQ("400,20 100x100", | 222 EXPECT_EQ("400,20 100x100", |
| 229 minimized->GetWindowBoundsInScreen().ToString()); | 223 minimized->GetWindowBoundsInScreen().ToString()); |
| 230 | 224 |
| 231 EXPECT_EQ(root_windows[0], fullscreen->GetNativeView()->GetRootWindow()); | 225 EXPECT_EQ(root_windows[0], fullscreen->GetNativeView()->GetRootWindow()); |
| 232 EXPECT_TRUE(fullscreen->IsFullscreen()); | 226 EXPECT_TRUE(fullscreen->IsFullscreen()); |
| 233 EXPECT_EQ("0,0 600x600", | 227 EXPECT_EQ("0,0 600x600", |
| 234 fullscreen->GetWindowBoundsInScreen().ToString()); | 228 fullscreen->GetWindowBoundsInScreen().ToString()); |
| (...skipping 814 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 1049 keyboard_controller->ui()->GetKeyboardWindow()->SetBounds( | 1043 keyboard_controller->ui()->GetKeyboardWindow()->SetBounds( |
| 1050 gfx::Rect(0, 400, 800, 200)); | 1044 gfx::Rect(0, 400, 800, 200)); |
| 1051 EXPECT_EQ("0,400 800x200", keyboard_container->bounds().ToString()); | 1045 EXPECT_EQ("0,400 800x200", keyboard_container->bounds().ToString()); |
| 1052 | 1046 |
| 1053 UpdateDisplay("600x800"); | 1047 UpdateDisplay("600x800"); |
| 1054 EXPECT_EQ("0,600 600x200", keyboard_container->bounds().ToString()); | 1048 EXPECT_EQ("0,600 600x200", keyboard_container->bounds().ToString()); |
| 1055 } | 1049 } |
| 1056 | 1050 |
| 1057 } // namespace test | 1051 } // namespace test |
| 1058 } // namespace ash | 1052 } // namespace ash |
| OLD | NEW |