Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright 2013 The Chromium Authors. All rights reserved. | 1 // Copyright 2013 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/accelerators/accelerator_commands.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/ash_switches.h" | |
| 9 #include "ash/shell.h" | 10 #include "ash/shell.h" |
| 10 #include "ash/wm/window_state.h" | 11 #include "ash/wm/window_state.h" |
| 11 #include "base/command_line.h" | 12 #include "base/command_line.h" |
| 12 #include "chrome/browser/apps/app_browsertest_util.h" | 13 #include "chrome/browser/apps/app_browsertest_util.h" |
| 13 #include "chrome/browser/ui/browser.h" | 14 #include "chrome/browser/ui/browser.h" |
| 14 #include "chrome/browser/ui/browser_commands.h" | 15 #include "chrome/browser/ui/browser_commands.h" |
| 15 #include "chrome/browser/ui/browser_finder.h" | 16 #include "chrome/browser/ui/browser_finder.h" |
| 16 #include "chrome/browser/ui/browser_window.h" | 17 #include "chrome/browser/ui/browser_window.h" |
| 17 #include "chrome/test/base/in_process_browser_test.h" | 18 #include "chrome/test/base/in_process_browser_test.h" |
| 18 #include "ui/aura/client/aura_constants.h" | 19 #include "ui/aura/client/aura_constants.h" |
| 19 | 20 |
| 20 namespace { | 21 namespace { |
| 21 | 22 |
| 22 // Returns true if |window| is in immersive fullscreen. Infer whether |window| | 23 // Returns true if |window| is in immersive fullscreen. Infer whether |window| |
| 23 // 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 |
| 24 // |window| is fullscreen because DEPS does not allow the test to use | 25 // |window| is fullscreen. (This is not quite right because the shelf is hidden |
| 25 // BrowserView. (This is not quite right because the shelf is hidden if a window | 26 // if a window is in both immersive fullscreen and tab fullscreen.) |
| 26 // is in both immersive fullscreen and tab fullscreen.) | 27 bool IsInImmersiveFullscreen(aura::Window* window) { |
| 27 bool IsInImmersiveFullscreen(BrowserWindow* browser_window) { | 28 ash::wm::WindowState* window_state = ash::wm::GetWindowState(window); |
| 28 ash::wm::WindowState* window_state = ash::wm::GetWindowState( | |
| 29 browser_window->GetNativeWindow()); | |
| 30 return window_state->IsFullscreen() && | 29 return window_state->IsFullscreen() && |
| 31 !window_state->hide_shelf_when_fullscreen(); | 30 !window_state->hide_shelf_when_fullscreen(); |
| 32 } | 31 } |
| 33 | 32 |
| 34 } // namespace | 33 } // namespace |
| 35 | 34 |
| 36 typedef InProcessBrowserTest AcceleratorCommandsBrowserTest; | 35 typedef InProcessBrowserTest AcceleratorCommandsBrowserTest; |
| 37 | 36 |
| 38 // Confirm that toggling window miximized works properly | 37 // Confirm that toggling window miximized works properly |
| 39 IN_PROC_BROWSER_TEST_F(AcceleratorCommandsBrowserTest, ToggleMaximized) { | 38 IN_PROC_BROWSER_TEST_F(AcceleratorCommandsBrowserTest, ToggleMaximized) { |
| (...skipping 17 matching lines...) Expand all Loading... | |
| 57 ash::accelerators::ToggleMaximized(); | 56 ash::accelerators::ToggleMaximized(); |
| 58 EXPECT_FALSE(window_state->IsFullscreen()); | 57 EXPECT_FALSE(window_state->IsFullscreen()); |
| 59 EXPECT_FALSE(window_state->IsMaximized()); | 58 EXPECT_FALSE(window_state->IsMaximized()); |
| 60 ash::accelerators::ToggleMaximized(); | 59 ash::accelerators::ToggleMaximized(); |
| 61 EXPECT_FALSE(window_state->IsFullscreen()); | 60 EXPECT_FALSE(window_state->IsFullscreen()); |
| 62 EXPECT_TRUE(window_state->IsMaximized()); | 61 EXPECT_TRUE(window_state->IsMaximized()); |
| 63 } | 62 } |
| 64 | 63 |
| 65 // Confirm that toggling window fullscren works properly. | 64 // Confirm that toggling window fullscren works properly. |
| 66 IN_PROC_BROWSER_TEST_F(AcceleratorCommandsBrowserTest, ToggleFullscreen) { | 65 IN_PROC_BROWSER_TEST_F(AcceleratorCommandsBrowserTest, ToggleFullscreen) { |
| 66 bool put_all_windows_in_immersive = CommandLine::ForCurrentProcess()-> | |
| 67 HasSwitch(ash::switches::kAshEnableImmersiveFullscreenForAllWindows); | |
| 68 | |
| 67 ASSERT_TRUE(ash::Shell::HasInstance()) << "No Instance"; | 69 ASSERT_TRUE(ash::Shell::HasInstance()) << "No Instance"; |
| 68 // 1) ToggleFullscreen() should toggle whether a tabbed browser window is in | 70 // 1) ToggleFullscreen() should always toggle whether a tabbed browser window |
| 69 // immersive fullscreen. | 71 // is in immersive fullscreen. |
| 70 ASSERT_TRUE(browser()->is_type_tabbed()); | 72 ASSERT_TRUE(browser()->is_type_tabbed()); |
| 71 BrowserWindow* browser_window = browser()->window(); | 73 BrowserWindow* browser_window = browser()->window(); |
| 72 ASSERT_TRUE(browser_window->IsActive()); | 74 ASSERT_TRUE(browser_window->IsActive()); |
| 73 EXPECT_FALSE(browser_window->IsMaximized()); | |
| 74 EXPECT_FALSE(browser_window->IsFullscreen()); | 75 EXPECT_FALSE(browser_window->IsFullscreen()); |
| 75 | 76 |
| 76 ash::accelerators::ToggleFullscreen(); | 77 ash::accelerators::ToggleFullscreen(); |
| 77 EXPECT_TRUE(browser_window->IsFullscreen()); | 78 EXPECT_TRUE(browser_window->IsFullscreen()); |
| 78 EXPECT_TRUE(IsInImmersiveFullscreen(browser_window)); | 79 EXPECT_TRUE(IsInImmersiveFullscreen(browser_window->GetNativeWindow())); |
| 79 | 80 |
| 80 ash::accelerators::ToggleFullscreen(); | 81 ash::accelerators::ToggleFullscreen(); |
| 81 EXPECT_FALSE(browser_window->IsMaximized()); | |
| 82 EXPECT_FALSE(browser_window->IsFullscreen()); | 82 EXPECT_FALSE(browser_window->IsFullscreen()); |
| 83 | 83 |
| 84 // 2) ToggleFullscreen() should have no effect on windows which cannot be | 84 // 2) ToggleFullscreen() should have no effect on windows which cannot be |
| 85 // maximized. | 85 // maximized. |
| 86 browser_window->GetNativeWindow()->SetProperty(aura::client::kCanMaximizeKey, | 86 browser_window->GetNativeWindow()->SetProperty(aura::client::kCanMaximizeKey, |
| 87 false); | 87 false); |
| 88 ash::accelerators::ToggleFullscreen(); | 88 ash::accelerators::ToggleFullscreen(); |
| 89 EXPECT_FALSE(browser_window->IsMaximized()); | |
| 90 EXPECT_FALSE(browser_window->IsFullscreen()); | 89 EXPECT_FALSE(browser_window->IsFullscreen()); |
| 91 | 90 |
| 92 // 3) ToggleFullscreen() should put v1 apps into non-immersive fullscreen. | 91 // 3) ToggleFullscreen() should put v1 apps into immersive fullscreen only if |
| 92 // the kAshEnableImmersiveFullscreenForAllWindows command line flag is set. | |
| 93 Browser::CreateParams browser_create_params(Browser::TYPE_POPUP, | 93 Browser::CreateParams browser_create_params(Browser::TYPE_POPUP, |
| 94 browser()->profile(), chrome::HOST_DESKTOP_TYPE_NATIVE); | 94 browser()->profile(), chrome::HOST_DESKTOP_TYPE_NATIVE); |
| 95 #if defined(OS_WIN) | 95 #if defined(OS_WIN) |
| 96 browser_create_params.host_desktop_type = chrome::HOST_DESKTOP_TYPE_ASH; | 96 browser_create_params.host_desktop_type = chrome::HOST_DESKTOP_TYPE_ASH; |
| 97 #endif // OS_WIN | 97 #endif // OS_WIN |
| 98 browser_create_params.app_name = "Test"; | 98 browser_create_params.app_name = "Test"; |
| 99 | 99 |
| 100 Browser* app_host_browser = new Browser(browser_create_params); | 100 Browser* app_host_browser = new Browser(browser_create_params); |
| 101 ASSERT_TRUE(app_host_browser->is_app()); | 101 ASSERT_TRUE(app_host_browser->is_app()); |
| 102 AddBlankTabAndShow(app_host_browser); | 102 AddBlankTabAndShow(app_host_browser); |
| 103 browser_window = app_host_browser->window(); | 103 browser_window = app_host_browser->window(); |
| 104 ASSERT_TRUE(browser_window->IsActive()); | 104 ASSERT_TRUE(browser_window->IsActive()); |
| 105 EXPECT_FALSE(browser_window->IsMaximized()); | |
| 106 EXPECT_FALSE(browser_window->IsFullscreen()); | 105 EXPECT_FALSE(browser_window->IsFullscreen()); |
| 107 | 106 |
| 108 ash::accelerators::ToggleFullscreen(); | 107 ash::accelerators::ToggleFullscreen(); |
| 109 EXPECT_TRUE(browser_window->IsFullscreen()); | 108 EXPECT_TRUE(browser_window->IsFullscreen()); |
| 110 EXPECT_FALSE(IsInImmersiveFullscreen(browser_window)); | 109 EXPECT_EQ(put_all_windows_in_immersive, |
| 110 IsInImmersiveFullscreen(browser_window->GetNativeWindow())); | |
| 111 | 111 |
| 112 ash::accelerators::ToggleFullscreen(); | 112 ash::accelerators::ToggleFullscreen(); |
| 113 EXPECT_FALSE(browser_window->IsMaximized()); | |
| 114 EXPECT_FALSE(browser_window->IsFullscreen()); | 113 EXPECT_FALSE(browser_window->IsFullscreen()); |
| 115 | 114 |
| 116 // 4) ToggleFullscreen() should put popup browser windows into non-immersive | 115 // 4) ToggleFullscreen() should put popup browser windows into immersive |
| 117 // fullscreen. | 116 // fullscreen only if the kAshEnableImmersiveFullscreenForAllWindows command |
| 117 // line flag is set. | |
| 118 browser_create_params.app_name = ""; | 118 browser_create_params.app_name = ""; |
| 119 Browser* popup_browser = new Browser(browser_create_params); | 119 Browser* popup_browser = new Browser(browser_create_params); |
| 120 ASSERT_TRUE(popup_browser->is_type_popup()); | 120 ASSERT_TRUE(popup_browser->is_type_popup()); |
| 121 ASSERT_FALSE(popup_browser->is_app()); | 121 ASSERT_FALSE(popup_browser->is_app()); |
| 122 AddBlankTabAndShow(popup_browser); | 122 AddBlankTabAndShow(popup_browser); |
| 123 browser_window = popup_browser->window(); | 123 browser_window = popup_browser->window(); |
| 124 ASSERT_TRUE(browser_window->IsActive()); | 124 ASSERT_TRUE(browser_window->IsActive()); |
| 125 EXPECT_FALSE(browser_window->IsMaximized()); | |
| 126 EXPECT_FALSE(browser_window->IsFullscreen()); | 125 EXPECT_FALSE(browser_window->IsFullscreen()); |
| 127 | 126 |
| 128 ash::accelerators::ToggleFullscreen(); | 127 ash::accelerators::ToggleFullscreen(); |
| 129 EXPECT_TRUE(browser_window->IsFullscreen()); | 128 EXPECT_TRUE(browser_window->IsFullscreen()); |
| 130 EXPECT_FALSE(IsInImmersiveFullscreen(browser_window)); | 129 EXPECT_EQ(put_all_windows_in_immersive, |
| 130 IsInImmersiveFullscreen(browser_window->GetNativeWindow())); | |
| 131 | 131 |
| 132 ash::accelerators::ToggleFullscreen(); | 132 ash::accelerators::ToggleFullscreen(); |
| 133 EXPECT_FALSE(browser_window->IsMaximized()); | |
| 134 EXPECT_FALSE(browser_window->IsFullscreen()); | 133 EXPECT_FALSE(browser_window->IsFullscreen()); |
| 135 } | 134 } |
| 136 | 135 |
| 137 typedef extensions::PlatformAppBrowserTest | 136 typedef extensions::PlatformAppBrowserTest |
| 138 AcceleratorCommandsPlatformAppBrowserTest; | 137 AcceleratorCommandsPlatformAppBrowserTest; |
| 139 | 138 |
| 140 // Test that ToggleFullscreen() toggles the platform app's fullscreen state. | 139 // Test the behavior of platform apps when ToggleFullscreen() is called. |
| 141 IN_PROC_BROWSER_TEST_F(AcceleratorCommandsPlatformAppBrowserTest, | 140 IN_PROC_BROWSER_TEST_F(AcceleratorCommandsPlatformAppBrowserTest, |
| 142 ToggleFullscreenPlatformApp) { | 141 ToggleFullscreenPlatformApp) { |
| 143 ASSERT_TRUE(ash::Shell::HasInstance()) << "No Instance"; | 142 ASSERT_TRUE(ash::Shell::HasInstance()) << "No Instance"; |
| 144 const extensions::Extension* extension = LoadAndLaunchPlatformApp("minimal"); | 143 const extensions::Extension* extension = LoadAndLaunchPlatformApp("minimal"); |
| 145 apps::ShellWindow* shell_window = CreateShellWindow(extension); | |
| 146 apps::NativeAppWindow* app_window = shell_window->GetBaseWindow(); | |
| 147 ASSERT_TRUE(shell_window->GetBaseWindow()->IsActive()); | |
| 148 EXPECT_FALSE(app_window->IsMaximized()); | |
| 149 EXPECT_FALSE(app_window->IsFullscreen()); | |
| 150 | 144 |
| 151 ash::accelerators::ToggleFullscreen(); | 145 { |
| 152 EXPECT_TRUE(app_window->IsFullscreen()); | 146 // Test that ToggleFullscreen() toggles a platform's app's fullscreen |
| 147 // state and that it additonally puts the app into immersive fullscreen | |
| 148 // if the kAshEnableImmersiveFullscreenForAllWindows command line flag | |
| 149 // is set. | |
| 150 bool put_all_windows_in_immersive = CommandLine::ForCurrentProcess()-> | |
| 151 HasSwitch(ash::switches::kAshEnableImmersiveFullscreenForAllWindows); | |
| 152 apps::ShellWindow::CreateParams params; | |
| 153 params.frame = apps::ShellWindow::FRAME_CHROME; | |
| 154 apps::ShellWindow* shell_window = CreateShellWindowFromParams( | |
| 155 extension, params); | |
| 156 apps::NativeAppWindow* app_window = shell_window->GetBaseWindow(); | |
| 157 ASSERT_TRUE(shell_window->GetBaseWindow()->IsActive()); | |
| 158 EXPECT_FALSE(app_window->IsFullscreen()); | |
| 153 | 159 |
| 154 ash::accelerators::ToggleFullscreen(); | 160 ash::accelerators::ToggleFullscreen(); |
| 155 EXPECT_FALSE(app_window->IsMaximized()); | 161 EXPECT_TRUE(app_window->IsFullscreen()); |
| 156 EXPECT_FALSE(app_window->IsFullscreen()); | 162 EXPECT_EQ(put_all_windows_in_immersive, |
| 163 IsInImmersiveFullscreen(app_window->GetNativeWindow())); | |
| 157 | 164 |
| 158 CloseShellWindow(shell_window); | 165 ash::accelerators::ToggleFullscreen(); |
| 166 EXPECT_FALSE(app_window->IsFullscreen()); | |
| 167 | |
| 168 CloseShellWindow(shell_window); | |
| 169 } | |
| 170 | |
| 171 { | |
| 172 // Repeat the test, but make sure that frameless platform apps are never put | |
| 173 // into immersive fullscreen. | |
| 174 apps::ShellWindow::CreateParams params; | |
| 175 params.frame = apps::ShellWindow::FRAME_NONE; | |
| 176 apps::ShellWindow* shell_window = CreateShellWindowFromParams( | |
| 177 extension, params); | |
| 178 apps::NativeAppWindow* app_window = shell_window->GetBaseWindow(); | |
| 179 ASSERT_TRUE(shell_window->GetBaseWindow()->IsActive()); | |
| 180 EXPECT_FALSE(app_window->IsFullscreen()); | |
| 181 | |
| 182 ash::accelerators::ToggleFullscreen(); | |
| 183 EXPECT_TRUE(app_window->IsFullscreen()); | |
| 184 EXPECT_FALSE(IsInImmersiveFullscreen(app_window->GetNativeWindow())); | |
| 185 | |
| 186 ash::accelerators::ToggleFullscreen(); | |
| 187 EXPECT_FALSE(app_window->IsFullscreen()); | |
| 188 | |
| 189 CloseShellWindow(shell_window); | |
| 190 } | |
|
James Cook
2013/11/25 19:09:20
Nice test.
| |
| 159 } | 191 } |
| OLD | NEW |