Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(566)

Side by Side Diff: chrome/browser/ui/ash/accelerator_commands_browsertest.cc

Issue 83343006: Enable immersive fullscreen for hosted apps part 2 (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Created 7 years ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch | Annotate | Revision Log
OLDNEW
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
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 }
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698