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/ash/chrome_shell_delegate.h" | 5 #include "ash/accelerators/accelerator_commands.h" |
James Cook
2013/10/29 16:13:04
nit: Maybe comment inside accelerator_commands_uni
oshima
2013/10/29 17:45:54
Done.
| |
6 | 6 |
7 #include "apps/shell_window.h" | 7 #include "apps/shell_window.h" |
8 #include "apps/ui/native_app_window.h" | 8 #include "apps/ui/native_app_window.h" |
9 #include "ash/accelerators/accelerator_commands.h" | |
10 #include "ash/ash_switches.h" | |
11 #include "ash/shell.h" | 9 #include "ash/shell.h" |
12 #include "ash/shell_delegate.h" | 10 #include "ash/shell_delegate.h" |
13 #include "ash/wm/window_state.h" | 11 #include "ash/wm/window_state.h" |
14 #include "base/command_line.h" | 12 #include "base/command_line.h" |
15 #include "chrome/browser/apps/app_browsertest_util.h" | 13 #include "chrome/browser/apps/app_browsertest_util.h" |
16 #include "chrome/browser/ui/browser.h" | 14 #include "chrome/browser/ui/browser.h" |
17 #include "chrome/browser/ui/browser_commands.h" | 15 #include "chrome/browser/ui/browser_commands.h" |
18 #include "chrome/browser/ui/browser_finder.h" | 16 #include "chrome/browser/ui/browser_finder.h" |
19 #include "chrome/browser/ui/browser_window.h" | 17 #include "chrome/browser/ui/browser_window.h" |
20 #include "chrome/test/base/in_process_browser_test.h" | 18 #include "chrome/test/base/in_process_browser_test.h" |
21 #include "ui/aura/client/aura_constants.h" | 19 #include "ui/aura/client/aura_constants.h" |
22 | 20 |
23 namespace { | 21 namespace { |
24 | 22 |
25 // Returns true if |window| is in immersive fullscreen. Infer whether |window| | 23 // Returns true if |window| is in immersive fullscreen. Infer whether |window| |
26 // is in immersive fullscreen based on whether the shelf is hidden when | 24 // is in immersive fullscreen based on whether the shelf is hidden when |
27 // |window| is fullscreen because DEPS does not allow the test to use | 25 // |window| is fullscreen because DEPS does not allow the test to use |
28 // BrowserView. (This is not quite right because the shelf is hidden if a window | 26 // BrowserView. (This is not quite right because the shelf is hidden if a window |
29 // is in both immersive fullscreen and tab fullscreen.) | 27 // is in both immersive fullscreen and tab fullscreen.) |
30 bool IsInImmersiveFullscreen(BrowserWindow* browser_window) { | 28 bool IsInImmersiveFullscreen(BrowserWindow* browser_window) { |
31 ash::wm::WindowState* window_state = ash::wm::GetWindowState( | 29 ash::wm::WindowState* window_state = ash::wm::GetWindowState( |
32 browser_window->GetNativeWindow()); | 30 browser_window->GetNativeWindow()); |
33 return window_state->IsFullscreen() && | 31 return window_state->IsFullscreen() && |
34 !window_state->hide_shelf_when_fullscreen(); | 32 !window_state->hide_shelf_when_fullscreen(); |
35 } | 33 } |
36 | 34 |
37 } // namespace | 35 } // namespace |
38 | 36 |
39 typedef InProcessBrowserTest ChromeShellDelegateBrowserTest; | 37 typedef InProcessBrowserTest AcceleratorCommandsBrowserTest; |
40 | |
41 // TODO(oshima): Move these tests to ash once ToggleFullscreen is moved | |
42 // to ash. crbug.com/309837. | |
43 | 38 |
44 // Confirm that toggling window miximized works properly | 39 // Confirm that toggling window miximized works properly |
45 IN_PROC_BROWSER_TEST_F(ChromeShellDelegateBrowserTest, ToggleMaximized) { | 40 IN_PROC_BROWSER_TEST_F(AcceleratorCommandsBrowserTest, ToggleMaximized) { |
46 ash::ShellDelegate* shell_delegate = ash::Shell::GetInstance()->delegate(); | 41 ash::ShellDelegate* shell_delegate = ash::Shell::GetInstance()->delegate(); |
47 ASSERT_TRUE(shell_delegate); | 42 ASSERT_TRUE(shell_delegate); |
48 ash::wm::WindowState* window_state = ash::wm::GetActiveWindowState(); | 43 ash::wm::WindowState* window_state = ash::wm::GetActiveWindowState(); |
49 ASSERT_TRUE(window_state); | 44 ASSERT_TRUE(window_state); |
50 | 45 |
51 // When not in fullscreen, accelerators::ToggleMaximized toggles Maximized. | 46 // When not in fullscreen, accelerators::ToggleMaximized toggles Maximized. |
52 EXPECT_FALSE(window_state->IsMaximized()); | 47 EXPECT_FALSE(window_state->IsMaximized()); |
53 ash::accelerators::ToggleMaximized(); | 48 ash::accelerators::ToggleMaximized(); |
54 EXPECT_TRUE(window_state->IsMaximized()); | 49 EXPECT_TRUE(window_state->IsMaximized()); |
55 ash::accelerators::ToggleMaximized(); | 50 ash::accelerators::ToggleMaximized(); |
56 EXPECT_FALSE(window_state->IsMaximized()); | 51 EXPECT_FALSE(window_state->IsMaximized()); |
57 | 52 |
58 // When in fullscreen accelerators::ToggleMaximized gets out of fullscreen. | 53 // When in fullscreen accelerators::ToggleMaximized gets out of fullscreen. |
59 EXPECT_FALSE(window_state->IsFullscreen()); | 54 EXPECT_FALSE(window_state->IsFullscreen()); |
60 Browser* browser = chrome::FindBrowserWithWindow(window_state->window()); | 55 Browser* browser = chrome::FindBrowserWithWindow(window_state->window()); |
61 ASSERT_TRUE(browser); | 56 ASSERT_TRUE(browser); |
62 chrome::ToggleFullscreenMode(browser); | 57 chrome::ToggleFullscreenMode(browser); |
63 EXPECT_TRUE(window_state->IsFullscreen()); | 58 EXPECT_TRUE(window_state->IsFullscreen()); |
64 ash::accelerators::ToggleMaximized(); | 59 ash::accelerators::ToggleMaximized(); |
65 EXPECT_FALSE(window_state->IsFullscreen()); | 60 EXPECT_FALSE(window_state->IsFullscreen()); |
66 EXPECT_FALSE(window_state->IsMaximized()); | 61 EXPECT_FALSE(window_state->IsMaximized()); |
67 ash::accelerators::ToggleMaximized(); | 62 ash::accelerators::ToggleMaximized(); |
68 EXPECT_FALSE(window_state->IsFullscreen()); | 63 EXPECT_FALSE(window_state->IsFullscreen()); |
69 EXPECT_TRUE(window_state->IsMaximized()); | 64 EXPECT_TRUE(window_state->IsMaximized()); |
70 } | 65 } |
71 | 66 |
72 // Confirm that toggling window fullscren works properly. | 67 // Confirm that toggling window fullscren works properly. |
73 IN_PROC_BROWSER_TEST_F(ChromeShellDelegateBrowserTest, ToggleFullscreen) { | 68 IN_PROC_BROWSER_TEST_F(AcceleratorCommandsBrowserTest, ToggleFullscreen) { |
74 ash::ShellDelegate* shell_delegate = ash::Shell::GetInstance()->delegate(); | 69 ash::ShellDelegate* shell_delegate = ash::Shell::GetInstance()->delegate(); |
75 ASSERT_TRUE(shell_delegate); | 70 ASSERT_TRUE(shell_delegate); |
76 | 71 |
77 // 1) ToggleFullscreen() should toggle whether a tabbed browser window is in | 72 // 1) ToggleFullscreen() should toggle whether a tabbed browser window is in |
78 // immersive fullscreen. | 73 // immersive fullscreen. |
79 ASSERT_TRUE(browser()->is_type_tabbed()); | 74 ASSERT_TRUE(browser()->is_type_tabbed()); |
80 BrowserWindow* browser_window = browser()->window(); | 75 BrowserWindow* browser_window = browser()->window(); |
81 ASSERT_TRUE(browser_window->IsActive()); | 76 ASSERT_TRUE(browser_window->IsActive()); |
82 EXPECT_FALSE(browser_window->IsMaximized()); | 77 EXPECT_FALSE(browser_window->IsMaximized()); |
83 EXPECT_FALSE(browser_window->IsFullscreen()); | 78 EXPECT_FALSE(browser_window->IsFullscreen()); |
84 | 79 |
85 shell_delegate->ToggleFullscreen(); | 80 ash::accelerators::ToggleFullscreen(); |
86 EXPECT_TRUE(browser_window->IsFullscreen()); | 81 EXPECT_TRUE(browser_window->IsFullscreen()); |
87 EXPECT_TRUE(IsInImmersiveFullscreen(browser_window)); | 82 EXPECT_TRUE(IsInImmersiveFullscreen(browser_window)); |
88 | 83 |
89 shell_delegate->ToggleFullscreen(); | 84 ash::accelerators::ToggleFullscreen(); |
90 EXPECT_FALSE(browser_window->IsMaximized()); | 85 EXPECT_FALSE(browser_window->IsMaximized()); |
91 EXPECT_FALSE(browser_window->IsFullscreen()); | 86 EXPECT_FALSE(browser_window->IsFullscreen()); |
92 | 87 |
93 // 2) ToggleFullscreen() should have no effect on windows which cannot be | 88 // 2) ToggleFullscreen() should have no effect on windows which cannot be |
94 // maximized. | 89 // maximized. |
95 browser_window->GetNativeWindow()->SetProperty(aura::client::kCanMaximizeKey, | 90 browser_window->GetNativeWindow()->SetProperty(aura::client::kCanMaximizeKey, |
96 false); | 91 false); |
97 shell_delegate->ToggleFullscreen(); | 92 ash::accelerators::ToggleFullscreen(); |
98 EXPECT_FALSE(browser_window->IsMaximized()); | 93 EXPECT_FALSE(browser_window->IsMaximized()); |
99 EXPECT_FALSE(browser_window->IsFullscreen()); | 94 EXPECT_FALSE(browser_window->IsFullscreen()); |
100 | 95 |
101 // 3) ToggleFullscreen() should maximize v1 app browser windows which use | 96 // 3) ToggleFullscreen() should maximize v1 app browser windows which use |
102 // AppNonClientFrameViewAsh. | 97 // AppNonClientFrameViewAsh. |
103 // TODO(pkotwicz): Figure out if we actually want this behavior. | 98 // TODO(pkotwicz): Figure out if we actually want this behavior. |
104 Browser::CreateParams browser_create_params(Browser::TYPE_POPUP, | 99 Browser::CreateParams browser_create_params(Browser::TYPE_POPUP, |
105 browser()->profile(), chrome::HOST_DESKTOP_TYPE_NATIVE); | 100 browser()->profile(), chrome::HOST_DESKTOP_TYPE_NATIVE); |
106 #if defined(OS_WIN) | 101 #if defined(OS_WIN) |
107 browser_create_params.host_desktop_type = chrome::HOST_DESKTOP_TYPE_ASH; | 102 browser_create_params.host_desktop_type = chrome::HOST_DESKTOP_TYPE_ASH; |
108 #endif // OS_WIN | 103 #endif // OS_WIN |
109 browser_create_params.app_name = "Test"; | 104 browser_create_params.app_name = "Test"; |
110 browser_create_params.app_type = Browser::APP_TYPE_HOST; | 105 browser_create_params.app_type = Browser::APP_TYPE_HOST; |
111 | 106 |
112 Browser* app_host_browser = new Browser(browser_create_params); | 107 Browser* app_host_browser = new Browser(browser_create_params); |
113 ASSERT_TRUE(app_host_browser->is_app()); | 108 ASSERT_TRUE(app_host_browser->is_app()); |
114 AddBlankTabAndShow(app_host_browser); | 109 AddBlankTabAndShow(app_host_browser); |
115 browser_window = app_host_browser->window(); | 110 browser_window = app_host_browser->window(); |
116 ASSERT_TRUE(browser_window->IsActive()); | 111 ASSERT_TRUE(browser_window->IsActive()); |
117 EXPECT_FALSE(browser_window->IsMaximized()); | 112 EXPECT_FALSE(browser_window->IsMaximized()); |
118 EXPECT_FALSE(browser_window->IsFullscreen()); | 113 EXPECT_FALSE(browser_window->IsFullscreen()); |
119 | 114 |
120 shell_delegate->ToggleFullscreen(); | 115 ash::accelerators::ToggleFullscreen(); |
121 EXPECT_TRUE(browser_window->IsMaximized()); | 116 EXPECT_TRUE(browser_window->IsMaximized()); |
122 | 117 |
123 shell_delegate->ToggleFullscreen(); | 118 ash::accelerators::ToggleFullscreen(); |
124 EXPECT_FALSE(browser_window->IsMaximized()); | 119 EXPECT_FALSE(browser_window->IsMaximized()); |
125 EXPECT_FALSE(browser_window->IsFullscreen()); | 120 EXPECT_FALSE(browser_window->IsFullscreen()); |
126 | 121 |
127 // 4) ToggleFullscreen() should put child windows of v1 apps into | 122 // 4) ToggleFullscreen() should put child windows of v1 apps into |
128 // non-immersive fullscreen. | 123 // non-immersive fullscreen. |
129 browser_create_params.host_desktop_type = chrome::HOST_DESKTOP_TYPE_NATIVE; | 124 browser_create_params.host_desktop_type = chrome::HOST_DESKTOP_TYPE_NATIVE; |
130 browser_create_params.app_type = Browser::APP_TYPE_CHILD; | 125 browser_create_params.app_type = Browser::APP_TYPE_CHILD; |
131 Browser* app_child_browser = new Browser(browser_create_params); | 126 Browser* app_child_browser = new Browser(browser_create_params); |
132 ASSERT_TRUE(app_child_browser->is_app()); | 127 ASSERT_TRUE(app_child_browser->is_app()); |
133 AddBlankTabAndShow(app_child_browser); | 128 AddBlankTabAndShow(app_child_browser); |
134 browser_window = app_child_browser->window(); | 129 browser_window = app_child_browser->window(); |
135 ASSERT_TRUE(browser_window->IsActive()); | 130 ASSERT_TRUE(browser_window->IsActive()); |
136 EXPECT_FALSE(browser_window->IsMaximized()); | 131 EXPECT_FALSE(browser_window->IsMaximized()); |
137 EXPECT_FALSE(browser_window->IsFullscreen()); | 132 EXPECT_FALSE(browser_window->IsFullscreen()); |
138 | 133 |
139 shell_delegate->ToggleFullscreen(); | 134 ash::accelerators::ToggleFullscreen(); |
140 EXPECT_TRUE(browser_window->IsFullscreen()); | 135 EXPECT_TRUE(browser_window->IsFullscreen()); |
141 EXPECT_FALSE(IsInImmersiveFullscreen(browser_window)); | 136 EXPECT_FALSE(IsInImmersiveFullscreen(browser_window)); |
142 | 137 |
143 shell_delegate->ToggleFullscreen(); | 138 ash::accelerators::ToggleFullscreen(); |
144 EXPECT_FALSE(browser_window->IsMaximized()); | 139 EXPECT_FALSE(browser_window->IsMaximized()); |
145 EXPECT_FALSE(browser_window->IsFullscreen()); | 140 EXPECT_FALSE(browser_window->IsFullscreen()); |
146 | 141 |
147 // 5) ToggleFullscreen() should put popup browser windows into non-immersive | 142 // 5) ToggleFullscreen() should put popup browser windows into non-immersive |
148 // fullscreen. | 143 // fullscreen. |
149 browser_create_params.app_name = ""; | 144 browser_create_params.app_name = ""; |
150 Browser* popup_browser = new Browser(browser_create_params); | 145 Browser* popup_browser = new Browser(browser_create_params); |
151 ASSERT_TRUE(popup_browser->is_type_popup()); | 146 ASSERT_TRUE(popup_browser->is_type_popup()); |
152 ASSERT_FALSE(popup_browser->is_app()); | 147 ASSERT_FALSE(popup_browser->is_app()); |
153 AddBlankTabAndShow(popup_browser); | 148 AddBlankTabAndShow(popup_browser); |
154 browser_window = popup_browser->window(); | 149 browser_window = popup_browser->window(); |
155 ASSERT_TRUE(browser_window->IsActive()); | 150 ASSERT_TRUE(browser_window->IsActive()); |
156 EXPECT_FALSE(browser_window->IsMaximized()); | 151 EXPECT_FALSE(browser_window->IsMaximized()); |
157 EXPECT_FALSE(browser_window->IsFullscreen()); | 152 EXPECT_FALSE(browser_window->IsFullscreen()); |
158 | 153 |
159 shell_delegate->ToggleFullscreen(); | 154 ash::accelerators::ToggleFullscreen(); |
160 EXPECT_TRUE(browser_window->IsFullscreen()); | 155 EXPECT_TRUE(browser_window->IsFullscreen()); |
161 EXPECT_FALSE(IsInImmersiveFullscreen(browser_window)); | 156 EXPECT_FALSE(IsInImmersiveFullscreen(browser_window)); |
162 | 157 |
163 shell_delegate->ToggleFullscreen(); | 158 ash::accelerators::ToggleFullscreen(); |
164 EXPECT_FALSE(browser_window->IsMaximized()); | 159 EXPECT_FALSE(browser_window->IsMaximized()); |
165 EXPECT_FALSE(browser_window->IsFullscreen()); | 160 EXPECT_FALSE(browser_window->IsFullscreen()); |
166 } | 161 } |
167 | 162 |
168 typedef extensions::PlatformAppBrowserTest | 163 typedef extensions::PlatformAppBrowserTest |
169 ChromeShellDelegatePlatformAppBrowserTest; | 164 AcceleratorCommandsPlatformAppBrowserTest; |
170 | 165 |
171 // Test that ToggleFullscreen() toggles the platform app's fullscreen state. | 166 // Test that ToggleFullscreen() toggles the platform app's fullscreen state. |
172 IN_PROC_BROWSER_TEST_F(ChromeShellDelegatePlatformAppBrowserTest, | 167 IN_PROC_BROWSER_TEST_F(AcceleratorCommandsPlatformAppBrowserTest, |
173 ToggleFullscreenPlatformApp) { | 168 ToggleFullscreenPlatformApp) { |
174 ash::ShellDelegate* shell_delegate = ash::Shell::GetInstance()->delegate(); | 169 ash::ShellDelegate* shell_delegate = ash::Shell::GetInstance()->delegate(); |
175 ASSERT_TRUE(shell_delegate); | 170 ASSERT_TRUE(shell_delegate); |
176 | 171 |
177 const extensions::Extension* extension = LoadAndLaunchPlatformApp("minimal"); | 172 const extensions::Extension* extension = LoadAndLaunchPlatformApp("minimal"); |
178 apps::ShellWindow* shell_window = CreateShellWindow(extension); | 173 apps::ShellWindow* shell_window = CreateShellWindow(extension); |
179 apps::NativeAppWindow* app_window = shell_window->GetBaseWindow(); | 174 apps::NativeAppWindow* app_window = shell_window->GetBaseWindow(); |
180 ASSERT_TRUE(shell_window->GetBaseWindow()->IsActive()); | 175 ASSERT_TRUE(shell_window->GetBaseWindow()->IsActive()); |
181 EXPECT_FALSE(app_window->IsMaximized()); | 176 EXPECT_FALSE(app_window->IsMaximized()); |
182 EXPECT_FALSE(app_window->IsFullscreen()); | 177 EXPECT_FALSE(app_window->IsFullscreen()); |
183 | 178 |
184 shell_delegate->ToggleFullscreen(); | 179 ash::accelerators::ToggleFullscreen(); |
185 EXPECT_TRUE(app_window->IsFullscreen()); | 180 EXPECT_TRUE(app_window->IsFullscreen()); |
186 | 181 |
187 shell_delegate->ToggleFullscreen(); | 182 ash::accelerators::ToggleFullscreen(); |
188 EXPECT_FALSE(app_window->IsMaximized()); | 183 EXPECT_FALSE(app_window->IsMaximized()); |
189 EXPECT_FALSE(app_window->IsFullscreen()); | 184 EXPECT_FALSE(app_window->IsFullscreen()); |
190 | 185 |
191 CloseShellWindow(shell_window); | 186 CloseShellWindow(shell_window); |
192 } | 187 } |
OLD | NEW |