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