| 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 "ash/focus_cycler.h" | 5 #include "ash/focus_cycler.h" |
| 6 | 6 |
| 7 #include "ash/launcher/launcher.h" | 7 #include "ash/launcher/launcher.h" |
| 8 #include "ash/root_window_controller.h" | 8 #include "ash/root_window_controller.h" |
| 9 #include "ash/shell.h" | 9 #include "ash/shell.h" |
| 10 #include "ash/shell_window_ids.h" | 10 #include "ash/shell_window_ids.h" |
| 11 #include "ash/system/status_area_widget.h" | 11 #include "ash/system/status_area_widget.h" |
| 12 #include "ash/system/status_area_widget_delegate.h" | 12 #include "ash/system/status_area_widget_delegate.h" |
| 13 #include "ash/system/tray/system_tray.h" | 13 #include "ash/system/tray/system_tray.h" |
| 14 #include "ash/wm/window_util.h" | 14 #include "ash/wm/window_util.h" |
| 15 #include "ash/test/ash_test_base.h" | 15 #include "ash/test/ash_test_base.h" |
| 16 #include "ash/shell_factory.h" | 16 #include "ash/shell_factory.h" |
| 17 #include "ui/aura/test/test_windows.h" | 17 #include "ui/aura/test/test_windows.h" |
| 18 #include "ui/aura/window.h" | 18 #include "ui/aura/window.h" |
| 19 #include "ui/views/controls/button/menu_button.h" | 19 #include "ui/views/controls/button/menu_button.h" |
| 20 #include "ui/views/widget/widget.h" | 20 #include "ui/views/widget/widget.h" |
| 21 | 21 |
| 22 namespace ash { | 22 namespace ash { |
| 23 namespace test { | 23 namespace test { |
| 24 | 24 |
| 25 using aura::test::CreateTestWindowWithId; | |
| 26 using aura::Window; | 25 using aura::Window; |
| 27 using internal::FocusCycler; | 26 using internal::FocusCycler; |
| 28 | 27 |
| 29 namespace { | 28 namespace { |
| 30 | 29 |
| 31 internal::StatusAreaWidgetDelegate* GetStatusAreaWidgetDelegate( | 30 internal::StatusAreaWidgetDelegate* GetStatusAreaWidgetDelegate( |
| 32 views::Widget* widget) { | 31 views::Widget* widget) { |
| 33 return static_cast<internal::StatusAreaWidgetDelegate*>( | 32 return static_cast<internal::StatusAreaWidgetDelegate*>( |
| 34 widget->GetContentsView()); | 33 widget->GetContentsView()); |
| 35 } | 34 } |
| (...skipping 62 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 98 | 97 |
| 99 private: | 98 private: |
| 100 scoped_ptr<FocusCycler> focus_cycler_; | 99 scoped_ptr<FocusCycler> focus_cycler_; |
| 101 scoped_ptr<SystemTray> tray_; | 100 scoped_ptr<SystemTray> tray_; |
| 102 | 101 |
| 103 DISALLOW_COPY_AND_ASSIGN(FocusCyclerTest); | 102 DISALLOW_COPY_AND_ASSIGN(FocusCyclerTest); |
| 104 }; | 103 }; |
| 105 | 104 |
| 106 TEST_F(FocusCyclerTest, CycleFocusBrowserOnly) { | 105 TEST_F(FocusCyclerTest, CycleFocusBrowserOnly) { |
| 107 // Create a single test window. | 106 // Create a single test window. |
| 108 scoped_ptr<Window> window0(CreateTestWindowWithId(0, NULL)); | 107 scoped_ptr<Window> window0(CreateTestWindowInShellWithId(0)); |
| 109 wm::ActivateWindow(window0.get()); | 108 wm::ActivateWindow(window0.get()); |
| 110 EXPECT_TRUE(wm::IsActiveWindow(window0.get())); | 109 EXPECT_TRUE(wm::IsActiveWindow(window0.get())); |
| 111 | 110 |
| 112 // Cycle the window | 111 // Cycle the window |
| 113 focus_cycler()->RotateFocus(FocusCycler::FORWARD); | 112 focus_cycler()->RotateFocus(FocusCycler::FORWARD); |
| 114 EXPECT_TRUE(wm::IsActiveWindow(window0.get())); | 113 EXPECT_TRUE(wm::IsActiveWindow(window0.get())); |
| 115 } | 114 } |
| 116 | 115 |
| 117 TEST_F(FocusCyclerTest, CycleFocusForward) { | 116 TEST_F(FocusCyclerTest, CycleFocusForward) { |
| 118 ASSERT_TRUE(CreateTray()); | 117 ASSERT_TRUE(CreateTray()); |
| 119 | 118 |
| 120 InstallFocusCycleOnLauncher(); | 119 InstallFocusCycleOnLauncher(); |
| 121 | 120 |
| 122 // Create a single test window. | 121 // Create a single test window. |
| 123 scoped_ptr<Window> window0(CreateTestWindowWithId(0, NULL)); | 122 scoped_ptr<Window> window0(CreateTestWindowInShellWithId(0)); |
| 124 wm::ActivateWindow(window0.get()); | 123 wm::ActivateWindow(window0.get()); |
| 125 EXPECT_TRUE(wm::IsActiveWindow(window0.get())); | 124 EXPECT_TRUE(wm::IsActiveWindow(window0.get())); |
| 126 | 125 |
| 127 // Cycle focus to the status area | 126 // Cycle focus to the status area |
| 128 focus_cycler()->RotateFocus(FocusCycler::FORWARD); | 127 focus_cycler()->RotateFocus(FocusCycler::FORWARD); |
| 129 EXPECT_TRUE(tray()->GetWidget()->IsActive()); | 128 EXPECT_TRUE(tray()->GetWidget()->IsActive()); |
| 130 | 129 |
| 131 // Cycle focus to the launcher | 130 // Cycle focus to the launcher |
| 132 focus_cycler()->RotateFocus(FocusCycler::FORWARD); | 131 focus_cycler()->RotateFocus(FocusCycler::FORWARD); |
| 133 EXPECT_TRUE(launcher_widget()->IsActive()); | 132 EXPECT_TRUE(launcher_widget()->IsActive()); |
| 134 | 133 |
| 135 // Cycle focus to the browser | 134 // Cycle focus to the browser |
| 136 focus_cycler()->RotateFocus(FocusCycler::FORWARD); | 135 focus_cycler()->RotateFocus(FocusCycler::FORWARD); |
| 137 EXPECT_TRUE(wm::IsActiveWindow(window0.get())); | 136 EXPECT_TRUE(wm::IsActiveWindow(window0.get())); |
| 138 } | 137 } |
| 139 | 138 |
| 140 TEST_F(FocusCyclerTest, CycleFocusBackward) { | 139 TEST_F(FocusCyclerTest, CycleFocusBackward) { |
| 141 ASSERT_TRUE(CreateTray()); | 140 ASSERT_TRUE(CreateTray()); |
| 142 | 141 |
| 143 InstallFocusCycleOnLauncher(); | 142 InstallFocusCycleOnLauncher(); |
| 144 | 143 |
| 145 // Create a single test window. | 144 // Create a single test window. |
| 146 scoped_ptr<Window> window0(CreateTestWindowWithId(0, NULL)); | 145 scoped_ptr<Window> window0(CreateTestWindowInShellWithId(0)); |
| 147 wm::ActivateWindow(window0.get()); | 146 wm::ActivateWindow(window0.get()); |
| 148 EXPECT_TRUE(wm::IsActiveWindow(window0.get())); | 147 EXPECT_TRUE(wm::IsActiveWindow(window0.get())); |
| 149 | 148 |
| 150 // Cycle focus to the launcher | 149 // Cycle focus to the launcher |
| 151 focus_cycler()->RotateFocus(FocusCycler::BACKWARD); | 150 focus_cycler()->RotateFocus(FocusCycler::BACKWARD); |
| 152 EXPECT_TRUE(launcher_widget()->IsActive()); | 151 EXPECT_TRUE(launcher_widget()->IsActive()); |
| 153 | 152 |
| 154 // Cycle focus to the status area | 153 // Cycle focus to the status area |
| 155 focus_cycler()->RotateFocus(FocusCycler::BACKWARD); | 154 focus_cycler()->RotateFocus(FocusCycler::BACKWARD); |
| 156 EXPECT_TRUE(tray()->GetWidget()->IsActive()); | 155 EXPECT_TRUE(tray()->GetWidget()->IsActive()); |
| 157 | 156 |
| 158 // Cycle focus to the browser | 157 // Cycle focus to the browser |
| 159 focus_cycler()->RotateFocus(FocusCycler::BACKWARD); | 158 focus_cycler()->RotateFocus(FocusCycler::BACKWARD); |
| 160 EXPECT_TRUE(wm::IsActiveWindow(window0.get())); | 159 EXPECT_TRUE(wm::IsActiveWindow(window0.get())); |
| 161 } | 160 } |
| 162 | 161 |
| 163 TEST_F(FocusCyclerTest, CycleFocusForwardBackward) { | 162 TEST_F(FocusCyclerTest, CycleFocusForwardBackward) { |
| 164 ASSERT_TRUE(CreateTray()); | 163 ASSERT_TRUE(CreateTray()); |
| 165 | 164 |
| 166 InstallFocusCycleOnLauncher(); | 165 InstallFocusCycleOnLauncher(); |
| 167 | 166 |
| 168 // Create a single test window. | 167 // Create a single test window. |
| 169 scoped_ptr<Window> window0(CreateTestWindowWithId(0, NULL)); | 168 scoped_ptr<Window> window0(CreateTestWindowInShellWithId(0)); |
| 170 wm::ActivateWindow(window0.get()); | 169 wm::ActivateWindow(window0.get()); |
| 171 EXPECT_TRUE(wm::IsActiveWindow(window0.get())); | 170 EXPECT_TRUE(wm::IsActiveWindow(window0.get())); |
| 172 | 171 |
| 173 // Cycle focus to the launcher | 172 // Cycle focus to the launcher |
| 174 focus_cycler()->RotateFocus(FocusCycler::BACKWARD); | 173 focus_cycler()->RotateFocus(FocusCycler::BACKWARD); |
| 175 EXPECT_TRUE(launcher_widget()->IsActive()); | 174 EXPECT_TRUE(launcher_widget()->IsActive()); |
| 176 | 175 |
| 177 // Cycle focus to the status area | 176 // Cycle focus to the status area |
| 178 focus_cycler()->RotateFocus(FocusCycler::BACKWARD); | 177 focus_cycler()->RotateFocus(FocusCycler::BACKWARD); |
| 179 EXPECT_TRUE(tray()->GetWidget()->IsActive()); | 178 EXPECT_TRUE(tray()->GetWidget()->IsActive()); |
| (...skipping 43 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 223 focus_cycler()->RotateFocus(FocusCycler::BACKWARD); | 222 focus_cycler()->RotateFocus(FocusCycler::BACKWARD); |
| 224 EXPECT_TRUE(tray()->GetWidget()->IsActive()); | 223 EXPECT_TRUE(tray()->GetWidget()->IsActive()); |
| 225 } | 224 } |
| 226 | 225 |
| 227 TEST_F(FocusCyclerTest, Launcher_CycleFocusForward) { | 226 TEST_F(FocusCyclerTest, Launcher_CycleFocusForward) { |
| 228 ASSERT_TRUE(CreateTray()); | 227 ASSERT_TRUE(CreateTray()); |
| 229 InstallFocusCycleOnLauncher(); | 228 InstallFocusCycleOnLauncher(); |
| 230 launcher_widget()->Hide(); | 229 launcher_widget()->Hide(); |
| 231 | 230 |
| 232 // Create a single test window. | 231 // Create a single test window. |
| 233 scoped_ptr<Window> window0(CreateTestWindowWithId(0, NULL)); | 232 scoped_ptr<Window> window0(CreateTestWindowInShellWithId(0)); |
| 234 wm::ActivateWindow(window0.get()); | 233 wm::ActivateWindow(window0.get()); |
| 235 EXPECT_TRUE(wm::IsActiveWindow(window0.get())); | 234 EXPECT_TRUE(wm::IsActiveWindow(window0.get())); |
| 236 | 235 |
| 237 // Cycle focus to the status area | 236 // Cycle focus to the status area |
| 238 focus_cycler()->RotateFocus(FocusCycler::FORWARD); | 237 focus_cycler()->RotateFocus(FocusCycler::FORWARD); |
| 239 EXPECT_TRUE(tray()->GetWidget()->IsActive()); | 238 EXPECT_TRUE(tray()->GetWidget()->IsActive()); |
| 240 | 239 |
| 241 // Cycle focus to the browser | 240 // Cycle focus to the browser |
| 242 focus_cycler()->RotateFocus(FocusCycler::FORWARD); | 241 focus_cycler()->RotateFocus(FocusCycler::FORWARD); |
| 243 EXPECT_TRUE(wm::IsActiveWindow(window0.get())); | 242 EXPECT_TRUE(wm::IsActiveWindow(window0.get())); |
| 244 } | 243 } |
| 245 | 244 |
| 246 TEST_F(FocusCyclerTest, Launcher_CycleFocusBackwardInvisible) { | 245 TEST_F(FocusCyclerTest, Launcher_CycleFocusBackwardInvisible) { |
| 247 ASSERT_TRUE(CreateTray()); | 246 ASSERT_TRUE(CreateTray()); |
| 248 InstallFocusCycleOnLauncher(); | 247 InstallFocusCycleOnLauncher(); |
| 249 launcher_widget()->Hide(); | 248 launcher_widget()->Hide(); |
| 250 | 249 |
| 251 // Create a single test window. | 250 // Create a single test window. |
| 252 scoped_ptr<Window> window0(CreateTestWindowWithId(0, NULL)); | 251 scoped_ptr<Window> window0(CreateTestWindowInShellWithId(0)); |
| 253 wm::ActivateWindow(window0.get()); | 252 wm::ActivateWindow(window0.get()); |
| 254 EXPECT_TRUE(wm::IsActiveWindow(window0.get())); | 253 EXPECT_TRUE(wm::IsActiveWindow(window0.get())); |
| 255 | 254 |
| 256 // Cycle focus to the status area | 255 // Cycle focus to the status area |
| 257 focus_cycler()->RotateFocus(FocusCycler::BACKWARD); | 256 focus_cycler()->RotateFocus(FocusCycler::BACKWARD); |
| 258 EXPECT_TRUE(tray()->GetWidget()->IsActive()); | 257 EXPECT_TRUE(tray()->GetWidget()->IsActive()); |
| 259 | 258 |
| 260 // Cycle focus to the browser | 259 // Cycle focus to the browser |
| 261 focus_cycler()->RotateFocus(FocusCycler::BACKWARD); | 260 focus_cycler()->RotateFocus(FocusCycler::BACKWARD); |
| 262 EXPECT_TRUE(wm::IsActiveWindow(window0.get())); | 261 EXPECT_TRUE(wm::IsActiveWindow(window0.get())); |
| 263 } | 262 } |
| 264 | 263 |
| 265 } // namespace test | 264 } // namespace test |
| 266 } // namespace ash | 265 } // namespace ash |
| OLD | NEW |