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 "chrome/browser/chromeos/events/event_rewriter.h" | 5 #include "chrome/browser/chromeos/events/event_rewriter.h" |
| 6 | 6 |
| 7 #include <vector> | 7 #include <vector> |
| 8 | 8 |
| 9 #include "ash/shell.h" | 9 #include "ash/shell.h" |
| 10 #include "ash/sticky_keys/sticky_keys_controller.h" | 10 #include "ash/sticky_keys/sticky_keys_controller.h" |
| (...skipping 25 matching lines...) Expand all Loading... | |
| 36 | 36 |
| 37 #include "ui/events/test/events_test_utils_x11.h" | 37 #include "ui/events/test/events_test_utils_x11.h" |
| 38 #include "ui/events/x/touch_factory_x11.h" | 38 #include "ui/events/x/touch_factory_x11.h" |
| 39 #include "ui/gfx/x/x11_types.h" | 39 #include "ui/gfx/x/x11_types.h" |
| 40 #endif | 40 #endif |
| 41 | 41 |
| 42 namespace { | 42 namespace { |
| 43 | 43 |
| 44 // The device id of the test touchpad device. | 44 // The device id of the test touchpad device. |
| 45 const unsigned int kTouchPadDeviceId = 1; | 45 const unsigned int kTouchPadDeviceId = 1; |
| 46 const int kKeyboardDeviceId = 2; | |
| 46 | 47 |
| 47 std::string GetExpectedResultAsString(ui::KeyboardCode ui_keycode, | 48 std::string GetExpectedResultAsString(ui::KeyboardCode ui_keycode, |
| 48 int ui_flags, | 49 int ui_flags, |
| 49 ui::EventType ui_type) { | 50 ui::EventType ui_type) { |
| 50 return base::StringPrintf("ui_keycode=0x%X ui_flags=0x%X ui_type=%d", | 51 return base::StringPrintf("ui_keycode=0x%X ui_flags=0x%X ui_type=%d", |
| 51 ui_keycode, | 52 ui_keycode, |
| 52 ui_flags & ~ui::EF_IS_REPEAT, | 53 ui_flags & ~ui::EF_IS_REPEAT, |
| 53 ui_type); | 54 ui_type); |
| 54 } | 55 } |
| 55 | 56 |
| (...skipping 28 matching lines...) Expand all Loading... | |
| 84 // between pairs like XK_Insert and XK_KP_Insert. | 85 // between pairs like XK_Insert and XK_KP_Insert. |
| 85 }; | 86 }; |
| 86 int test; | 87 int test; |
| 87 ui::EventType type; | 88 ui::EventType type; |
| 88 struct { | 89 struct { |
| 89 ui::KeyboardCode key_code; | 90 ui::KeyboardCode key_code; |
| 90 int flags; | 91 int flags; |
| 91 } input, expected; | 92 } input, expected; |
| 92 }; | 93 }; |
| 93 | 94 |
| 95 #if defined(USE_X11) | |
| 96 // Check rewriting of an X11-based key event. | |
| 97 void CheckX11KeyTestCase(const std::string& id, | |
| 98 const std::string& expected, | |
| 99 chromeos::EventRewriter* rewriter, | |
| 100 const KeyTestCase& test, | |
| 101 XEvent* xevent) { | |
| 102 ui::KeyEvent xkey_event(xevent, false); | |
| 103 if (test.test & KeyTestCase::NUMPAD) | |
| 104 xkey_event.set_flags(xkey_event.flags() | ui::EF_NUMPAD_KEY); | |
| 105 // Verify that the X11-based key event is as expected. | |
| 106 EXPECT_EQ(id + GetExpectedResultAsString( | |
| 107 test.input.key_code, test.input.flags, test.type), | |
| 108 id + GetKeyEventAsString(xkey_event)); | |
| 109 // Rewrite the event and check the result. | |
| 110 scoped_ptr<ui::Event> new_event; | |
| 111 rewriter->RewriteEvent(xkey_event, &new_event); | |
| 112 ui::KeyEvent& rewritten_key_event = | |
| 113 new_event ? *static_cast<ui::KeyEvent*>(new_event.get()) : xkey_event; | |
| 114 EXPECT_EQ(expected, id + GetKeyEventAsString(rewritten_key_event)); | |
| 115 if ((rewritten_key_event.key_code() != ui::VKEY_UNKNOWN) && | |
| 116 (rewritten_key_event.native_event()->xkey.keycode != 0)) { | |
| 117 // Build a new ui::KeyEvent from the rewritten native component, | |
| 118 // and check that it also matches the rewritten event. | |
| 119 EXPECT_TRUE(rewritten_key_event.native_event()); | |
| 120 ui::KeyEvent from_native_event(rewritten_key_event.native_event(), false); | |
| 121 EXPECT_EQ(expected, id + GetKeyEventAsString(from_native_event)); | |
| 122 } | |
| 123 } | |
| 124 #endif | |
| 125 | |
| 94 // Tests a single stateless key rewrite operation. | 126 // Tests a single stateless key rewrite operation. |
| 95 // |i| is a an identifying number to locate failing tests in the tables. | 127 // |i| is a an identifying number to locate failing tests in the tables. |
| 96 void CheckKeyTestCase(size_t i, | 128 void CheckKeyTestCase(size_t i, |
| 97 chromeos::EventRewriter* rewriter, | 129 chromeos::EventRewriter* rewriter, |
| 98 const KeyTestCase& test) { | 130 const KeyTestCase& test) { |
| 99 std::string id = base::StringPrintf("(%zu) ", i); | 131 std::string id = base::StringPrintf("(%zu) ", i); |
| 100 std::string expected = | 132 std::string expected = |
| 101 id + GetExpectedResultAsString( | 133 id + GetExpectedResultAsString( |
| 102 test.expected.key_code, test.expected.flags, test.type); | 134 test.expected.key_code, test.expected.flags, test.type); |
| 103 | 135 |
| 104 if (test.test & KeyTestCase::TEST_VKEY) { | 136 if (test.test & KeyTestCase::TEST_VKEY) { |
| 105 // Check rewriting of a non-native-based key event. | 137 // Check rewriting of a non-native-based key event. |
| 106 EXPECT_EQ( | 138 EXPECT_EQ( |
| 107 expected, | 139 expected, |
| 108 id + GetRewrittenEventAsString( | 140 id + GetRewrittenEventAsString( |
| 109 rewriter, test.input.key_code, test.input.flags, test.type)); | 141 rewriter, test.input.key_code, test.input.flags, test.type)); |
| 110 } | 142 } |
| 111 | 143 |
| 112 #if defined(USE_X11) | 144 #if defined(USE_X11) |
| 113 if (test.test & KeyTestCase::TEST_X11) { | 145 if (test.test & KeyTestCase::TEST_X11) { |
| 114 ui::ScopedXI2Event xev; | 146 ui::ScopedXI2Event xev; |
| 147 // Test an XKeyEvent. | |
| 115 xev.InitKeyEvent(test.type, test.input.key_code, test.input.flags); | 148 xev.InitKeyEvent(test.type, test.input.key_code, test.input.flags); |
| 116 XEvent* xevent = xev; | 149 XEvent* xevent = xev; |
| 117 if (xevent->xkey.keycode) { | 150 DCHECK((xevent->type == KeyPress) || (xevent->type == KeyRelease)); |
| 118 ui::KeyEvent xkey_event(xevent, false); | 151 if (xevent->xkey.keycode) |
| 119 if (test.test & KeyTestCase::NUMPAD) | 152 CheckX11KeyTestCase(id, expected, rewriter, test, xevent); |
| 120 xkey_event.set_flags(xkey_event.flags() | ui::EF_NUMPAD_KEY); | 153 // Test an XI2 GenericEvent. |
| 121 // Verify that the X11-based key event is as expected. | 154 xev.InitGenericKeyEvent( |
| 122 EXPECT_EQ(id + GetExpectedResultAsString( | 155 kKeyboardDeviceId, test.type, test.input.key_code, test.input.flags); |
| 123 test.input.key_code, test.input.flags, test.type), | 156 xevent = xev; |
| 124 id + GetKeyEventAsString(xkey_event)); | 157 DCHECK(xevent->type == GenericEvent); |
| 125 // Rewrite the event and check the result. | 158 XIDeviceEvent* xievent = static_cast<XIDeviceEvent*>(xevent->xcookie.data); |
| 126 scoped_ptr<ui::Event> new_event; | 159 DCHECK((xievent->evtype == XI_KeyPress) || |
| 127 rewriter->RewriteEvent(xkey_event, &new_event); | 160 (xievent->evtype == XI_KeyRelease)); |
| 128 ui::KeyEvent& rewritten_key_event = | 161 if (xievent->detail) |
| 129 new_event ? *static_cast<ui::KeyEvent*>(new_event.get()) : xkey_event; | 162 CheckX11KeyTestCase(id, expected, rewriter, test, xevent); |
| 130 EXPECT_EQ(expected, id + GetKeyEventAsString(rewritten_key_event)); | |
| 131 if ((rewritten_key_event.key_code() != ui::VKEY_UNKNOWN) && | |
| 132 (rewritten_key_event.native_event()->xkey.keycode != 0)) { | |
| 133 // Build a new ui::KeyEvent from the rewritten native component, | |
| 134 // and check that it also matches the rewritten event. | |
| 135 ui::KeyEvent from_native_event(rewritten_key_event.native_event(), | |
| 136 false); | |
| 137 EXPECT_EQ(expected, id + GetKeyEventAsString(from_native_event)); | |
| 138 } | |
| 139 } | |
| 140 } | 163 } |
| 141 #endif | 164 #endif |
| 142 } | 165 } |
| 143 | 166 |
| 144 // Table entry for simple single function key event rewriting tests. | 167 // Table entry for simple single function key event rewriting tests. |
| 145 struct FunctionKeyTestCase { | 168 struct FunctionKeyTestCase { |
| 146 ui::EventType type; | 169 ui::EventType type; |
| 147 struct { | 170 struct { |
| 148 ui::KeyboardCode key_code; | 171 ui::KeyboardCode key_code; |
| 149 int flags; | 172 int flags; |
| (...skipping 68 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 218 virtual void TearDown() { | 241 virtual void TearDown() { |
| 219 AshTestBase::TearDown(); | 242 AshTestBase::TearDown(); |
| 220 // Shutdown() deletes the IME mock object. | 243 // Shutdown() deletes the IME mock object. |
| 221 chromeos::input_method::Shutdown(); | 244 chromeos::input_method::Shutdown(); |
| 222 } | 245 } |
| 223 | 246 |
| 224 protected: | 247 protected: |
| 225 void TestRewriteNumPadKeys(); | 248 void TestRewriteNumPadKeys(); |
| 226 void TestRewriteNumPadKeysOnAppleKeyboard(); | 249 void TestRewriteNumPadKeysOnAppleKeyboard(); |
| 227 | 250 |
| 228 int RewriteMouseEvent(chromeos::EventRewriter* rewriter, | 251 const ui::MouseEvent* RewriteMouseButtonEvent( |
| 229 const ui::MouseEvent& event) { | 252 chromeos::EventRewriter* rewriter, |
| 230 int flags = event.flags(); | 253 const ui::MouseEvent& event, |
| 231 rewriter->RewriteLocatedEventForTesting(event, &flags); | 254 scoped_ptr<ui::Event>* new_event) { |
| 232 return flags; | 255 rewriter->RewriteMouseButtonEventForTesting(event, new_event); |
| 256 return *new_event ? static_cast<const ui::MouseEvent*>(new_event->get()) | |
| 257 : &event; | |
| 233 } | 258 } |
| 234 | 259 |
| 235 chromeos::MockUserManager* mock_user_manager_; // Not owned. | 260 chromeos::MockUserManager* mock_user_manager_; // Not owned. |
| 236 chromeos::ScopedUserManagerEnabler user_manager_enabler_; | 261 chromeos::ScopedUserManagerEnabler user_manager_enabler_; |
| 237 chromeos::input_method::MockInputMethodManager* input_method_manager_mock_; | 262 chromeos::input_method::MockInputMethodManager* input_method_manager_mock_; |
| 238 }; | 263 }; |
| 239 | 264 |
| 240 TEST_F(EventRewriterTest, TestRewriteCommandToControl) { | 265 TEST_F(EventRewriterTest, TestRewriteCommandToControl) { |
| 241 // First, test with a PC keyboard. | 266 // First, test with a PC keyboard. |
| 242 TestingPrefServiceSyncable prefs; | 267 TestingPrefServiceSyncable prefs; |
| 243 EventRewriter rewriter(NULL); | 268 EventRewriter rewriter(NULL); |
| 244 rewriter.DeviceAddedForTesting(0, "PC Keyboard"); | 269 rewriter.KeyboardDeviceAddedForTesting(kKeyboardDeviceId, "PC Keyboard"); |
| 245 rewriter.set_last_device_id_for_testing(0); | 270 rewriter.set_last_keyboard_device_id_for_testing(kKeyboardDeviceId); |
| 246 rewriter.set_pref_service_for_testing(&prefs); | 271 rewriter.set_pref_service_for_testing(&prefs); |
| 247 | 272 |
| 248 KeyTestCase pc_keyboard_tests[] = { | 273 KeyTestCase pc_keyboard_tests[] = { |
| 249 // VKEY_A, Alt modifier. | 274 // VKEY_A, Alt modifier. |
| 250 {KeyTestCase::TEST_ALL, ui::ET_KEY_PRESSED, | 275 {KeyTestCase::TEST_ALL, ui::ET_KEY_PRESSED, |
| 251 {ui::VKEY_A, ui::EF_ALT_DOWN}, | 276 {ui::VKEY_A, ui::EF_ALT_DOWN}, |
| 252 {ui::VKEY_A, ui::EF_ALT_DOWN}}, | 277 {ui::VKEY_A, ui::EF_ALT_DOWN}}, |
| 253 | 278 |
| 254 // VKEY_A, Win modifier. | 279 // VKEY_A, Win modifier. |
| 255 {KeyTestCase::TEST_ALL, ui::ET_KEY_PRESSED, | 280 {KeyTestCase::TEST_ALL, ui::ET_KEY_PRESSED, |
| (...skipping 10 matching lines...) Expand all Loading... | |
| 266 {ui::VKEY_LWIN, ui::EF_ALT_DOWN | ui::EF_COMMAND_DOWN}, | 291 {ui::VKEY_LWIN, ui::EF_ALT_DOWN | ui::EF_COMMAND_DOWN}, |
| 267 {ui::VKEY_LWIN, ui::EF_ALT_DOWN | ui::EF_COMMAND_DOWN}}, | 292 {ui::VKEY_LWIN, ui::EF_ALT_DOWN | ui::EF_COMMAND_DOWN}}, |
| 268 | 293 |
| 269 // VKEY_RWIN (right Windows key), Alt modifier. | 294 // VKEY_RWIN (right Windows key), Alt modifier. |
| 270 {KeyTestCase::TEST_ALL, ui::ET_KEY_PRESSED, | 295 {KeyTestCase::TEST_ALL, ui::ET_KEY_PRESSED, |
| 271 {ui::VKEY_RWIN, ui::EF_ALT_DOWN | ui::EF_COMMAND_DOWN}, | 296 {ui::VKEY_RWIN, ui::EF_ALT_DOWN | ui::EF_COMMAND_DOWN}, |
| 272 {ui::VKEY_RWIN, ui::EF_ALT_DOWN | ui::EF_COMMAND_DOWN}}, | 297 {ui::VKEY_RWIN, ui::EF_ALT_DOWN | ui::EF_COMMAND_DOWN}}, |
| 273 }; | 298 }; |
| 274 | 299 |
| 275 for (size_t i = 0; i < arraysize(pc_keyboard_tests); ++i) { | 300 for (size_t i = 0; i < arraysize(pc_keyboard_tests); ++i) { |
| 276 CheckKeyTestCase(1000 + i, &rewriter, pc_keyboard_tests[i]); | 301 CheckKeyTestCase(1000 + i, &rewriter, pc_keyboard_tests[i]); |
|
Daniel Erat
2014/06/25 17:13:24
nit: mind adding a SCOPED_TRACE() call at the begi
kpschoedel
2014/06/25 19:59:48
Thanks; I only added the ID because I wasn't aware
| |
| 277 } | 302 } |
| 278 | 303 |
| 279 // An Apple keyboard reusing the ID, zero. | 304 // An Apple keyboard reusing the ID, zero. |
| 280 rewriter.DeviceAddedForTesting(0, "Apple Keyboard"); | 305 rewriter.KeyboardDeviceAddedForTesting(kKeyboardDeviceId, "Apple Keyboard"); |
| 281 rewriter.set_last_device_id_for_testing(0); | 306 rewriter.set_last_keyboard_device_id_for_testing(kKeyboardDeviceId); |
| 282 | 307 |
| 283 KeyTestCase apple_keyboard_tests[] = { | 308 KeyTestCase apple_keyboard_tests[] = { |
| 284 // VKEY_A, Alt modifier. | 309 // VKEY_A, Alt modifier. |
| 285 {KeyTestCase::TEST_ALL, ui::ET_KEY_PRESSED, | 310 {KeyTestCase::TEST_ALL, ui::ET_KEY_PRESSED, |
| 286 {ui::VKEY_A, ui::EF_ALT_DOWN}, | 311 {ui::VKEY_A, ui::EF_ALT_DOWN}, |
| 287 {ui::VKEY_A, ui::EF_ALT_DOWN}}, | 312 {ui::VKEY_A, ui::EF_ALT_DOWN}}, |
| 288 | 313 |
| 289 // VKEY_A, Win modifier. | 314 // VKEY_A, Win modifier. |
| 290 {KeyTestCase::TEST_ALL, ui::ET_KEY_PRESSED, | 315 {KeyTestCase::TEST_ALL, ui::ET_KEY_PRESSED, |
| 291 {ui::VKEY_A, ui::EF_COMMAND_DOWN}, | 316 {ui::VKEY_A, ui::EF_COMMAND_DOWN}, |
| (...skipping 24 matching lines...) Expand all Loading... | |
| 316 TEST_F(EventRewriterTest, TestRewriteCommandToControlWithControlRemapped) { | 341 TEST_F(EventRewriterTest, TestRewriteCommandToControlWithControlRemapped) { |
| 317 // Remap Control to Alt. | 342 // Remap Control to Alt. |
| 318 TestingPrefServiceSyncable prefs; | 343 TestingPrefServiceSyncable prefs; |
| 319 chromeos::Preferences::RegisterProfilePrefs(prefs.registry()); | 344 chromeos::Preferences::RegisterProfilePrefs(prefs.registry()); |
| 320 IntegerPrefMember control; | 345 IntegerPrefMember control; |
| 321 control.Init(prefs::kLanguageRemapControlKeyTo, &prefs); | 346 control.Init(prefs::kLanguageRemapControlKeyTo, &prefs); |
| 322 control.SetValue(chromeos::input_method::kAltKey); | 347 control.SetValue(chromeos::input_method::kAltKey); |
| 323 | 348 |
| 324 EventRewriter rewriter(NULL); | 349 EventRewriter rewriter(NULL); |
| 325 rewriter.set_pref_service_for_testing(&prefs); | 350 rewriter.set_pref_service_for_testing(&prefs); |
| 326 rewriter.DeviceAddedForTesting(0, "PC Keyboard"); | 351 rewriter.KeyboardDeviceAddedForTesting(kKeyboardDeviceId, "PC Keyboard"); |
| 327 rewriter.set_last_device_id_for_testing(0); | 352 rewriter.set_last_keyboard_device_id_for_testing(kKeyboardDeviceId); |
| 328 | 353 |
| 329 KeyTestCase pc_keyboard_tests[] = {// Control should be remapped to Alt. | 354 KeyTestCase pc_keyboard_tests[] = {// Control should be remapped to Alt. |
| 330 {KeyTestCase::TEST_ALL, ui::ET_KEY_PRESSED, | 355 {KeyTestCase::TEST_ALL, ui::ET_KEY_PRESSED, |
| 331 {ui::VKEY_CONTROL, ui::EF_CONTROL_DOWN}, | 356 {ui::VKEY_CONTROL, ui::EF_CONTROL_DOWN}, |
| 332 {ui::VKEY_MENU, ui::EF_ALT_DOWN}}, | 357 {ui::VKEY_MENU, ui::EF_ALT_DOWN}}, |
| 333 }; | 358 }; |
| 334 | 359 |
| 335 for (size_t i = 0; i < arraysize(pc_keyboard_tests); ++i) { | 360 for (size_t i = 0; i < arraysize(pc_keyboard_tests); ++i) { |
| 336 CheckKeyTestCase(1000 + i, &rewriter, pc_keyboard_tests[i]); | 361 CheckKeyTestCase(1000 + i, &rewriter, pc_keyboard_tests[i]); |
| 337 } | 362 } |
| 338 | 363 |
| 339 // An Apple keyboard reusing the ID, zero. | 364 // An Apple keyboard reusing the ID, zero. |
| 340 rewriter.DeviceAddedForTesting(0, "Apple Keyboard"); | 365 rewriter.KeyboardDeviceAddedForTesting(kKeyboardDeviceId, "Apple Keyboard"); |
| 341 rewriter.set_last_device_id_for_testing(0); | 366 rewriter.set_last_keyboard_device_id_for_testing(kKeyboardDeviceId); |
| 342 | 367 |
| 343 KeyTestCase apple_keyboard_tests[] = { | 368 KeyTestCase apple_keyboard_tests[] = { |
| 344 // VKEY_LWIN (left Command key) with Alt modifier. The remapped Command | 369 // VKEY_LWIN (left Command key) with Alt modifier. The remapped Command |
| 345 // key should never be re-remapped to Alt. | 370 // key should never be re-remapped to Alt. |
| 346 {KeyTestCase::TEST_ALL, ui::ET_KEY_PRESSED, | 371 {KeyTestCase::TEST_ALL, ui::ET_KEY_PRESSED, |
| 347 {ui::VKEY_LWIN, ui::EF_COMMAND_DOWN | ui::EF_ALT_DOWN}, | 372 {ui::VKEY_LWIN, ui::EF_COMMAND_DOWN | ui::EF_ALT_DOWN}, |
| 348 {ui::VKEY_CONTROL, ui::EF_CONTROL_DOWN | ui::EF_ALT_DOWN}}, | 373 {ui::VKEY_CONTROL, ui::EF_CONTROL_DOWN | ui::EF_ALT_DOWN}}, |
| 349 | 374 |
| 350 // VKEY_RWIN (right Command key) with Alt modifier. The remapped Command | 375 // VKEY_RWIN (right Command key) with Alt modifier. The remapped Command |
| 351 // key should never be re-remapped to Alt. | 376 // key should never be re-remapped to Alt. |
| 352 {KeyTestCase::TEST_ALL, ui::ET_KEY_PRESSED, | 377 {KeyTestCase::TEST_ALL, ui::ET_KEY_PRESSED, |
| 353 {ui::VKEY_RWIN, ui::EF_COMMAND_DOWN | ui::EF_ALT_DOWN}, | 378 {ui::VKEY_RWIN, ui::EF_COMMAND_DOWN | ui::EF_ALT_DOWN}, |
| 354 {ui::VKEY_CONTROL, ui::EF_CONTROL_DOWN | ui::EF_ALT_DOWN}}, | 379 {ui::VKEY_CONTROL, ui::EF_CONTROL_DOWN | ui::EF_ALT_DOWN}}, |
| 355 }; | 380 }; |
| 356 | 381 |
| 357 for (size_t i = 0; i < arraysize(apple_keyboard_tests); ++i) { | 382 for (size_t i = 0; i < arraysize(apple_keyboard_tests); ++i) { |
| 358 CheckKeyTestCase(2000 + i, &rewriter, apple_keyboard_tests[i]); | 383 CheckKeyTestCase(2000 + i, &rewriter, apple_keyboard_tests[i]); |
| 359 } | 384 } |
| 360 } | 385 } |
| 361 | 386 |
| 362 void EventRewriterTest::TestRewriteNumPadKeys() { | 387 void EventRewriterTest::TestRewriteNumPadKeys() { |
| 363 TestingPrefServiceSyncable prefs; | 388 TestingPrefServiceSyncable prefs; |
| 364 EventRewriter rewriter(NULL); | 389 EventRewriter rewriter(NULL); |
| 390 rewriter.set_last_keyboard_device_id_for_testing(kKeyboardDeviceId); | |
| 365 rewriter.set_pref_service_for_testing(&prefs); | 391 rewriter.set_pref_service_for_testing(&prefs); |
| 366 | 392 |
| 367 KeyTestCase tests[] = { | 393 KeyTestCase tests[] = { |
| 368 // XK_KP_Insert (= NumPad 0 without Num Lock), no modifier. | 394 // XK_KP_Insert (= NumPad 0 without Num Lock), no modifier. |
| 369 {KeyTestCase::TEST_ALL|KeyTestCase::NUMPAD, ui::ET_KEY_PRESSED, | 395 {KeyTestCase::TEST_ALL|KeyTestCase::NUMPAD, ui::ET_KEY_PRESSED, |
| 370 {ui::VKEY_INSERT, ui::EF_NUMPAD_KEY}, | 396 {ui::VKEY_INSERT, ui::EF_NUMPAD_KEY}, |
| 371 {ui::VKEY_NUMPAD0, ui::EF_NUMPAD_KEY}}, | 397 {ui::VKEY_NUMPAD0, ui::EF_NUMPAD_KEY}}, |
| 372 | 398 |
| 373 // XK_KP_Insert (= NumPad 0 without Num Lock), Alt modifier. | 399 // XK_KP_Insert (= NumPad 0 without Num Lock), Alt modifier. |
| 374 {KeyTestCase::TEST_ALL|KeyTestCase::NUMPAD, ui::ET_KEY_PRESSED, | 400 {KeyTestCase::TEST_ALL|KeyTestCase::NUMPAD, ui::ET_KEY_PRESSED, |
| (...skipping 122 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 497 chromeos::switches::kHasChromeOSDiamondKey, ""); | 523 chromeos::switches::kHasChromeOSDiamondKey, ""); |
| 498 | 524 |
| 499 TestRewriteNumPadKeys(); | 525 TestRewriteNumPadKeys(); |
| 500 *CommandLine::ForCurrentProcess() = original_cl; | 526 *CommandLine::ForCurrentProcess() = original_cl; |
| 501 } | 527 } |
| 502 | 528 |
| 503 // Tests if the rewriter can handle a Command + Num Pad event. | 529 // Tests if the rewriter can handle a Command + Num Pad event. |
| 504 void EventRewriterTest::TestRewriteNumPadKeysOnAppleKeyboard() { | 530 void EventRewriterTest::TestRewriteNumPadKeysOnAppleKeyboard() { |
| 505 TestingPrefServiceSyncable prefs; | 531 TestingPrefServiceSyncable prefs; |
| 506 EventRewriter rewriter(NULL); | 532 EventRewriter rewriter(NULL); |
| 507 rewriter.DeviceAddedForTesting(0, "Apple Keyboard"); | 533 rewriter.KeyboardDeviceAddedForTesting(kKeyboardDeviceId, "Apple Keyboard"); |
| 508 rewriter.set_last_device_id_for_testing(0); | 534 rewriter.set_last_keyboard_device_id_for_testing(kKeyboardDeviceId); |
| 509 rewriter.set_pref_service_for_testing(&prefs); | 535 rewriter.set_pref_service_for_testing(&prefs); |
| 510 | 536 |
| 511 KeyTestCase tests[] = { | 537 KeyTestCase tests[] = { |
| 512 // XK_KP_End (= NumPad 1 without Num Lock), Win modifier. | 538 // XK_KP_End (= NumPad 1 without Num Lock), Win modifier. |
| 513 // The result should be "Num Pad 1 with Control + Num Lock modifiers". | 539 // The result should be "Num Pad 1 with Control + Num Lock modifiers". |
| 514 {KeyTestCase::TEST_ALL|KeyTestCase::NUMPAD, ui::ET_KEY_PRESSED, | 540 {KeyTestCase::TEST_ALL|KeyTestCase::NUMPAD, ui::ET_KEY_PRESSED, |
| 515 {ui::VKEY_END, ui::EF_COMMAND_DOWN | ui::EF_NUMPAD_KEY}, | 541 {ui::VKEY_END, ui::EF_COMMAND_DOWN | ui::EF_NUMPAD_KEY}, |
| 516 {ui::VKEY_NUMPAD1, ui::EF_CONTROL_DOWN | ui::EF_NUMPAD_KEY}}, | 542 {ui::VKEY_NUMPAD1, ui::EF_CONTROL_DOWN | ui::EF_NUMPAD_KEY}}, |
| 517 | 543 |
| 518 // XK_KP_1 (= NumPad 1 with Num Lock), Win modifier. | 544 // XK_KP_1 (= NumPad 1 with Num Lock), Win modifier. |
| (...skipping 20 matching lines...) Expand all Loading... | |
| 539 CommandLine::ForCurrentProcess()->AppendSwitchASCII( | 565 CommandLine::ForCurrentProcess()->AppendSwitchASCII( |
| 540 chromeos::switches::kHasChromeOSDiamondKey, ""); | 566 chromeos::switches::kHasChromeOSDiamondKey, ""); |
| 541 | 567 |
| 542 TestRewriteNumPadKeysOnAppleKeyboard(); | 568 TestRewriteNumPadKeysOnAppleKeyboard(); |
| 543 *CommandLine::ForCurrentProcess() = original_cl; | 569 *CommandLine::ForCurrentProcess() = original_cl; |
| 544 } | 570 } |
| 545 | 571 |
| 546 TEST_F(EventRewriterTest, TestRewriteModifiersNoRemap) { | 572 TEST_F(EventRewriterTest, TestRewriteModifiersNoRemap) { |
| 547 TestingPrefServiceSyncable prefs; | 573 TestingPrefServiceSyncable prefs; |
| 548 EventRewriter rewriter(NULL); | 574 EventRewriter rewriter(NULL); |
| 575 rewriter.KeyboardDeviceAddedForTesting(kKeyboardDeviceId, "PC Keyboard"); | |
| 549 rewriter.set_pref_service_for_testing(&prefs); | 576 rewriter.set_pref_service_for_testing(&prefs); |
| 550 | 577 |
| 551 KeyTestCase tests[] = { | 578 KeyTestCase tests[] = { |
| 552 // Press Search. Confirm the event is not rewritten. | 579 // Press Search. Confirm the event is not rewritten. |
| 553 {KeyTestCase::TEST_ALL, ui::ET_KEY_PRESSED, | 580 {KeyTestCase::TEST_ALL, ui::ET_KEY_PRESSED, |
| 554 {ui::VKEY_LWIN, ui::EF_NONE}, | 581 {ui::VKEY_LWIN, ui::EF_NONE}, |
| 555 {ui::VKEY_LWIN, ui::EF_COMMAND_DOWN}}, | 582 {ui::VKEY_LWIN, ui::EF_COMMAND_DOWN}}, |
| 556 | 583 |
| 557 // Press left Control. Confirm the event is not rewritten. | 584 // Press left Control. Confirm the event is not rewritten. |
| 558 {KeyTestCase::TEST_ALL, ui::ET_KEY_PRESSED, | 585 {KeyTestCase::TEST_ALL, ui::ET_KEY_PRESSED, |
| (...skipping 23 matching lines...) Expand all Loading... | |
| 582 }; | 609 }; |
| 583 | 610 |
| 584 for (size_t i = 0; i < arraysize(tests); ++i) { | 611 for (size_t i = 0; i < arraysize(tests); ++i) { |
| 585 CheckKeyTestCase(1000 + i, &rewriter, tests[i]); | 612 CheckKeyTestCase(1000 + i, &rewriter, tests[i]); |
| 586 } | 613 } |
| 587 } | 614 } |
| 588 | 615 |
| 589 TEST_F(EventRewriterTest, TestRewriteModifiersNoRemapMultipleKeys) { | 616 TEST_F(EventRewriterTest, TestRewriteModifiersNoRemapMultipleKeys) { |
| 590 TestingPrefServiceSyncable prefs; | 617 TestingPrefServiceSyncable prefs; |
| 591 EventRewriter rewriter(NULL); | 618 EventRewriter rewriter(NULL); |
| 619 rewriter.KeyboardDeviceAddedForTesting(kKeyboardDeviceId, "PC Keyboard"); | |
| 592 rewriter.set_pref_service_for_testing(&prefs); | 620 rewriter.set_pref_service_for_testing(&prefs); |
| 593 | 621 |
| 594 KeyTestCase tests[] = { | 622 KeyTestCase tests[] = { |
| 595 // Press Alt with Shift. Confirm the event is not rewritten. | 623 // Press Alt with Shift. Confirm the event is not rewritten. |
| 596 {KeyTestCase::TEST_ALL, ui::ET_KEY_PRESSED, | 624 {KeyTestCase::TEST_ALL, ui::ET_KEY_PRESSED, |
| 597 {ui::VKEY_MENU, ui::EF_SHIFT_DOWN | ui::EF_ALT_DOWN}, | 625 {ui::VKEY_MENU, ui::EF_SHIFT_DOWN | ui::EF_ALT_DOWN}, |
| 598 {ui::VKEY_MENU, ui::EF_SHIFT_DOWN | ui::EF_ALT_DOWN}}, | 626 {ui::VKEY_MENU, ui::EF_SHIFT_DOWN | ui::EF_ALT_DOWN}}, |
| 599 | 627 |
| 600 // Press Search with Caps Lock mask. Confirm the event is not rewritten. | 628 // Press Search with Caps Lock mask. Confirm the event is not rewritten. |
| 601 {KeyTestCase::TEST_ALL, ui::ET_KEY_PRESSED, | 629 {KeyTestCase::TEST_ALL, ui::ET_KEY_PRESSED, |
| (...skipping 23 matching lines...) Expand all Loading... | |
| 625 TestingPrefServiceSyncable prefs; | 653 TestingPrefServiceSyncable prefs; |
| 626 chromeos::Preferences::RegisterProfilePrefs(prefs.registry()); | 654 chromeos::Preferences::RegisterProfilePrefs(prefs.registry()); |
| 627 IntegerPrefMember search; | 655 IntegerPrefMember search; |
| 628 search.Init(prefs::kLanguageRemapSearchKeyTo, &prefs); | 656 search.Init(prefs::kLanguageRemapSearchKeyTo, &prefs); |
| 629 search.SetValue(chromeos::input_method::kVoidKey); | 657 search.SetValue(chromeos::input_method::kVoidKey); |
| 630 IntegerPrefMember control; | 658 IntegerPrefMember control; |
| 631 control.Init(prefs::kLanguageRemapControlKeyTo, &prefs); | 659 control.Init(prefs::kLanguageRemapControlKeyTo, &prefs); |
| 632 control.SetValue(chromeos::input_method::kVoidKey); | 660 control.SetValue(chromeos::input_method::kVoidKey); |
| 633 | 661 |
| 634 EventRewriter rewriter(NULL); | 662 EventRewriter rewriter(NULL); |
| 663 rewriter.KeyboardDeviceAddedForTesting(kKeyboardDeviceId, "PC Keyboard"); | |
| 635 rewriter.set_pref_service_for_testing(&prefs); | 664 rewriter.set_pref_service_for_testing(&prefs); |
| 636 | 665 |
| 637 KeyTestCase disabled_modifier_tests[] = { | 666 KeyTestCase disabled_modifier_tests[] = { |
| 638 // Press Alt with Shift. This key press shouldn't be affected by the | 667 // Press Alt with Shift. This key press shouldn't be affected by the |
| 639 // pref. Confirm the event is not rewritten. | 668 // pref. Confirm the event is not rewritten. |
| 640 {KeyTestCase::TEST_ALL, ui::ET_KEY_PRESSED, | 669 {KeyTestCase::TEST_ALL, ui::ET_KEY_PRESSED, |
| 641 {ui::VKEY_MENU, ui::EF_SHIFT_DOWN | ui::EF_ALT_DOWN}, | 670 {ui::VKEY_MENU, ui::EF_SHIFT_DOWN | ui::EF_ALT_DOWN}, |
| 642 {ui::VKEY_MENU, ui::EF_SHIFT_DOWN | ui::EF_ALT_DOWN}}, | 671 {ui::VKEY_MENU, ui::EF_SHIFT_DOWN | ui::EF_ALT_DOWN}}, |
| 643 | 672 |
| 644 // Press Search. Confirm the event is now VKEY_UNKNOWN. | 673 // Press Search. Confirm the event is now VKEY_UNKNOWN. |
| (...skipping 55 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 700 | 729 |
| 701 TEST_F(EventRewriterTest, TestRewriteModifiersRemapToControl) { | 730 TEST_F(EventRewriterTest, TestRewriteModifiersRemapToControl) { |
| 702 // Remap Search to Control. | 731 // Remap Search to Control. |
| 703 TestingPrefServiceSyncable prefs; | 732 TestingPrefServiceSyncable prefs; |
| 704 chromeos::Preferences::RegisterProfilePrefs(prefs.registry()); | 733 chromeos::Preferences::RegisterProfilePrefs(prefs.registry()); |
| 705 IntegerPrefMember search; | 734 IntegerPrefMember search; |
| 706 search.Init(prefs::kLanguageRemapSearchKeyTo, &prefs); | 735 search.Init(prefs::kLanguageRemapSearchKeyTo, &prefs); |
| 707 search.SetValue(chromeos::input_method::kControlKey); | 736 search.SetValue(chromeos::input_method::kControlKey); |
| 708 | 737 |
| 709 EventRewriter rewriter(NULL); | 738 EventRewriter rewriter(NULL); |
| 739 rewriter.KeyboardDeviceAddedForTesting(kKeyboardDeviceId, "PC Keyboard"); | |
| 710 rewriter.set_pref_service_for_testing(&prefs); | 740 rewriter.set_pref_service_for_testing(&prefs); |
| 711 | 741 |
| 712 KeyTestCase s_tests[] = { | 742 KeyTestCase s_tests[] = { |
| 713 // Press Search. Confirm the event is now VKEY_CONTROL. | 743 // Press Search. Confirm the event is now VKEY_CONTROL. |
| 714 {KeyTestCase::TEST_ALL, ui::ET_KEY_PRESSED, | 744 {KeyTestCase::TEST_ALL, ui::ET_KEY_PRESSED, |
| 715 {ui::VKEY_LWIN, ui::EF_COMMAND_DOWN}, | 745 {ui::VKEY_LWIN, ui::EF_COMMAND_DOWN}, |
| 716 {ui::VKEY_CONTROL, ui::EF_CONTROL_DOWN}}, | 746 {ui::VKEY_CONTROL, ui::EF_CONTROL_DOWN}}, |
| 717 }; | 747 }; |
| 718 | 748 |
| 719 for (size_t i = 0; i < arraysize(s_tests); ++i) { | 749 for (size_t i = 0; i < arraysize(s_tests); ++i) { |
| (...skipping 44 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 764 | 794 |
| 765 TEST_F(EventRewriterTest, TestRewriteModifiersRemapToEscape) { | 795 TEST_F(EventRewriterTest, TestRewriteModifiersRemapToEscape) { |
| 766 // Remap Search to ESC. | 796 // Remap Search to ESC. |
| 767 TestingPrefServiceSyncable prefs; | 797 TestingPrefServiceSyncable prefs; |
| 768 chromeos::Preferences::RegisterProfilePrefs(prefs.registry()); | 798 chromeos::Preferences::RegisterProfilePrefs(prefs.registry()); |
| 769 IntegerPrefMember search; | 799 IntegerPrefMember search; |
| 770 search.Init(prefs::kLanguageRemapSearchKeyTo, &prefs); | 800 search.Init(prefs::kLanguageRemapSearchKeyTo, &prefs); |
| 771 search.SetValue(chromeos::input_method::kEscapeKey); | 801 search.SetValue(chromeos::input_method::kEscapeKey); |
| 772 | 802 |
| 773 EventRewriter rewriter(NULL); | 803 EventRewriter rewriter(NULL); |
| 804 rewriter.KeyboardDeviceAddedForTesting(kKeyboardDeviceId, "PC Keyboard"); | |
| 774 rewriter.set_pref_service_for_testing(&prefs); | 805 rewriter.set_pref_service_for_testing(&prefs); |
| 775 | 806 |
| 776 KeyTestCase tests[] = {// Press Search. Confirm the event is now VKEY_ESCAPE. | 807 KeyTestCase tests[] = {// Press Search. Confirm the event is now VKEY_ESCAPE. |
| 777 {KeyTestCase::TEST_ALL, ui::ET_KEY_PRESSED, | 808 {KeyTestCase::TEST_ALL, ui::ET_KEY_PRESSED, |
| 778 {ui::VKEY_LWIN, ui::EF_COMMAND_DOWN}, | 809 {ui::VKEY_LWIN, ui::EF_COMMAND_DOWN}, |
| 779 {ui::VKEY_ESCAPE, ui::EF_NONE}}, | 810 {ui::VKEY_ESCAPE, ui::EF_NONE}}, |
| 780 }; | 811 }; |
| 781 | 812 |
| 782 for (size_t i = 0; i < arraysize(tests); ++i) { | 813 for (size_t i = 0; i < arraysize(tests); ++i) { |
| 783 CheckKeyTestCase(1000 + i, &rewriter, tests[i]); | 814 CheckKeyTestCase(1000 + i, &rewriter, tests[i]); |
| 784 } | 815 } |
| 785 } | 816 } |
| 786 | 817 |
| 787 TEST_F(EventRewriterTest, TestRewriteModifiersRemapMany) { | 818 TEST_F(EventRewriterTest, TestRewriteModifiersRemapMany) { |
| 788 // Remap Search to Alt. | 819 // Remap Search to Alt. |
| 789 TestingPrefServiceSyncable prefs; | 820 TestingPrefServiceSyncable prefs; |
| 790 chromeos::Preferences::RegisterProfilePrefs(prefs.registry()); | 821 chromeos::Preferences::RegisterProfilePrefs(prefs.registry()); |
| 791 IntegerPrefMember search; | 822 IntegerPrefMember search; |
| 792 search.Init(prefs::kLanguageRemapSearchKeyTo, &prefs); | 823 search.Init(prefs::kLanguageRemapSearchKeyTo, &prefs); |
| 793 search.SetValue(chromeos::input_method::kAltKey); | 824 search.SetValue(chromeos::input_method::kAltKey); |
| 794 | 825 |
| 795 EventRewriter rewriter(NULL); | 826 EventRewriter rewriter(NULL); |
| 827 rewriter.KeyboardDeviceAddedForTesting(kKeyboardDeviceId, "PC Keyboard"); | |
| 796 rewriter.set_pref_service_for_testing(&prefs); | 828 rewriter.set_pref_service_for_testing(&prefs); |
| 797 | 829 |
| 798 KeyTestCase s2a_tests[] = { | 830 KeyTestCase s2a_tests[] = { |
| 799 // Press Search. Confirm the event is now VKEY_MENU. | 831 // Press Search. Confirm the event is now VKEY_MENU. |
| 800 {KeyTestCase::TEST_ALL, ui::ET_KEY_PRESSED, | 832 {KeyTestCase::TEST_ALL, ui::ET_KEY_PRESSED, |
| 801 {ui::VKEY_LWIN, ui::EF_COMMAND_DOWN}, | 833 {ui::VKEY_LWIN, ui::EF_COMMAND_DOWN}, |
| 802 {ui::VKEY_MENU, ui::EF_ALT_DOWN}}, | 834 {ui::VKEY_MENU, ui::EF_ALT_DOWN}}, |
| 803 }; | 835 }; |
| 804 | 836 |
| 805 for (size_t i = 0; i < arraysize(s2a_tests); ++i) { | 837 for (size_t i = 0; i < arraysize(s2a_tests); ++i) { |
| (...skipping 57 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 863 TEST_F(EventRewriterTest, TestRewriteModifiersRemapToCapsLock) { | 895 TEST_F(EventRewriterTest, TestRewriteModifiersRemapToCapsLock) { |
| 864 // Remap Search to Caps Lock. | 896 // Remap Search to Caps Lock. |
| 865 TestingPrefServiceSyncable prefs; | 897 TestingPrefServiceSyncable prefs; |
| 866 chromeos::Preferences::RegisterProfilePrefs(prefs.registry()); | 898 chromeos::Preferences::RegisterProfilePrefs(prefs.registry()); |
| 867 IntegerPrefMember search; | 899 IntegerPrefMember search; |
| 868 search.Init(prefs::kLanguageRemapSearchKeyTo, &prefs); | 900 search.Init(prefs::kLanguageRemapSearchKeyTo, &prefs); |
| 869 search.SetValue(chromeos::input_method::kCapsLockKey); | 901 search.SetValue(chromeos::input_method::kCapsLockKey); |
| 870 | 902 |
| 871 chromeos::input_method::FakeImeKeyboard ime_keyboard; | 903 chromeos::input_method::FakeImeKeyboard ime_keyboard; |
| 872 EventRewriter rewriter(NULL); | 904 EventRewriter rewriter(NULL); |
| 905 rewriter.KeyboardDeviceAddedForTesting(kKeyboardDeviceId, "PC Keyboard"); | |
| 873 rewriter.set_pref_service_for_testing(&prefs); | 906 rewriter.set_pref_service_for_testing(&prefs); |
| 874 rewriter.set_ime_keyboard_for_testing(&ime_keyboard); | 907 rewriter.set_ime_keyboard_for_testing(&ime_keyboard); |
| 875 EXPECT_FALSE(ime_keyboard.caps_lock_is_enabled_); | 908 EXPECT_FALSE(ime_keyboard.caps_lock_is_enabled_); |
| 876 | 909 |
| 877 // Press Search. | 910 // Press Search. |
| 878 EXPECT_EQ( | 911 EXPECT_EQ( |
| 879 GetExpectedResultAsString(ui::VKEY_CAPITAL, | 912 GetExpectedResultAsString(ui::VKEY_CAPITAL, |
| 880 ui::EF_CAPS_LOCK_DOWN | ui::EF_MOD3_DOWN, | 913 ui::EF_CAPS_LOCK_DOWN | ui::EF_MOD3_DOWN, |
| 881 ui::ET_KEY_PRESSED), | 914 ui::ET_KEY_PRESSED), |
| 882 GetRewrittenEventAsString( | 915 GetRewrittenEventAsString( |
| (...skipping 50 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 933 &rewriter, ui::VKEY_CAPITAL, ui::EF_NONE, ui::ET_KEY_RELEASED)); | 966 &rewriter, ui::VKEY_CAPITAL, ui::EF_NONE, ui::ET_KEY_RELEASED)); |
| 934 EXPECT_FALSE(ime_keyboard.caps_lock_is_enabled_); | 967 EXPECT_FALSE(ime_keyboard.caps_lock_is_enabled_); |
| 935 } | 968 } |
| 936 | 969 |
| 937 TEST_F(EventRewriterTest, TestRewriteCapsLock) { | 970 TEST_F(EventRewriterTest, TestRewriteCapsLock) { |
| 938 TestingPrefServiceSyncable prefs; | 971 TestingPrefServiceSyncable prefs; |
| 939 chromeos::Preferences::RegisterProfilePrefs(prefs.registry()); | 972 chromeos::Preferences::RegisterProfilePrefs(prefs.registry()); |
| 940 | 973 |
| 941 chromeos::input_method::FakeImeKeyboard ime_keyboard; | 974 chromeos::input_method::FakeImeKeyboard ime_keyboard; |
| 942 EventRewriter rewriter(NULL); | 975 EventRewriter rewriter(NULL); |
| 976 rewriter.KeyboardDeviceAddedForTesting(kKeyboardDeviceId, "PC Keyboard"); | |
| 943 rewriter.set_pref_service_for_testing(&prefs); | 977 rewriter.set_pref_service_for_testing(&prefs); |
| 944 rewriter.set_ime_keyboard_for_testing(&ime_keyboard); | 978 rewriter.set_ime_keyboard_for_testing(&ime_keyboard); |
| 945 EXPECT_FALSE(ime_keyboard.caps_lock_is_enabled_); | 979 EXPECT_FALSE(ime_keyboard.caps_lock_is_enabled_); |
| 946 | 980 |
| 947 // On Chrome OS, CapsLock is mapped to F16 with Mod3Mask. | 981 // On Chrome OS, CapsLock is mapped to F16 with Mod3Mask. |
| 948 EXPECT_EQ(GetExpectedResultAsString(ui::VKEY_CAPITAL, | 982 EXPECT_EQ(GetExpectedResultAsString(ui::VKEY_CAPITAL, |
| 949 ui::EF_CAPS_LOCK_DOWN | ui::EF_MOD3_DOWN, | 983 ui::EF_CAPS_LOCK_DOWN | ui::EF_MOD3_DOWN, |
| 950 ui::ET_KEY_PRESSED), | 984 ui::ET_KEY_PRESSED), |
| 951 GetRewrittenEventAsString( | 985 GetRewrittenEventAsString( |
| 952 &rewriter, ui::VKEY_F16, ui::EF_MOD3_DOWN, ui::ET_KEY_PRESSED)); | 986 &rewriter, ui::VKEY_F16, ui::EF_MOD3_DOWN, ui::ET_KEY_PRESSED)); |
| 953 EXPECT_TRUE(ime_keyboard.caps_lock_is_enabled_); | 987 EXPECT_TRUE(ime_keyboard.caps_lock_is_enabled_); |
| 954 } | 988 } |
| 955 | 989 |
| 956 TEST_F(EventRewriterTest, TestRewriteDiamondKey) { | 990 TEST_F(EventRewriterTest, TestRewriteDiamondKey) { |
| 957 TestingPrefServiceSyncable prefs; | 991 TestingPrefServiceSyncable prefs; |
| 958 chromeos::Preferences::RegisterProfilePrefs(prefs.registry()); | 992 chromeos::Preferences::RegisterProfilePrefs(prefs.registry()); |
| 959 | 993 |
| 960 chromeos::input_method::FakeImeKeyboard ime_keyboard; | 994 chromeos::input_method::FakeImeKeyboard ime_keyboard; |
| 961 EventRewriter rewriter(NULL); | 995 EventRewriter rewriter(NULL); |
| 996 rewriter.KeyboardDeviceAddedForTesting(kKeyboardDeviceId, "PC Keyboard"); | |
| 962 rewriter.set_pref_service_for_testing(&prefs); | 997 rewriter.set_pref_service_for_testing(&prefs); |
| 963 rewriter.set_ime_keyboard_for_testing(&ime_keyboard); | 998 rewriter.set_ime_keyboard_for_testing(&ime_keyboard); |
| 964 | 999 |
| 965 KeyTestCase tests[] = { | 1000 KeyTestCase tests[] = { |
| 966 // F15 should work as Ctrl when --has-chromeos-diamond-key is not | 1001 // F15 should work as Ctrl when --has-chromeos-diamond-key is not |
| 967 // specified. | 1002 // specified. |
| 968 {KeyTestCase::TEST_VKEY, | 1003 {KeyTestCase::TEST_VKEY, |
| 969 ui::ET_KEY_PRESSED, | 1004 ui::ET_KEY_PRESSED, |
| 970 {ui::VKEY_F15, ui::EF_NONE}, | 1005 {ui::VKEY_F15, ui::EF_NONE}, |
| 971 {ui::VKEY_CONTROL, ui::EF_CONTROL_DOWN}}, | 1006 {ui::VKEY_CONTROL, ui::EF_CONTROL_DOWN}}, |
| 972 | 1007 |
| 973 // However, Mod2Mask should not be rewritten to CtrlMask when | 1008 // However, Mod2Mask should not be rewritten to CtrlMask when |
| 974 // --has-chromeos-diamond-key is not specified. | 1009 // --has-chromeos-diamond-key is not specified. |
| 975 {KeyTestCase::TEST_VKEY, | 1010 {KeyTestCase::TEST_VKEY, |
| 976 ui::ET_KEY_PRESSED, | 1011 ui::ET_KEY_PRESSED, |
| 977 {ui::VKEY_A, ui::EF_NONE}, | 1012 {ui::VKEY_A, ui::EF_NONE}, |
| 978 {ui::VKEY_A, ui::EF_NONE}}, | 1013 {ui::VKEY_A, ui::EF_NONE}}, |
| 979 }; | 1014 }; |
| 980 | 1015 |
| 981 for (size_t i = 0; i < arraysize(tests); ++i) { | 1016 for (size_t i = 0; i < arraysize(tests); ++i) { |
| 982 CheckKeyTestCase(1000 + i, &rewriter, tests[i]); | 1017 CheckKeyTestCase(1000 + i, &rewriter, tests[i]); |
| 983 } | 1018 } |
| 984 } | 1019 } |
| 1020 | |
| 985 TEST_F(EventRewriterTest, TestRewriteDiamondKeyWithFlag) { | 1021 TEST_F(EventRewriterTest, TestRewriteDiamondKeyWithFlag) { |
| 986 const CommandLine original_cl(*CommandLine::ForCurrentProcess()); | 1022 const CommandLine original_cl(*CommandLine::ForCurrentProcess()); |
| 987 CommandLine::ForCurrentProcess()->AppendSwitchASCII( | 1023 CommandLine::ForCurrentProcess()->AppendSwitchASCII( |
| 988 chromeos::switches::kHasChromeOSDiamondKey, ""); | 1024 chromeos::switches::kHasChromeOSDiamondKey, ""); |
| 989 | 1025 |
| 990 TestingPrefServiceSyncable prefs; | 1026 TestingPrefServiceSyncable prefs; |
| 991 chromeos::Preferences::RegisterProfilePrefs(prefs.registry()); | 1027 chromeos::Preferences::RegisterProfilePrefs(prefs.registry()); |
| 992 | 1028 |
| 993 chromeos::input_method::FakeImeKeyboard ime_keyboard; | 1029 chromeos::input_method::FakeImeKeyboard ime_keyboard; |
| 994 EventRewriter rewriter(NULL); | 1030 EventRewriter rewriter(NULL); |
| 1031 rewriter.KeyboardDeviceAddedForTesting(kKeyboardDeviceId, "PC Keyboard"); | |
| 995 rewriter.set_pref_service_for_testing(&prefs); | 1032 rewriter.set_pref_service_for_testing(&prefs); |
| 996 rewriter.set_ime_keyboard_for_testing(&ime_keyboard); | 1033 rewriter.set_ime_keyboard_for_testing(&ime_keyboard); |
| 997 | 1034 |
| 998 // By default, F15 should work as Control. | 1035 // By default, F15 should work as Control. |
| 999 EXPECT_EQ(GetExpectedResultAsString( | 1036 EXPECT_EQ(GetExpectedResultAsString( |
| 1000 ui::VKEY_CONTROL, ui::EF_CONTROL_DOWN, ui::ET_KEY_PRESSED), | 1037 ui::VKEY_CONTROL, ui::EF_CONTROL_DOWN, ui::ET_KEY_PRESSED), |
| 1001 GetRewrittenEventAsString( | 1038 GetRewrittenEventAsString( |
| 1002 &rewriter, ui::VKEY_F15, ui::EF_NONE, ui::ET_KEY_PRESSED)); | 1039 &rewriter, ui::VKEY_F15, ui::EF_NONE, ui::ET_KEY_PRESSED)); |
| 1003 | 1040 |
| 1004 IntegerPrefMember diamond; | 1041 IntegerPrefMember diamond; |
| (...skipping 32 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 1037 | 1074 |
| 1038 TEST_F(EventRewriterTest, TestRewriteCapsLockToControl) { | 1075 TEST_F(EventRewriterTest, TestRewriteCapsLockToControl) { |
| 1039 // Remap CapsLock to Control. | 1076 // Remap CapsLock to Control. |
| 1040 TestingPrefServiceSyncable prefs; | 1077 TestingPrefServiceSyncable prefs; |
| 1041 chromeos::Preferences::RegisterProfilePrefs(prefs.registry()); | 1078 chromeos::Preferences::RegisterProfilePrefs(prefs.registry()); |
| 1042 IntegerPrefMember control; | 1079 IntegerPrefMember control; |
| 1043 control.Init(prefs::kLanguageRemapCapsLockKeyTo, &prefs); | 1080 control.Init(prefs::kLanguageRemapCapsLockKeyTo, &prefs); |
| 1044 control.SetValue(chromeos::input_method::kControlKey); | 1081 control.SetValue(chromeos::input_method::kControlKey); |
| 1045 | 1082 |
| 1046 EventRewriter rewriter(NULL); | 1083 EventRewriter rewriter(NULL); |
| 1084 rewriter.KeyboardDeviceAddedForTesting(kKeyboardDeviceId, "PC Keyboard"); | |
| 1047 rewriter.set_pref_service_for_testing(&prefs); | 1085 rewriter.set_pref_service_for_testing(&prefs); |
| 1048 | 1086 |
| 1049 KeyTestCase tests[] = { | 1087 KeyTestCase tests[] = { |
| 1050 // Press CapsLock+a. Confirm that Mod3Mask is rewritten to ControlMask. | 1088 // Press CapsLock+a. Confirm that Mod3Mask is rewritten to ControlMask. |
| 1051 // On Chrome OS, CapsLock works as a Mod3 modifier. | 1089 // On Chrome OS, CapsLock works as a Mod3 modifier. |
| 1052 {KeyTestCase::TEST_ALL, ui::ET_KEY_PRESSED, | 1090 {KeyTestCase::TEST_ALL, ui::ET_KEY_PRESSED, |
| 1053 {ui::VKEY_A, ui::EF_MOD3_DOWN}, | 1091 {ui::VKEY_A, ui::EF_MOD3_DOWN}, |
| 1054 {ui::VKEY_A, ui::EF_CONTROL_DOWN}}, | 1092 {ui::VKEY_A, ui::EF_CONTROL_DOWN}}, |
| 1055 | 1093 |
| 1056 // Press Control+CapsLock+a. Confirm that Mod3Mask is rewritten to | 1094 // Press Control+CapsLock+a. Confirm that Mod3Mask is rewritten to |
| (...skipping 16 matching lines...) Expand all Loading... | |
| 1073 | 1111 |
| 1074 TEST_F(EventRewriterTest, TestRewriteCapsLockMod3InUse) { | 1112 TEST_F(EventRewriterTest, TestRewriteCapsLockMod3InUse) { |
| 1075 // Remap CapsLock to Control. | 1113 // Remap CapsLock to Control. |
| 1076 TestingPrefServiceSyncable prefs; | 1114 TestingPrefServiceSyncable prefs; |
| 1077 chromeos::Preferences::RegisterProfilePrefs(prefs.registry()); | 1115 chromeos::Preferences::RegisterProfilePrefs(prefs.registry()); |
| 1078 IntegerPrefMember control; | 1116 IntegerPrefMember control; |
| 1079 control.Init(prefs::kLanguageRemapCapsLockKeyTo, &prefs); | 1117 control.Init(prefs::kLanguageRemapCapsLockKeyTo, &prefs); |
| 1080 control.SetValue(chromeos::input_method::kControlKey); | 1118 control.SetValue(chromeos::input_method::kControlKey); |
| 1081 | 1119 |
| 1082 EventRewriter rewriter(NULL); | 1120 EventRewriter rewriter(NULL); |
| 1121 rewriter.KeyboardDeviceAddedForTesting(kKeyboardDeviceId, "PC Keyboard"); | |
| 1083 rewriter.set_pref_service_for_testing(&prefs); | 1122 rewriter.set_pref_service_for_testing(&prefs); |
| 1084 input_method_manager_mock_->set_mod3_used(true); | 1123 input_method_manager_mock_->set_mod3_used(true); |
| 1085 | 1124 |
| 1086 // Press CapsLock+a. Confirm that Mod3Mask is NOT rewritten to ControlMask | 1125 // Press CapsLock+a. Confirm that Mod3Mask is NOT rewritten to ControlMask |
| 1087 // when Mod3Mask is already in use by the current XKB layout. | 1126 // when Mod3Mask is already in use by the current XKB layout. |
| 1088 EXPECT_EQ( | 1127 EXPECT_EQ( |
| 1089 GetExpectedResultAsString(ui::VKEY_A, ui::EF_NONE, ui::ET_KEY_PRESSED), | 1128 GetExpectedResultAsString(ui::VKEY_A, ui::EF_NONE, ui::ET_KEY_PRESSED), |
| 1090 GetRewrittenEventAsString( | 1129 GetRewrittenEventAsString( |
| 1091 &rewriter, ui::VKEY_A, ui::EF_NONE, ui::ET_KEY_PRESSED)); | 1130 &rewriter, ui::VKEY_A, ui::EF_NONE, ui::ET_KEY_PRESSED)); |
| 1092 | 1131 |
| 1093 input_method_manager_mock_->set_mod3_used(false); | 1132 input_method_manager_mock_->set_mod3_used(false); |
| 1094 } | 1133 } |
| 1095 | 1134 |
| 1096 TEST_F(EventRewriterTest, TestRewriteExtendedKeys) { | 1135 TEST_F(EventRewriterTest, TestRewriteExtendedKeys) { |
| 1097 TestingPrefServiceSyncable prefs; | 1136 TestingPrefServiceSyncable prefs; |
| 1098 chromeos::Preferences::RegisterProfilePrefs(prefs.registry()); | 1137 chromeos::Preferences::RegisterProfilePrefs(prefs.registry()); |
| 1099 EventRewriter rewriter(NULL); | 1138 EventRewriter rewriter(NULL); |
| 1100 rewriter.DeviceAddedForTesting(0, "PC Keyboard"); | 1139 rewriter.KeyboardDeviceAddedForTesting(kKeyboardDeviceId, "PC Keyboard"); |
| 1101 rewriter.set_last_device_id_for_testing(0); | 1140 rewriter.set_last_keyboard_device_id_for_testing(kKeyboardDeviceId); |
| 1102 rewriter.set_pref_service_for_testing(&prefs); | 1141 rewriter.set_pref_service_for_testing(&prefs); |
| 1103 | 1142 |
| 1104 KeyTestCase tests[] = { | 1143 KeyTestCase tests[] = { |
| 1105 // Alt+Backspace -> Delete | 1144 // Alt+Backspace -> Delete |
| 1106 {KeyTestCase::TEST_ALL, ui::ET_KEY_PRESSED, | 1145 {KeyTestCase::TEST_ALL, ui::ET_KEY_PRESSED, |
| 1107 {ui::VKEY_BACK, ui::EF_ALT_DOWN}, | 1146 {ui::VKEY_BACK, ui::EF_ALT_DOWN}, |
| 1108 {ui::VKEY_DELETE, ui::EF_NONE}}, | 1147 {ui::VKEY_DELETE, ui::EF_NONE}}, |
| 1109 // Control+Alt+Backspace -> Control+Delete | 1148 // Control+Alt+Backspace -> Control+Delete |
| 1110 {KeyTestCase::TEST_ALL, ui::ET_KEY_PRESSED, | 1149 {KeyTestCase::TEST_ALL, ui::ET_KEY_PRESSED, |
| 1111 {ui::VKEY_BACK, ui::EF_ALT_DOWN | ui::EF_CONTROL_DOWN}, | 1150 {ui::VKEY_BACK, ui::EF_ALT_DOWN | ui::EF_CONTROL_DOWN}, |
| (...skipping 87 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 1199 | 1238 |
| 1200 for (size_t i = 0; i < arraysize(tests); ++i) { | 1239 for (size_t i = 0; i < arraysize(tests); ++i) { |
| 1201 CheckKeyTestCase(1000 + i, &rewriter, tests[i]); | 1240 CheckKeyTestCase(1000 + i, &rewriter, tests[i]); |
| 1202 } | 1241 } |
| 1203 } | 1242 } |
| 1204 | 1243 |
| 1205 TEST_F(EventRewriterTest, TestRewriteFunctionKeys) { | 1244 TEST_F(EventRewriterTest, TestRewriteFunctionKeys) { |
| 1206 TestingPrefServiceSyncable prefs; | 1245 TestingPrefServiceSyncable prefs; |
| 1207 chromeos::Preferences::RegisterProfilePrefs(prefs.registry()); | 1246 chromeos::Preferences::RegisterProfilePrefs(prefs.registry()); |
| 1208 EventRewriter rewriter(NULL); | 1247 EventRewriter rewriter(NULL); |
| 1248 rewriter.KeyboardDeviceAddedForTesting(kKeyboardDeviceId, "PC Keyboard"); | |
| 1209 rewriter.set_pref_service_for_testing(&prefs); | 1249 rewriter.set_pref_service_for_testing(&prefs); |
| 1210 | 1250 |
| 1211 FunctionKeyTestCase tests[] = { | 1251 FunctionKeyTestCase tests[] = { |
| 1212 // F1 -> Back | 1252 // F1 -> Back |
| 1213 {ui::ET_KEY_PRESSED, | 1253 {ui::ET_KEY_PRESSED, |
| 1214 {ui::VKEY_F1, ui::EF_NONE}, | 1254 {ui::VKEY_F1, ui::EF_NONE}, |
| 1215 {ui::VKEY_BROWSER_BACK, ui::EF_NONE}, | 1255 {ui::VKEY_BROWSER_BACK, ui::EF_NONE}, |
| 1216 {ui::VKEY_BROWSER_BACK, ui::EF_FUNCTION_KEY}}, | 1256 {ui::VKEY_BROWSER_BACK, ui::EF_FUNCTION_KEY}}, |
| 1217 {ui::ET_KEY_PRESSED, | 1257 {ui::ET_KEY_PRESSED, |
| 1218 {ui::VKEY_F1, ui::EF_CONTROL_DOWN}, | 1258 {ui::VKEY_F1, ui::EF_CONTROL_DOWN}, |
| (...skipping 308 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 1527 const CommandLine original_cl(*CommandLine::ForCurrentProcess()); | 1567 const CommandLine original_cl(*CommandLine::ForCurrentProcess()); |
| 1528 | 1568 |
| 1529 // Remap Search to Control. | 1569 // Remap Search to Control. |
| 1530 TestingPrefServiceSyncable prefs; | 1570 TestingPrefServiceSyncable prefs; |
| 1531 chromeos::Preferences::RegisterProfilePrefs(prefs.registry()); | 1571 chromeos::Preferences::RegisterProfilePrefs(prefs.registry()); |
| 1532 IntegerPrefMember search; | 1572 IntegerPrefMember search; |
| 1533 search.Init(prefs::kLanguageRemapSearchKeyTo, &prefs); | 1573 search.Init(prefs::kLanguageRemapSearchKeyTo, &prefs); |
| 1534 search.SetValue(chromeos::input_method::kControlKey); | 1574 search.SetValue(chromeos::input_method::kControlKey); |
| 1535 | 1575 |
| 1536 EventRewriter rewriter(NULL); | 1576 EventRewriter rewriter(NULL); |
| 1577 rewriter.KeyboardDeviceAddedForTesting(kKeyboardDeviceId, "PC Keyboard"); | |
| 1537 rewriter.set_pref_service_for_testing(&prefs); | 1578 rewriter.set_pref_service_for_testing(&prefs); |
| 1538 | 1579 |
| 1539 CommandLine::ForCurrentProcess()->AppendSwitchASCII( | 1580 CommandLine::ForCurrentProcess()->AppendSwitchASCII( |
| 1540 chromeos::switches::kHasChromeOSKeyboard, ""); | 1581 chromeos::switches::kHasChromeOSKeyboard, ""); |
| 1541 | 1582 |
| 1542 KeyTestCase tests[] = { | 1583 KeyTestCase tests[] = { |
| 1543 // Alt+Search+Down -> End | 1584 // Alt+Search+Down -> End |
| 1544 {KeyTestCase::TEST_ALL, ui::ET_KEY_PRESSED, | 1585 {KeyTestCase::TEST_ALL, ui::ET_KEY_PRESSED, |
| 1545 {ui::VKEY_DOWN, ui::EF_ALT_DOWN | ui::EF_COMMAND_DOWN}, | 1586 {ui::VKEY_DOWN, ui::EF_ALT_DOWN | ui::EF_COMMAND_DOWN}, |
| 1546 {ui::VKEY_END, ui::EF_NONE}}, | 1587 {ui::VKEY_END, ui::EF_NONE}}, |
| (...skipping 16 matching lines...) Expand all Loading... | |
| 1563 #if defined(USE_X11) | 1604 #if defined(USE_X11) |
| 1564 // TODO(kpschoedel): pending alternative to xevent.xany.send_event | 1605 // TODO(kpschoedel): pending alternative to xevent.xany.send_event |
| 1565 // Remap Control to Alt. | 1606 // Remap Control to Alt. |
| 1566 TestingPrefServiceSyncable prefs; | 1607 TestingPrefServiceSyncable prefs; |
| 1567 chromeos::Preferences::RegisterProfilePrefs(prefs.registry()); | 1608 chromeos::Preferences::RegisterProfilePrefs(prefs.registry()); |
| 1568 IntegerPrefMember control; | 1609 IntegerPrefMember control; |
| 1569 control.Init(prefs::kLanguageRemapControlKeyTo, &prefs); | 1610 control.Init(prefs::kLanguageRemapControlKeyTo, &prefs); |
| 1570 control.SetValue(chromeos::input_method::kAltKey); | 1611 control.SetValue(chromeos::input_method::kAltKey); |
| 1571 | 1612 |
| 1572 EventRewriter rewriter(NULL); | 1613 EventRewriter rewriter(NULL); |
| 1614 rewriter.KeyboardDeviceAddedForTesting(kKeyboardDeviceId, "PC Keyboard"); | |
| 1573 rewriter.set_pref_service_for_testing(&prefs); | 1615 rewriter.set_pref_service_for_testing(&prefs); |
| 1574 | 1616 |
| 1575 // Send left control press. | 1617 // Send left control press. |
| 1576 std::string rewritten_event; | 1618 std::string rewritten_event; |
| 1577 { | 1619 { |
| 1578 ui::ScopedXI2Event xev; | 1620 ui::ScopedXI2Event xev; |
| 1579 xev.InitKeyEvent(ui::ET_KEY_PRESSED, ui::VKEY_CONTROL, 0); | 1621 xev.InitKeyEvent(ui::ET_KEY_PRESSED, ui::VKEY_CONTROL, 0); |
| 1580 XEvent* xevent = xev; | 1622 XEvent* xevent = xev; |
| 1581 xevent->xkey.keycode = XKeysymToKeycode(gfx::GetXDisplay(), XK_Control_L); | 1623 xevent->xkey.keycode = XKeysymToKeycode(gfx::GetXDisplay(), XK_Control_L); |
| 1582 xevent->xkey.send_event = True; // XSendEvent() always does this. | 1624 xevent->xkey.send_event = True; // XSendEvent() always does this. |
| (...skipping 10 matching lines...) Expand all Loading... | |
| 1593 | 1635 |
| 1594 TEST_F(EventRewriterTest, TestRewriteNonNativeEvent) { | 1636 TEST_F(EventRewriterTest, TestRewriteNonNativeEvent) { |
| 1595 // Remap Control to Alt. | 1637 // Remap Control to Alt. |
| 1596 TestingPrefServiceSyncable prefs; | 1638 TestingPrefServiceSyncable prefs; |
| 1597 chromeos::Preferences::RegisterProfilePrefs(prefs.registry()); | 1639 chromeos::Preferences::RegisterProfilePrefs(prefs.registry()); |
| 1598 IntegerPrefMember control; | 1640 IntegerPrefMember control; |
| 1599 control.Init(prefs::kLanguageRemapControlKeyTo, &prefs); | 1641 control.Init(prefs::kLanguageRemapControlKeyTo, &prefs); |
| 1600 control.SetValue(chromeos::input_method::kAltKey); | 1642 control.SetValue(chromeos::input_method::kAltKey); |
| 1601 | 1643 |
| 1602 EventRewriter rewriter(NULL); | 1644 EventRewriter rewriter(NULL); |
| 1645 rewriter.KeyboardDeviceAddedForTesting(kKeyboardDeviceId, "PC Keyboard"); | |
| 1603 rewriter.set_pref_service_for_testing(&prefs); | 1646 rewriter.set_pref_service_for_testing(&prefs); |
| 1604 | 1647 |
| 1605 const int kTouchId = 2; | 1648 const int kTouchId = 2; |
| 1606 gfx::Point location(0, 0); | 1649 gfx::Point location(0, 0); |
| 1607 ui::TouchEvent press( | 1650 ui::TouchEvent press( |
| 1608 ui::ET_TOUCH_PRESSED, location, kTouchId, base::TimeDelta()); | 1651 ui::ET_TOUCH_PRESSED, location, kTouchId, base::TimeDelta()); |
| 1609 press.set_flags(ui::EF_CONTROL_DOWN); | 1652 press.set_flags(ui::EF_CONTROL_DOWN); |
| 1610 | 1653 |
| 1611 scoped_ptr<ui::Event> new_event; | 1654 scoped_ptr<ui::Event> new_event; |
| 1612 rewriter.RewriteEvent(press, &new_event); | 1655 rewriter.RewriteEvent(press, &new_event); |
| (...skipping 174 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 1787 ui::TouchFactory::GetInstance()->SetPointerDeviceForTest(device_list); | 1830 ui::TouchFactory::GetInstance()->SetPointerDeviceForTest(device_list); |
| 1788 | 1831 |
| 1789 // Remap Control to Alt. | 1832 // Remap Control to Alt. |
| 1790 TestingPrefServiceSyncable prefs; | 1833 TestingPrefServiceSyncable prefs; |
| 1791 chromeos::Preferences::RegisterProfilePrefs(prefs.registry()); | 1834 chromeos::Preferences::RegisterProfilePrefs(prefs.registry()); |
| 1792 IntegerPrefMember control; | 1835 IntegerPrefMember control; |
| 1793 control.Init(prefs::kLanguageRemapControlKeyTo, &prefs); | 1836 control.Init(prefs::kLanguageRemapControlKeyTo, &prefs); |
| 1794 control.SetValue(chromeos::input_method::kAltKey); | 1837 control.SetValue(chromeos::input_method::kAltKey); |
| 1795 | 1838 |
| 1796 EventRewriter rewriter(NULL); | 1839 EventRewriter rewriter(NULL); |
| 1840 rewriter.KeyboardDeviceAddedForTesting(kKeyboardDeviceId, "PC Keyboard"); | |
| 1797 rewriter.set_pref_service_for_testing(&prefs); | 1841 rewriter.set_pref_service_for_testing(&prefs); |
| 1798 | 1842 |
| 1799 // Check that Control + Left Button is converted (via Alt + Left Button) | 1843 // Check that Control + Left Button is converted (via Alt + Left Button) |
| 1800 // to Right Button. | 1844 // to Right Button. |
| 1801 ui::ScopedXI2Event xev; | 1845 ui::ScopedXI2Event xev; |
| 1802 xev.InitGenericButtonEvent(10, | 1846 xev.InitGenericButtonEvent(10, |
| 1803 ui::ET_MOUSE_PRESSED, | 1847 ui::ET_MOUSE_PRESSED, |
| 1804 gfx::Point(), | 1848 gfx::Point(), |
| 1805 ui::EF_LEFT_MOUSE_BUTTON | ui::EF_CONTROL_DOWN); | 1849 ui::EF_LEFT_MOUSE_BUTTON | ui::EF_CONTROL_DOWN); |
| 1806 ui::MouseEvent press(xev); | 1850 ui::MouseEvent press(xev); |
| 1807 // Sanity check. | 1851 // Sanity check. |
| 1808 EXPECT_EQ(ui::ET_MOUSE_PRESSED, press.type()); | 1852 EXPECT_EQ(ui::ET_MOUSE_PRESSED, press.type()); |
| 1809 EXPECT_EQ(ui::EF_LEFT_MOUSE_BUTTON | ui::EF_CONTROL_DOWN, press.flags()); | 1853 EXPECT_EQ(ui::EF_LEFT_MOUSE_BUTTON | ui::EF_CONTROL_DOWN, press.flags()); |
| 1810 int flags = RewriteMouseEvent(&rewriter, press); | 1854 scoped_ptr<ui::Event> new_event; |
| 1811 EXPECT_TRUE(ui::EF_RIGHT_MOUSE_BUTTON & flags); | 1855 const ui::MouseEvent* result = |
| 1812 EXPECT_FALSE(ui::EF_CONTROL_DOWN & flags); | 1856 RewriteMouseButtonEvent(&rewriter, press, &new_event); |
| 1813 EXPECT_FALSE(ui::EF_ALT_DOWN & flags); | 1857 EXPECT_TRUE(ui::EF_RIGHT_MOUSE_BUTTON & result->flags()); |
| 1858 EXPECT_FALSE(ui::EF_LEFT_MOUSE_BUTTON & result->flags()); | |
| 1859 EXPECT_FALSE(ui::EF_CONTROL_DOWN & result->flags()); | |
| 1860 EXPECT_FALSE(ui::EF_ALT_DOWN & result->flags()); | |
| 1861 EXPECT_TRUE(ui::EF_RIGHT_MOUSE_BUTTON & result->flags()); | |
| 1814 } | 1862 } |
| 1815 | 1863 |
| 1816 | |
| 1817 TEST_F(EventRewriterTest, DontRewriteIfNotRewritten) { | 1864 TEST_F(EventRewriterTest, DontRewriteIfNotRewritten) { |
| 1818 #if defined(USE_X11) | |
| 1819 // TODO(kpschoedel): pending changes for crbug.com/360377 | 1865 // TODO(kpschoedel): pending changes for crbug.com/360377 |
| 1820 // to |chromeos::EventRewriter::RewriteLocatedEvent() | 1866 // to |chromeos::EventRewriter::RewriteLocatedEvent() |
| 1821 std::vector<unsigned int> device_list; | 1867 std::vector<unsigned int> device_list; |
| 1822 device_list.push_back(10); | 1868 device_list.push_back(10); |
| 1823 device_list.push_back(11); | 1869 device_list.push_back(11); |
| 1824 ui::TouchFactory::GetInstance()->SetPointerDeviceForTest(device_list); | 1870 ui::TouchFactory::GetInstance()->SetPointerDeviceForTest(device_list); |
| 1825 TestingPrefServiceSyncable prefs; | 1871 TestingPrefServiceSyncable prefs; |
| 1826 EventRewriter rewriter(NULL); | 1872 EventRewriter rewriter(NULL); |
| 1827 rewriter.set_pref_service_for_testing(&prefs); | 1873 rewriter.set_pref_service_for_testing(&prefs); |
| 1828 const int kLeftAndAltFlag = ui::EF_LEFT_MOUSE_BUTTON | ui::EF_ALT_DOWN; | 1874 const int kLeftAndAltFlag = ui::EF_LEFT_MOUSE_BUTTON | ui::EF_ALT_DOWN; |
| 1875 | |
| 1876 // Test Alt + Left click. | |
| 1877 { | |
| 1878 ui::MouseEvent press(ui::ET_MOUSE_PRESSED, | |
| 1879 gfx::Point(), | |
| 1880 gfx::Point(), | |
| 1881 kLeftAndAltFlag, | |
| 1882 ui::EF_LEFT_MOUSE_BUTTON); | |
| 1883 press.set_source_device_id(10); | |
| 1884 // Sanity check. | |
| 1885 EXPECT_EQ(ui::ET_MOUSE_PRESSED, press.type()); | |
| 1886 EXPECT_EQ(kLeftAndAltFlag, press.flags()); | |
| 1887 scoped_ptr<ui::Event> new_event; | |
| 1888 const ui::MouseEvent* result = | |
| 1889 RewriteMouseButtonEvent(&rewriter, press, &new_event); | |
| 1890 EXPECT_TRUE(ui::EF_RIGHT_MOUSE_BUTTON & result->flags()); | |
| 1891 EXPECT_FALSE(kLeftAndAltFlag & result->flags()); | |
| 1892 EXPECT_EQ(ui::EF_RIGHT_MOUSE_BUTTON, result->changed_button_flags()); | |
| 1893 } | |
| 1894 { | |
| 1895 ui::MouseEvent release(ui::ET_MOUSE_RELEASED, | |
| 1896 gfx::Point(), | |
| 1897 gfx::Point(), | |
| 1898 kLeftAndAltFlag, | |
| 1899 ui::EF_LEFT_MOUSE_BUTTON); | |
| 1900 release.set_source_device_id(10); | |
| 1901 scoped_ptr<ui::Event> new_event; | |
| 1902 const ui::MouseEvent* result = | |
| 1903 RewriteMouseButtonEvent(&rewriter, release, &new_event); | |
| 1904 EXPECT_TRUE(ui::EF_RIGHT_MOUSE_BUTTON & result->flags()); | |
| 1905 EXPECT_FALSE(kLeftAndAltFlag & result->flags()); | |
| 1906 EXPECT_EQ(ui::EF_RIGHT_MOUSE_BUTTON, result->changed_button_flags()); | |
| 1907 } | |
| 1908 #if defined(USE_X11) | |
| 1909 // Test Alt + Left click, using XI2 native events. | |
| 1829 { | 1910 { |
| 1830 ui::ScopedXI2Event xev; | 1911 ui::ScopedXI2Event xev; |
| 1831 xev.InitGenericButtonEvent( | 1912 xev.InitGenericButtonEvent( |
| 1832 10, ui::ET_MOUSE_PRESSED, gfx::Point(), kLeftAndAltFlag); | 1913 10, ui::ET_MOUSE_PRESSED, gfx::Point(), kLeftAndAltFlag); |
| 1833 ui::MouseEvent press(xev); | 1914 ui::MouseEvent press(xev); |
| 1834 // Sanity check. | 1915 // Sanity check. |
| 1835 EXPECT_EQ(ui::ET_MOUSE_PRESSED, press.type()); | 1916 EXPECT_EQ(ui::ET_MOUSE_PRESSED, press.type()); |
| 1836 EXPECT_EQ(kLeftAndAltFlag, press.flags()); | 1917 EXPECT_EQ(kLeftAndAltFlag, press.flags()); |
| 1837 int flags = RewriteMouseEvent(&rewriter, press); | 1918 scoped_ptr<ui::Event> new_event; |
| 1838 EXPECT_TRUE(ui::EF_RIGHT_MOUSE_BUTTON & flags); | 1919 const ui::MouseEvent* result = |
| 1920 RewriteMouseButtonEvent(&rewriter, press, &new_event); | |
| 1921 EXPECT_TRUE(ui::EF_RIGHT_MOUSE_BUTTON & result->flags()); | |
| 1922 EXPECT_FALSE(kLeftAndAltFlag & result->flags()); | |
| 1923 EXPECT_EQ(ui::EF_RIGHT_MOUSE_BUTTON, result->changed_button_flags()); | |
| 1839 } | 1924 } |
| 1840 { | 1925 { |
| 1841 ui::ScopedXI2Event xev; | 1926 ui::ScopedXI2Event xev; |
| 1842 xev.InitGenericButtonEvent( | 1927 xev.InitGenericButtonEvent( |
| 1843 10, ui::ET_MOUSE_RELEASED, gfx::Point(), kLeftAndAltFlag); | 1928 10, ui::ET_MOUSE_RELEASED, gfx::Point(), kLeftAndAltFlag); |
| 1844 ui::MouseEvent release(xev); | 1929 ui::MouseEvent release(xev); |
| 1845 int flags = RewriteMouseEvent(&rewriter, release); | 1930 scoped_ptr<ui::Event> new_event; |
| 1846 EXPECT_TRUE(ui::EF_RIGHT_MOUSE_BUTTON & flags); | 1931 const ui::MouseEvent* result = |
| 1932 RewriteMouseButtonEvent(&rewriter, release, &new_event); | |
| 1933 EXPECT_TRUE(ui::EF_RIGHT_MOUSE_BUTTON & result->flags()); | |
| 1934 EXPECT_FALSE(kLeftAndAltFlag & result->flags()); | |
| 1935 EXPECT_EQ(ui::EF_RIGHT_MOUSE_BUTTON, result->changed_button_flags()); | |
| 1847 } | 1936 } |
| 1937 #endif | |
| 1848 | 1938 |
| 1849 // No ALT in frst click. | 1939 // No ALT in frst click. |
| 1850 { | 1940 { |
| 1941 ui::MouseEvent press(ui::ET_MOUSE_PRESSED, | |
| 1942 gfx::Point(), | |
| 1943 gfx::Point(), | |
| 1944 ui::EF_LEFT_MOUSE_BUTTON, | |
| 1945 ui::EF_LEFT_MOUSE_BUTTON); | |
| 1946 press.set_source_device_id(10); | |
| 1947 scoped_ptr<ui::Event> new_event; | |
| 1948 const ui::MouseEvent* result = | |
| 1949 RewriteMouseButtonEvent(&rewriter, press, &new_event); | |
| 1950 EXPECT_TRUE(ui::EF_LEFT_MOUSE_BUTTON & result->flags()); | |
| 1951 EXPECT_EQ(ui::EF_LEFT_MOUSE_BUTTON, result->changed_button_flags()); | |
| 1952 } | |
| 1953 { | |
| 1954 ui::MouseEvent release(ui::ET_MOUSE_RELEASED, | |
| 1955 gfx::Point(), | |
| 1956 gfx::Point(), | |
| 1957 kLeftAndAltFlag, | |
| 1958 ui::EF_LEFT_MOUSE_BUTTON); | |
| 1959 release.set_source_device_id(10); | |
| 1960 scoped_ptr<ui::Event> new_event; | |
| 1961 const ui::MouseEvent* result = | |
| 1962 RewriteMouseButtonEvent(&rewriter, release, &new_event); | |
| 1963 EXPECT_TRUE((ui::EF_LEFT_MOUSE_BUTTON | ui::EF_ALT_DOWN) & result->flags()); | |
| 1964 EXPECT_EQ(ui::EF_LEFT_MOUSE_BUTTON, result->changed_button_flags()); | |
| 1965 } | |
| 1966 #if defined(USE_X11) | |
| 1967 // No ALT in frst click, using XI2 native events. | |
| 1968 { | |
| 1851 ui::ScopedXI2Event xev; | 1969 ui::ScopedXI2Event xev; |
| 1852 xev.InitGenericButtonEvent( | 1970 xev.InitGenericButtonEvent( |
| 1853 10, ui::ET_MOUSE_PRESSED, gfx::Point(), ui::EF_LEFT_MOUSE_BUTTON); | 1971 10, ui::ET_MOUSE_PRESSED, gfx::Point(), ui::EF_LEFT_MOUSE_BUTTON); |
| 1854 ui::MouseEvent press(xev); | 1972 ui::MouseEvent press(xev); |
| 1855 int flags = RewriteMouseEvent(&rewriter, press); | 1973 scoped_ptr<ui::Event> new_event; |
| 1856 EXPECT_TRUE(ui::EF_LEFT_MOUSE_BUTTON & flags); | 1974 const ui::MouseEvent* result = |
| 1975 RewriteMouseButtonEvent(&rewriter, press, &new_event); | |
| 1976 EXPECT_TRUE(ui::EF_LEFT_MOUSE_BUTTON & result->flags()); | |
| 1977 EXPECT_EQ(ui::EF_LEFT_MOUSE_BUTTON, result->changed_button_flags()); | |
| 1857 } | 1978 } |
| 1858 { | 1979 { |
| 1859 ui::ScopedXI2Event xev; | 1980 ui::ScopedXI2Event xev; |
| 1860 xev.InitGenericButtonEvent( | 1981 xev.InitGenericButtonEvent( |
| 1861 10, ui::ET_MOUSE_RELEASED, gfx::Point(), kLeftAndAltFlag); | 1982 10, ui::ET_MOUSE_RELEASED, gfx::Point(), kLeftAndAltFlag); |
| 1862 ui::MouseEvent release(xev); | 1983 ui::MouseEvent release(xev); |
| 1863 int flags = RewriteMouseEvent(&rewriter, release); | 1984 scoped_ptr<ui::Event> new_event; |
| 1864 EXPECT_TRUE((ui::EF_LEFT_MOUSE_BUTTON | ui::EF_ALT_DOWN) & flags); | 1985 const ui::MouseEvent* result = |
| 1986 RewriteMouseButtonEvent(&rewriter, release, &new_event); | |
| 1987 EXPECT_TRUE((ui::EF_LEFT_MOUSE_BUTTON | ui::EF_ALT_DOWN) & result->flags()); | |
| 1988 EXPECT_EQ(ui::EF_LEFT_MOUSE_BUTTON, result->changed_button_flags()); | |
| 1865 } | 1989 } |
| 1990 #endif | |
| 1866 | 1991 |
| 1867 // ALT on different device. | 1992 // ALT on different device. |
| 1868 { | 1993 { |
| 1994 ui::MouseEvent press(ui::ET_MOUSE_PRESSED, | |
| 1995 gfx::Point(), | |
| 1996 gfx::Point(), | |
| 1997 kLeftAndAltFlag, | |
| 1998 ui::EF_LEFT_MOUSE_BUTTON); | |
| 1999 press.set_source_device_id(11); | |
| 2000 scoped_ptr<ui::Event> new_event; | |
| 2001 const ui::MouseEvent* result = | |
| 2002 RewriteMouseButtonEvent(&rewriter, press, &new_event); | |
| 2003 EXPECT_TRUE(ui::EF_RIGHT_MOUSE_BUTTON & result->flags()); | |
| 2004 EXPECT_FALSE(kLeftAndAltFlag & result->flags()); | |
| 2005 EXPECT_EQ(ui::EF_RIGHT_MOUSE_BUTTON, result->changed_button_flags()); | |
| 2006 } | |
| 2007 { | |
| 2008 ui::MouseEvent release(ui::ET_MOUSE_RELEASED, | |
| 2009 gfx::Point(), | |
| 2010 gfx::Point(), | |
| 2011 kLeftAndAltFlag, | |
| 2012 ui::EF_LEFT_MOUSE_BUTTON); | |
| 2013 release.set_source_device_id(10); | |
| 2014 scoped_ptr<ui::Event> new_event; | |
| 2015 const ui::MouseEvent* result = | |
| 2016 RewriteMouseButtonEvent(&rewriter, release, &new_event); | |
| 2017 EXPECT_TRUE((ui::EF_LEFT_MOUSE_BUTTON | ui::EF_ALT_DOWN) & result->flags()); | |
| 2018 EXPECT_EQ(ui::EF_LEFT_MOUSE_BUTTON, result->changed_button_flags()); | |
| 2019 } | |
| 2020 { | |
| 2021 ui::MouseEvent release(ui::ET_MOUSE_RELEASED, | |
| 2022 gfx::Point(), | |
| 2023 gfx::Point(), | |
| 2024 kLeftAndAltFlag, | |
| 2025 ui::EF_LEFT_MOUSE_BUTTON); | |
| 2026 release.set_source_device_id(11); | |
| 2027 scoped_ptr<ui::Event> new_event; | |
| 2028 const ui::MouseEvent* result = | |
| 2029 RewriteMouseButtonEvent(&rewriter, release, &new_event); | |
| 2030 EXPECT_TRUE(ui::EF_RIGHT_MOUSE_BUTTON & result->flags()); | |
| 2031 EXPECT_FALSE(kLeftAndAltFlag & result->flags()); | |
| 2032 EXPECT_EQ(ui::EF_RIGHT_MOUSE_BUTTON, result->changed_button_flags()); | |
| 2033 } | |
| 2034 #if defined(USE_X11) | |
| 2035 // ALT on different device, using XI2 native events. | |
| 2036 { | |
| 1869 ui::ScopedXI2Event xev; | 2037 ui::ScopedXI2Event xev; |
| 1870 xev.InitGenericButtonEvent( | 2038 xev.InitGenericButtonEvent( |
| 1871 11, ui::ET_MOUSE_PRESSED, gfx::Point(), kLeftAndAltFlag); | 2039 11, ui::ET_MOUSE_PRESSED, gfx::Point(), kLeftAndAltFlag); |
| 1872 ui::MouseEvent press(xev); | 2040 ui::MouseEvent press(xev); |
| 1873 int flags = RewriteMouseEvent(&rewriter, press); | 2041 scoped_ptr<ui::Event> new_event; |
| 1874 EXPECT_TRUE(ui::EF_RIGHT_MOUSE_BUTTON & flags); | 2042 const ui::MouseEvent* result = |
| 2043 RewriteMouseButtonEvent(&rewriter, press, &new_event); | |
| 2044 EXPECT_TRUE(ui::EF_RIGHT_MOUSE_BUTTON & result->flags()); | |
| 2045 EXPECT_FALSE(kLeftAndAltFlag & result->flags()); | |
| 2046 EXPECT_EQ(ui::EF_RIGHT_MOUSE_BUTTON, result->changed_button_flags()); | |
| 1875 } | 2047 } |
| 1876 { | 2048 { |
| 1877 ui::ScopedXI2Event xev; | 2049 ui::ScopedXI2Event xev; |
| 1878 xev.InitGenericButtonEvent( | 2050 xev.InitGenericButtonEvent( |
| 1879 10, ui::ET_MOUSE_RELEASED, gfx::Point(), kLeftAndAltFlag); | 2051 10, ui::ET_MOUSE_RELEASED, gfx::Point(), kLeftAndAltFlag); |
| 1880 ui::MouseEvent release(xev); | 2052 ui::MouseEvent release(xev); |
| 1881 int flags = RewriteMouseEvent(&rewriter, release); | 2053 scoped_ptr<ui::Event> new_event; |
| 1882 EXPECT_TRUE((ui::EF_LEFT_MOUSE_BUTTON | ui::EF_ALT_DOWN) & flags); | 2054 const ui::MouseEvent* result = |
| 2055 RewriteMouseButtonEvent(&rewriter, release, &new_event); | |
| 2056 EXPECT_TRUE((ui::EF_LEFT_MOUSE_BUTTON | ui::EF_ALT_DOWN) & result->flags()); | |
| 2057 EXPECT_EQ(ui::EF_LEFT_MOUSE_BUTTON, result->changed_button_flags()); | |
| 1883 } | 2058 } |
| 1884 { | 2059 { |
| 1885 ui::ScopedXI2Event xev; | 2060 ui::ScopedXI2Event xev; |
| 1886 xev.InitGenericButtonEvent( | 2061 xev.InitGenericButtonEvent( |
| 1887 11, ui::ET_MOUSE_RELEASED, gfx::Point(), kLeftAndAltFlag); | 2062 11, ui::ET_MOUSE_RELEASED, gfx::Point(), kLeftAndAltFlag); |
| 1888 ui::MouseEvent release(xev); | 2063 ui::MouseEvent release(xev); |
| 1889 int flags = RewriteMouseEvent(&rewriter, release); | 2064 scoped_ptr<ui::Event> new_event; |
| 1890 EXPECT_TRUE(ui::EF_RIGHT_MOUSE_BUTTON & flags); | 2065 const ui::MouseEvent* result = |
| 2066 RewriteMouseButtonEvent(&rewriter, release, &new_event); | |
| 2067 EXPECT_TRUE(ui::EF_RIGHT_MOUSE_BUTTON & result->flags()); | |
| 2068 EXPECT_FALSE(kLeftAndAltFlag & result->flags()); | |
| 2069 EXPECT_EQ(ui::EF_RIGHT_MOUSE_BUTTON, result->changed_button_flags()); | |
| 1891 } | 2070 } |
| 1892 #endif | 2071 #endif |
| 1893 } | 2072 } |
| 1894 | 2073 |
| 1895 TEST_F(EventRewriterAshTest, StickyKeyEventDispatchImpl) { | 2074 TEST_F(EventRewriterAshTest, StickyKeyEventDispatchImpl) { |
| 1896 // Test the actual key event dispatch implementation. | 2075 // Test the actual key event dispatch implementation. |
| 1897 ScopedVector<ui::Event> events; | 2076 ScopedVector<ui::Event> events; |
| 1898 | 2077 |
| 1899 SendActivateStickyKeyPattern(ui::VKEY_CONTROL); | 2078 SendActivateStickyKeyPattern(ui::VKEY_CONTROL); |
| 1900 PopEvents(&events); | 2079 PopEvents(&events); |
| (...skipping 277 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 2178 EXPECT_FALSE(overlay_->GetModifierVisible(ui::EF_ALTGR_DOWN)); | 2357 EXPECT_FALSE(overlay_->GetModifierVisible(ui::EF_ALTGR_DOWN)); |
| 2179 EXPECT_TRUE(overlay_->GetModifierVisible(ui::EF_MOD3_DOWN)); | 2358 EXPECT_TRUE(overlay_->GetModifierVisible(ui::EF_MOD3_DOWN)); |
| 2180 | 2359 |
| 2181 // Turn off AltGr and Mod3. | 2360 // Turn off AltGr and Mod3. |
| 2182 sticky_keys_controller_->SetModifiersEnabled(false, false); | 2361 sticky_keys_controller_->SetModifiersEnabled(false, false); |
| 2183 EXPECT_FALSE(overlay_->GetModifierVisible(ui::EF_ALTGR_DOWN)); | 2362 EXPECT_FALSE(overlay_->GetModifierVisible(ui::EF_ALTGR_DOWN)); |
| 2184 EXPECT_FALSE(overlay_->GetModifierVisible(ui::EF_MOD3_DOWN)); | 2363 EXPECT_FALSE(overlay_->GetModifierVisible(ui::EF_MOD3_DOWN)); |
| 2185 } | 2364 } |
| 2186 | 2365 |
| 2187 } // namespace chromeos | 2366 } // namespace chromeos |
| OLD | NEW |