Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright 2014 The Chromium Authors. All rights reserved. | 1 // Copyright 2014 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/virtual_keyboard_controller.h" | 5 #include "ash/virtual_keyboard_controller.h" |
| 6 | 6 |
| 7 #include <utility> | 7 #include <utility> |
| 8 #include <vector> | 8 #include <vector> |
| 9 | 9 |
| 10 #include "ash/shell.h" | 10 #include "ash/shell.h" |
| 11 #include "ash/system/chromeos/virtual_keyboard/virtual_keyboard_observer.h" | 11 #include "ash/system/chromeos/virtual_keyboard/virtual_keyboard_observer.h" |
| 12 #include "ash/test/ash_test_base.h" | 12 #include "ash/test/ash_test_base.h" |
| 13 #include "ash/wm/maximize_mode/maximize_mode_controller.h" | 13 #include "ash/wm/maximize_mode/maximize_mode_controller.h" |
| 14 #include "ash/wm/maximize_mode/scoped_disable_internal_mouse_and_keyboard.h" | 14 #include "ash/wm/maximize_mode/scoped_disable_internal_mouse_and_keyboard.h" |
| 15 #include "ash_switches.h" | 15 #include "ash_switches.h" |
| 16 #include "base/command_line.h" | 16 #include "base/command_line.h" |
| 17 #include "ui/events/devices/device_data_manager.h" | 17 #include "ui/events/devices/device_data_manager.h" |
| 18 #include "ui/events/devices/device_hotplug_event_observer.h" | 18 #include "ui/events/devices/device_hotplug_event_observer.h" |
| 19 #include "ui/events/devices/input_device.h" | 19 #include "ui/events/devices/input_device.h" |
| 20 #include "ui/events/devices/keyboard_device.h" | |
| 21 #include "ui/events/devices/touchscreen_device.h" | 20 #include "ui/events/devices/touchscreen_device.h" |
| 22 #include "ui/keyboard/keyboard_export.h" | 21 #include "ui/keyboard/keyboard_export.h" |
| 23 #include "ui/keyboard/keyboard_switches.h" | 22 #include "ui/keyboard/keyboard_switches.h" |
| 24 #include "ui/keyboard/keyboard_util.h" | 23 #include "ui/keyboard/keyboard_util.h" |
| 25 | 24 |
| 26 namespace ash { | 25 namespace ash { |
| 27 namespace test { | 26 namespace test { |
| 28 | 27 |
| 29 class VirtualKeyboardControllerTest : public AshTestBase { | 28 class VirtualKeyboardControllerTest : public AshTestBase { |
| 30 public: | 29 public: |
| 31 VirtualKeyboardControllerTest() {} | 30 VirtualKeyboardControllerTest() {} |
| 32 ~VirtualKeyboardControllerTest() override {} | 31 ~VirtualKeyboardControllerTest() override {} |
| 33 | 32 |
| 34 void UpdateTouchscreenDevices( | 33 void UpdateTouchscreenDevices( |
| 35 std::vector<ui::TouchscreenDevice> touchscreen_devices) { | 34 std::vector<ui::TouchscreenDevice> touchscreen_devices) { |
| 36 ui::DeviceHotplugEventObserver* manager = | 35 ui::DeviceHotplugEventObserver* manager = |
| 37 ui::DeviceDataManager::GetInstance(); | 36 ui::DeviceDataManager::GetInstance(); |
| 38 manager->OnTouchscreenDevicesUpdated(touchscreen_devices); | 37 manager->OnTouchscreenDevicesUpdated(touchscreen_devices); |
| 39 } | 38 } |
| 40 | 39 |
| 41 void UpdateKeyboardDevices(std::vector<ui::KeyboardDevice> keyboard_devices) { | 40 void UpdateKeyboardDevices(std::vector<ui::InputDevice> keyboard_devices) { |
| 42 ui::DeviceHotplugEventObserver* manager = | 41 ui::DeviceHotplugEventObserver* manager = |
| 43 ui::DeviceDataManager::GetInstance(); | 42 ui::DeviceDataManager::GetInstance(); |
| 44 manager->OnKeyboardDevicesUpdated(keyboard_devices); | 43 manager->OnKeyboardDevicesUpdated(keyboard_devices); |
| 45 } | 44 } |
| 46 | 45 |
| 47 // Sets the event blocker on the maximized window controller. | 46 // Sets the event blocker on the maximized window controller. |
| 48 void SetEventBlocker( | 47 void SetEventBlocker( |
| 49 std::unique_ptr<ScopedDisableInternalMouseAndKeyboard> blocker) { | 48 std::unique_ptr<ScopedDisableInternalMouseAndKeyboard> blocker) { |
| 50 Shell::GetInstance()->maximize_mode_controller()->event_blocker_ = | 49 Shell::GetInstance()->maximize_mode_controller()->event_blocker_ = |
| 51 std::move(blocker); | 50 std::move(blocker); |
| 52 } | 51 } |
| 53 | 52 |
| 54 void SetUp() override { | 53 void SetUp() override { |
| 55 base::CommandLine::ForCurrentProcess()->AppendSwitch( | 54 base::CommandLine::ForCurrentProcess()->AppendSwitch( |
| 56 keyboard::switches::kDisableSmartVirtualKeyboard); | 55 keyboard::switches::kDisableSmartVirtualKeyboard); |
| 57 AshTestBase::SetUp(); | 56 AshTestBase::SetUp(); |
| 58 UpdateKeyboardDevices(std::vector<ui::KeyboardDevice>()); | 57 UpdateKeyboardDevices(std::vector<ui::InputDevice>()); |
| 59 UpdateTouchscreenDevices(std::vector<ui::TouchscreenDevice>()); | 58 UpdateTouchscreenDevices(std::vector<ui::TouchscreenDevice>()); |
| 60 } | 59 } |
| 61 | 60 |
| 62 private: | 61 private: |
| 63 DISALLOW_COPY_AND_ASSIGN(VirtualKeyboardControllerTest); | 62 DISALLOW_COPY_AND_ASSIGN(VirtualKeyboardControllerTest); |
| 64 }; | 63 }; |
| 65 | 64 |
| 66 TEST_F(VirtualKeyboardControllerTest, EnabledDuringMaximizeMode) { | 65 TEST_F(VirtualKeyboardControllerTest, EnabledDuringMaximizeMode) { |
| 67 ASSERT_FALSE(keyboard::IsKeyboardEnabled()); | 66 ASSERT_FALSE(keyboard::IsKeyboardEnabled()); |
| 68 // Toggle maximized mode on. | 67 // Toggle maximized mode on. |
| 69 Shell::GetInstance() | 68 Shell::GetInstance() |
| 70 ->maximize_mode_controller() | 69 ->maximize_mode_controller() |
| 71 ->EnableMaximizeModeWindowManager(true); | 70 ->EnableMaximizeModeWindowManager(true); |
| 72 EXPECT_TRUE(keyboard::IsKeyboardEnabled()); | 71 EXPECT_TRUE(keyboard::IsKeyboardEnabled()); |
| 73 // Toggle maximized mode off. | 72 // Toggle maximized mode off. |
| 74 Shell::GetInstance() | 73 Shell::GetInstance() |
| 75 ->maximize_mode_controller() | 74 ->maximize_mode_controller() |
| 76 ->EnableMaximizeModeWindowManager(false); | 75 ->EnableMaximizeModeWindowManager(false); |
| 77 EXPECT_FALSE(keyboard::IsKeyboardEnabled()); | 76 EXPECT_FALSE(keyboard::IsKeyboardEnabled()); |
| 78 } | 77 } |
| 79 | 78 |
| 80 // Mock event blocker that enables the internal keyboard when it's destructor | 79 // Mock event blocker that enables the internal keyboard when it's destructor |
| 81 // is called. | 80 // is called. |
| 82 class MockEventBlocker : public ScopedDisableInternalMouseAndKeyboard { | 81 class MockEventBlocker : public ScopedDisableInternalMouseAndKeyboard { |
| 83 public: | 82 public: |
| 84 MockEventBlocker() {} | 83 MockEventBlocker() {} |
| 85 ~MockEventBlocker() override { | 84 ~MockEventBlocker() override { |
| 86 std::vector<ui::KeyboardDevice> keyboards; | 85 std::vector<ui::InputDevice> keyboards; |
|
sky
2016/05/31 18:13:45
input_devices or maybe keyboard_devices?
kylechar
2016/05/31 19:31:11
Done.
| |
| 87 keyboards.push_back(ui::KeyboardDevice( | 86 keyboards.push_back(ui::InputDevice( |
| 88 1, ui::InputDeviceType::INPUT_DEVICE_INTERNAL, "keyboard")); | 87 1, ui::InputDeviceType::INPUT_DEVICE_INTERNAL, "keyboard")); |
| 89 ui::DeviceHotplugEventObserver* manager = | 88 ui::DeviceHotplugEventObserver* manager = |
| 90 ui::DeviceDataManager::GetInstance(); | 89 ui::DeviceDataManager::GetInstance(); |
| 91 manager->OnKeyboardDevicesUpdated(keyboards); | 90 manager->OnKeyboardDevicesUpdated(keyboards); |
| 92 } | 91 } |
| 93 | 92 |
| 94 private: | 93 private: |
| 95 DISALLOW_COPY_AND_ASSIGN(MockEventBlocker); | 94 DISALLOW_COPY_AND_ASSIGN(MockEventBlocker); |
| 96 }; | 95 }; |
| 97 | 96 |
| (...skipping 12 matching lines...) Expand all Loading... | |
| 110 class VirtualKeyboardControllerAutoTest : public VirtualKeyboardControllerTest, | 109 class VirtualKeyboardControllerAutoTest : public VirtualKeyboardControllerTest, |
| 111 public VirtualKeyboardObserver { | 110 public VirtualKeyboardObserver { |
| 112 public: | 111 public: |
| 113 VirtualKeyboardControllerAutoTest() : notified_(false), suppressed_(false) {} | 112 VirtualKeyboardControllerAutoTest() : notified_(false), suppressed_(false) {} |
| 114 ~VirtualKeyboardControllerAutoTest() override {} | 113 ~VirtualKeyboardControllerAutoTest() override {} |
| 115 | 114 |
| 116 void SetUp() override { | 115 void SetUp() override { |
| 117 AshTestBase::SetUp(); | 116 AshTestBase::SetUp(); |
| 118 // Set the current list of devices to empty so that they don't interfere | 117 // Set the current list of devices to empty so that they don't interfere |
| 119 // with the test. | 118 // with the test. |
| 120 UpdateKeyboardDevices(std::vector<ui::KeyboardDevice>()); | 119 UpdateKeyboardDevices(std::vector<ui::InputDevice>()); |
| 121 UpdateTouchscreenDevices(std::vector<ui::TouchscreenDevice>()); | 120 UpdateTouchscreenDevices(std::vector<ui::TouchscreenDevice>()); |
| 122 Shell::GetInstance()->system_tray_notifier()->AddVirtualKeyboardObserver( | 121 Shell::GetInstance()->system_tray_notifier()->AddVirtualKeyboardObserver( |
| 123 this); | 122 this); |
| 124 } | 123 } |
| 125 | 124 |
| 126 void TearDown() override { | 125 void TearDown() override { |
| 127 Shell::GetInstance()->system_tray_notifier()->RemoveVirtualKeyboardObserver( | 126 Shell::GetInstance()->system_tray_notifier()->RemoveVirtualKeyboardObserver( |
| 128 this); | 127 this); |
| 129 AshTestBase::TearDown(); | 128 AshTestBase::TearDown(); |
| 130 } | 129 } |
| (...skipping 23 matching lines...) Expand all Loading... | |
| 154 }; | 153 }; |
| 155 | 154 |
| 156 // Tests that the onscreen keyboard is disabled if an internal keyboard is | 155 // Tests that the onscreen keyboard is disabled if an internal keyboard is |
| 157 // present and maximized mode is disabled. | 156 // present and maximized mode is disabled. |
| 158 TEST_F(VirtualKeyboardControllerAutoTest, DisabledIfInternalKeyboardPresent) { | 157 TEST_F(VirtualKeyboardControllerAutoTest, DisabledIfInternalKeyboardPresent) { |
| 159 std::vector<ui::TouchscreenDevice> screens; | 158 std::vector<ui::TouchscreenDevice> screens; |
| 160 screens.push_back( | 159 screens.push_back( |
| 161 ui::TouchscreenDevice(1, ui::InputDeviceType::INPUT_DEVICE_INTERNAL, | 160 ui::TouchscreenDevice(1, ui::InputDeviceType::INPUT_DEVICE_INTERNAL, |
| 162 "Touchscreen", gfx::Size(1024, 768), 0)); | 161 "Touchscreen", gfx::Size(1024, 768), 0)); |
| 163 UpdateTouchscreenDevices(screens); | 162 UpdateTouchscreenDevices(screens); |
| 164 std::vector<ui::KeyboardDevice> keyboards; | 163 std::vector<ui::InputDevice> keyboards; |
|
sky
2016/05/31 18:13:45
keyboard_devices?
kylechar
2016/05/31 19:31:11
Done.
| |
| 165 keyboards.push_back(ui::KeyboardDevice( | 164 keyboards.push_back(ui::InputDevice( |
| 166 1, ui::InputDeviceType::INPUT_DEVICE_INTERNAL, "keyboard")); | 165 1, ui::InputDeviceType::INPUT_DEVICE_INTERNAL, "keyboard")); |
| 167 UpdateKeyboardDevices(keyboards); | 166 UpdateKeyboardDevices(keyboards); |
| 168 ASSERT_FALSE(keyboard::IsKeyboardEnabled()); | 167 ASSERT_FALSE(keyboard::IsKeyboardEnabled()); |
| 169 // Remove the internal keyboard. Virtual keyboard should now show. | 168 // Remove the internal keyboard. Virtual keyboard should now show. |
| 170 UpdateKeyboardDevices(std::vector<ui::KeyboardDevice>()); | 169 UpdateKeyboardDevices(std::vector<ui::InputDevice>()); |
| 171 EXPECT_TRUE(keyboard::IsKeyboardEnabled()); | 170 EXPECT_TRUE(keyboard::IsKeyboardEnabled()); |
| 172 // Replug in the internal keyboard. Virtual keyboard should hide. | 171 // Replug in the internal keyboard. Virtual keyboard should hide. |
| 173 UpdateKeyboardDevices(keyboards); | 172 UpdateKeyboardDevices(keyboards); |
| 174 EXPECT_FALSE(keyboard::IsKeyboardEnabled()); | 173 EXPECT_FALSE(keyboard::IsKeyboardEnabled()); |
| 175 } | 174 } |
| 176 | 175 |
| 177 TEST_F(VirtualKeyboardControllerAutoTest, DisabledIfNoTouchScreen) { | 176 TEST_F(VirtualKeyboardControllerAutoTest, DisabledIfNoTouchScreen) { |
| 178 std::vector<ui::TouchscreenDevice> devices; | 177 std::vector<ui::TouchscreenDevice> devices; |
| 179 // Add a touchscreen. Keyboard should deploy. | 178 // Add a touchscreen. Keyboard should deploy. |
| 180 devices.push_back( | 179 devices.push_back( |
| 181 ui::TouchscreenDevice(1, ui::InputDeviceType::INPUT_DEVICE_EXTERNAL, | 180 ui::TouchscreenDevice(1, ui::InputDeviceType::INPUT_DEVICE_EXTERNAL, |
| 182 "Touchscreen", gfx::Size(800, 600), 0)); | 181 "Touchscreen", gfx::Size(800, 600), 0)); |
| 183 UpdateTouchscreenDevices(devices); | 182 UpdateTouchscreenDevices(devices); |
| 184 EXPECT_TRUE(keyboard::IsKeyboardEnabled()); | 183 EXPECT_TRUE(keyboard::IsKeyboardEnabled()); |
| 185 // Remove touchscreen. Keyboard should hide. | 184 // Remove touchscreen. Keyboard should hide. |
| 186 UpdateTouchscreenDevices(std::vector<ui::TouchscreenDevice>()); | 185 UpdateTouchscreenDevices(std::vector<ui::TouchscreenDevice>()); |
| 187 EXPECT_FALSE(keyboard::IsKeyboardEnabled()); | 186 EXPECT_FALSE(keyboard::IsKeyboardEnabled()); |
| 188 } | 187 } |
| 189 | 188 |
| 190 TEST_F(VirtualKeyboardControllerAutoTest, SuppressedIfExternalKeyboardPresent) { | 189 TEST_F(VirtualKeyboardControllerAutoTest, SuppressedIfExternalKeyboardPresent) { |
| 191 std::vector<ui::TouchscreenDevice> screens; | 190 std::vector<ui::TouchscreenDevice> screens; |
| 192 screens.push_back( | 191 screens.push_back( |
| 193 ui::TouchscreenDevice(1, ui::InputDeviceType::INPUT_DEVICE_INTERNAL, | 192 ui::TouchscreenDevice(1, ui::InputDeviceType::INPUT_DEVICE_INTERNAL, |
| 194 "Touchscreen", gfx::Size(1024, 768), 0)); | 193 "Touchscreen", gfx::Size(1024, 768), 0)); |
| 195 UpdateTouchscreenDevices(screens); | 194 UpdateTouchscreenDevices(screens); |
| 196 std::vector<ui::KeyboardDevice> keyboards; | 195 std::vector<ui::InputDevice> keyboards; |
|
sky
2016/05/31 18:13:45
keyboard_devices?
kylechar
2016/05/31 19:31:12
Done.
| |
| 197 keyboards.push_back(ui::KeyboardDevice( | 196 keyboards.push_back(ui::InputDevice( |
| 198 1, ui::InputDeviceType::INPUT_DEVICE_EXTERNAL, "keyboard")); | 197 1, ui::InputDeviceType::INPUT_DEVICE_EXTERNAL, "keyboard")); |
| 199 UpdateKeyboardDevices(keyboards); | 198 UpdateKeyboardDevices(keyboards); |
| 200 ASSERT_FALSE(keyboard::IsKeyboardEnabled()); | 199 ASSERT_FALSE(keyboard::IsKeyboardEnabled()); |
| 201 ASSERT_TRUE(notified()); | 200 ASSERT_TRUE(notified()); |
| 202 ASSERT_TRUE(IsVirtualKeyboardSuppressed()); | 201 ASSERT_TRUE(IsVirtualKeyboardSuppressed()); |
| 203 // Toggle show keyboard. Keyboard should be visible. | 202 // Toggle show keyboard. Keyboard should be visible. |
| 204 ResetObserver(); | 203 ResetObserver(); |
| 205 Shell::GetInstance() | 204 Shell::GetInstance() |
| 206 ->virtual_keyboard_controller() | 205 ->virtual_keyboard_controller() |
| 207 ->ToggleIgnoreExternalKeyboard(); | 206 ->ToggleIgnoreExternalKeyboard(); |
| 208 ASSERT_TRUE(keyboard::IsKeyboardEnabled()); | 207 ASSERT_TRUE(keyboard::IsKeyboardEnabled()); |
| 209 ASSERT_TRUE(notified()); | 208 ASSERT_TRUE(notified()); |
| 210 ASSERT_TRUE(IsVirtualKeyboardSuppressed()); | 209 ASSERT_TRUE(IsVirtualKeyboardSuppressed()); |
| 211 // Toggle show keyboard. Keyboard should be hidden. | 210 // Toggle show keyboard. Keyboard should be hidden. |
| 212 ResetObserver(); | 211 ResetObserver(); |
| 213 Shell::GetInstance() | 212 Shell::GetInstance() |
| 214 ->virtual_keyboard_controller() | 213 ->virtual_keyboard_controller() |
| 215 ->ToggleIgnoreExternalKeyboard(); | 214 ->ToggleIgnoreExternalKeyboard(); |
| 216 ASSERT_FALSE(keyboard::IsKeyboardEnabled()); | 215 ASSERT_FALSE(keyboard::IsKeyboardEnabled()); |
| 217 ASSERT_TRUE(notified()); | 216 ASSERT_TRUE(notified()); |
| 218 ASSERT_TRUE(IsVirtualKeyboardSuppressed()); | 217 ASSERT_TRUE(IsVirtualKeyboardSuppressed()); |
| 219 // Remove external keyboard. Should be notified that the keyboard is not | 218 // Remove external keyboard. Should be notified that the keyboard is not |
| 220 // suppressed. | 219 // suppressed. |
| 221 ResetObserver(); | 220 ResetObserver(); |
| 222 UpdateKeyboardDevices(std::vector<ui::KeyboardDevice>()); | 221 UpdateKeyboardDevices(std::vector<ui::InputDevice>()); |
| 223 ASSERT_TRUE(keyboard::IsKeyboardEnabled()); | 222 ASSERT_TRUE(keyboard::IsKeyboardEnabled()); |
| 224 ASSERT_TRUE(notified()); | 223 ASSERT_TRUE(notified()); |
| 225 ASSERT_FALSE(IsVirtualKeyboardSuppressed()); | 224 ASSERT_FALSE(IsVirtualKeyboardSuppressed()); |
| 226 } | 225 } |
| 227 | 226 |
| 228 // Tests handling multiple keyboards. Catches crbug.com/430252 | 227 // Tests handling multiple keyboards. Catches crbug.com/430252 |
| 229 TEST_F(VirtualKeyboardControllerAutoTest, HandleMultipleKeyboardsPresent) { | 228 TEST_F(VirtualKeyboardControllerAutoTest, HandleMultipleKeyboardsPresent) { |
| 230 std::vector<ui::KeyboardDevice> keyboards; | 229 std::vector<ui::InputDevice> keyboards; |
| 231 keyboards.push_back(ui::KeyboardDevice( | 230 keyboards.push_back(ui::InputDevice( |
| 232 1, ui::InputDeviceType::INPUT_DEVICE_INTERNAL, "keyboard")); | 231 1, ui::InputDeviceType::INPUT_DEVICE_INTERNAL, "keyboard")); |
| 233 keyboards.push_back(ui::KeyboardDevice( | 232 keyboards.push_back(ui::InputDevice( |
| 234 2, ui::InputDeviceType::INPUT_DEVICE_EXTERNAL, "keyboard")); | 233 2, ui::InputDeviceType::INPUT_DEVICE_EXTERNAL, "keyboard")); |
| 235 keyboards.push_back(ui::KeyboardDevice( | 234 keyboards.push_back(ui::InputDevice( |
| 236 3, ui::InputDeviceType::INPUT_DEVICE_EXTERNAL, "keyboard")); | 235 3, ui::InputDeviceType::INPUT_DEVICE_EXTERNAL, "keyboard")); |
| 237 UpdateKeyboardDevices(keyboards); | 236 UpdateKeyboardDevices(keyboards); |
| 238 ASSERT_FALSE(keyboard::IsKeyboardEnabled()); | 237 ASSERT_FALSE(keyboard::IsKeyboardEnabled()); |
| 239 } | 238 } |
| 240 | 239 |
| 241 // Tests maximized mode interaction without disabling the internal keyboard. | 240 // Tests maximized mode interaction without disabling the internal keyboard. |
| 242 TEST_F(VirtualKeyboardControllerAutoTest, EnabledDuringMaximizeMode) { | 241 TEST_F(VirtualKeyboardControllerAutoTest, EnabledDuringMaximizeMode) { |
| 243 std::vector<ui::TouchscreenDevice> screens; | 242 std::vector<ui::TouchscreenDevice> screens; |
| 244 screens.push_back( | 243 screens.push_back( |
| 245 ui::TouchscreenDevice(1, ui::InputDeviceType::INPUT_DEVICE_INTERNAL, | 244 ui::TouchscreenDevice(1, ui::InputDeviceType::INPUT_DEVICE_INTERNAL, |
| 246 "Touchscreen", gfx::Size(1024, 768), 0)); | 245 "Touchscreen", gfx::Size(1024, 768), 0)); |
| 247 UpdateTouchscreenDevices(screens); | 246 UpdateTouchscreenDevices(screens); |
| 248 std::vector<ui::KeyboardDevice> keyboards; | 247 std::vector<ui::InputDevice> keyboards; |
| 249 keyboards.push_back(ui::KeyboardDevice( | 248 keyboards.push_back(ui::InputDevice( |
| 250 1, ui::InputDeviceType::INPUT_DEVICE_INTERNAL, "Keyboard")); | 249 1, ui::InputDeviceType::INPUT_DEVICE_INTERNAL, "Keyboard")); |
| 251 UpdateKeyboardDevices(keyboards); | 250 UpdateKeyboardDevices(keyboards); |
| 252 ASSERT_FALSE(keyboard::IsKeyboardEnabled()); | 251 ASSERT_FALSE(keyboard::IsKeyboardEnabled()); |
| 253 // Toggle maximized mode on. | 252 // Toggle maximized mode on. |
| 254 Shell::GetInstance() | 253 Shell::GetInstance() |
| 255 ->maximize_mode_controller() | 254 ->maximize_mode_controller() |
| 256 ->EnableMaximizeModeWindowManager(true); | 255 ->EnableMaximizeModeWindowManager(true); |
| 257 ASSERT_TRUE(keyboard::IsKeyboardEnabled()); | 256 ASSERT_TRUE(keyboard::IsKeyboardEnabled()); |
| 258 // Toggle maximized mode off. | 257 // Toggle maximized mode off. |
| 259 Shell::GetInstance() | 258 Shell::GetInstance() |
| 260 ->maximize_mode_controller() | 259 ->maximize_mode_controller() |
| 261 ->EnableMaximizeModeWindowManager(false); | 260 ->EnableMaximizeModeWindowManager(false); |
| 262 ASSERT_FALSE(keyboard::IsKeyboardEnabled()); | 261 ASSERT_FALSE(keyboard::IsKeyboardEnabled()); |
| 263 } | 262 } |
| 264 | 263 |
| 265 // Tests that keyboard gets suppressed in maximized mode. | 264 // Tests that keyboard gets suppressed in maximized mode. |
| 266 TEST_F(VirtualKeyboardControllerAutoTest, SuppressedInMaximizedMode) { | 265 TEST_F(VirtualKeyboardControllerAutoTest, SuppressedInMaximizedMode) { |
| 267 std::vector<ui::TouchscreenDevice> screens; | 266 std::vector<ui::TouchscreenDevice> screens; |
| 268 screens.push_back( | 267 screens.push_back( |
| 269 ui::TouchscreenDevice(1, ui::InputDeviceType::INPUT_DEVICE_INTERNAL, | 268 ui::TouchscreenDevice(1, ui::InputDeviceType::INPUT_DEVICE_INTERNAL, |
| 270 "Touchscreen", gfx::Size(1024, 768), 0)); | 269 "Touchscreen", gfx::Size(1024, 768), 0)); |
| 271 UpdateTouchscreenDevices(screens); | 270 UpdateTouchscreenDevices(screens); |
| 272 std::vector<ui::KeyboardDevice> keyboards; | 271 std::vector<ui::InputDevice> keyboards; |
| 273 keyboards.push_back(ui::KeyboardDevice( | 272 keyboards.push_back(ui::InputDevice( |
| 274 1, ui::InputDeviceType::INPUT_DEVICE_INTERNAL, "Keyboard")); | 273 1, ui::InputDeviceType::INPUT_DEVICE_INTERNAL, "Keyboard")); |
| 275 keyboards.push_back(ui::KeyboardDevice( | 274 keyboards.push_back(ui::InputDevice( |
| 276 2, ui::InputDeviceType::INPUT_DEVICE_EXTERNAL, "Keyboard")); | 275 2, ui::InputDeviceType::INPUT_DEVICE_EXTERNAL, "Keyboard")); |
| 277 UpdateKeyboardDevices(keyboards); | 276 UpdateKeyboardDevices(keyboards); |
| 278 // Toggle maximized mode on. | 277 // Toggle maximized mode on. |
| 279 Shell::GetInstance() | 278 Shell::GetInstance() |
| 280 ->maximize_mode_controller() | 279 ->maximize_mode_controller() |
| 281 ->EnableMaximizeModeWindowManager(true); | 280 ->EnableMaximizeModeWindowManager(true); |
| 282 ASSERT_FALSE(keyboard::IsKeyboardEnabled()); | 281 ASSERT_FALSE(keyboard::IsKeyboardEnabled()); |
| 283 ASSERT_TRUE(notified()); | 282 ASSERT_TRUE(notified()); |
| 284 ASSERT_TRUE(IsVirtualKeyboardSuppressed()); | 283 ASSERT_TRUE(IsVirtualKeyboardSuppressed()); |
| 285 // Toggle show keyboard. Keyboard should be visible. | 284 // Toggle show keyboard. Keyboard should be visible. |
| (...skipping 45 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 331 }; | 330 }; |
| 332 | 331 |
| 333 // Tests that the controller cannot suppress the keyboard if the virtual | 332 // Tests that the controller cannot suppress the keyboard if the virtual |
| 334 // keyboard always enabled flag is active. | 333 // keyboard always enabled flag is active. |
| 335 TEST_F(VirtualKeyboardControllerAlwaysEnabledTest, DoesNotSuppressKeyboard) { | 334 TEST_F(VirtualKeyboardControllerAlwaysEnabledTest, DoesNotSuppressKeyboard) { |
| 336 std::vector<ui::TouchscreenDevice> screens; | 335 std::vector<ui::TouchscreenDevice> screens; |
| 337 screens.push_back( | 336 screens.push_back( |
| 338 ui::TouchscreenDevice(1, ui::InputDeviceType::INPUT_DEVICE_INTERNAL, | 337 ui::TouchscreenDevice(1, ui::InputDeviceType::INPUT_DEVICE_INTERNAL, |
| 339 "Touchscreen", gfx::Size(1024, 768), 0)); | 338 "Touchscreen", gfx::Size(1024, 768), 0)); |
| 340 UpdateTouchscreenDevices(screens); | 339 UpdateTouchscreenDevices(screens); |
| 341 std::vector<ui::KeyboardDevice> keyboards; | 340 std::vector<ui::InputDevice> keyboards; |
| 342 keyboards.push_back(ui::KeyboardDevice( | 341 keyboards.push_back(ui::InputDevice( |
| 343 1, ui::InputDeviceType::INPUT_DEVICE_EXTERNAL, "keyboard")); | 342 1, ui::InputDeviceType::INPUT_DEVICE_EXTERNAL, "keyboard")); |
| 344 UpdateKeyboardDevices(keyboards); | 343 UpdateKeyboardDevices(keyboards); |
| 345 ASSERT_TRUE(keyboard::IsKeyboardEnabled()); | 344 ASSERT_TRUE(keyboard::IsKeyboardEnabled()); |
| 346 } | 345 } |
| 347 | 346 |
| 348 } // namespace test | 347 } // namespace test |
| 349 } // namespace ash | 348 } // namespace ash |
| OLD | NEW |