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

Side by Side Diff: chrome/browser/chromeos/events/event_rewriter_unittest.cc

Issue 336403005: Use XInput2 events for keyboard events. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Add TODO regarding XI2-to-core rewriting. Created 6 years, 6 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
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
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
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
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
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
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
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
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
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
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
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
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
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
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
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
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
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
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
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
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
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
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
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698