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

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

Issue 42353002: Introduce WindowStateDelegate::ToggleFullscreen (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Created 7 years, 1 month 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 (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 }
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698