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

Side by Side Diff: ash/accelerators/accelerator_controller_unittest.cc

Issue 2068333002: Disable the deprecated Alt+Shift for NEXT_IME (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Created 4 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 (c) 2012 The Chromium Authors. All rights reserved. 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be 2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file. 3 // found in the LICENSE file.
4 4
5 #include "ash/accelerators/accelerator_controller.h" 5 #include "ash/accelerators/accelerator_controller.h"
6 6
7 #include "ash/accelerators/accelerator_table.h" 7 #include "ash/accelerators/accelerator_table.h"
8 #include "ash/ash_switches.h" 8 #include "ash/ash_switches.h"
9 #include "ash/aura/wm_window_aura.h" 9 #include "ash/aura/wm_window_aura.h"
10 #include "ash/common/accessibility_delegate.h" 10 #include "ash/common/accessibility_delegate.h"
(...skipping 1018 matching lines...) Expand 10 before | Expand all | Expand 10 after
1029 EXPECT_TRUE(ash::Shell::GetInstance()->GetAppListTargetVisibility()); 1029 EXPECT_TRUE(ash::Shell::GetInstance()->GetAppListTargetVisibility());
1030 EXPECT_FALSE(ProcessInController(ReleaseAccelerator(ui::VKEY_BROWSER_SEARCH, 1030 EXPECT_FALSE(ProcessInController(ReleaseAccelerator(ui::VKEY_BROWSER_SEARCH,
1031 ui::EF_NONE))); 1031 ui::EF_NONE)));
1032 EXPECT_TRUE(ash::Shell::GetInstance()->GetAppListTargetVisibility()); 1032 EXPECT_TRUE(ash::Shell::GetInstance()->GetAppListTargetVisibility());
1033 #endif 1033 #endif
1034 } 1034 }
1035 1035
1036 TEST_F(AcceleratorControllerTest, ImeGlobalAccelerators) { 1036 TEST_F(AcceleratorControllerTest, ImeGlobalAccelerators) {
1037 // Test IME shortcuts. 1037 // Test IME shortcuts.
1038 { 1038 {
1039 ui::Accelerator control_space_down(ui::VKEY_SPACE, ui::EF_CONTROL_DOWN); 1039 ui::Accelerator control_space_down(ui::VKEY_SPACE, ui::EF_CONTROL_DOWN);
1040 control_space_down.set_type(ui::ET_KEY_PRESSED); 1040 control_space_down.set_type(ui::ET_KEY_PRESSED);
1041 ui::Accelerator control_space_up(ui::VKEY_SPACE, ui::EF_CONTROL_DOWN); 1041 ui::Accelerator control_space_up(ui::VKEY_SPACE, ui::EF_CONTROL_DOWN);
1042 control_space_up.set_type(ui::ET_KEY_RELEASED); 1042 control_space_up.set_type(ui::ET_KEY_RELEASED);
1043 const ui::Accelerator convert(ui::VKEY_CONVERT, ui::EF_NONE); 1043 const ui::Accelerator convert(ui::VKEY_CONVERT, ui::EF_NONE);
1044 const ui::Accelerator non_convert(ui::VKEY_NONCONVERT, ui::EF_NONE); 1044 const ui::Accelerator non_convert(ui::VKEY_NONCONVERT, ui::EF_NONE);
1045 const ui::Accelerator wide_half_1(ui::VKEY_DBE_SBCSCHAR, ui::EF_NONE); 1045 const ui::Accelerator wide_half_1(ui::VKEY_DBE_SBCSCHAR, ui::EF_NONE);
1046 const ui::Accelerator wide_half_2(ui::VKEY_DBE_DBCSCHAR, ui::EF_NONE); 1046 const ui::Accelerator wide_half_2(ui::VKEY_DBE_DBCSCHAR, ui::EF_NONE);
1047 const ui::Accelerator hangul(ui::VKEY_HANGUL, ui::EF_NONE); 1047 const ui::Accelerator hangul(ui::VKEY_HANGUL, ui::EF_NONE);
1048 EXPECT_FALSE(ProcessInController(control_space_down)); 1048 EXPECT_FALSE(ProcessInController(control_space_down));
1049 EXPECT_FALSE(ProcessInController(control_space_up)); 1049 EXPECT_FALSE(ProcessInController(control_space_up));
(...skipping 16 matching lines...) Expand all
1066 EXPECT_TRUE(ProcessInController(non_convert)); 1066 EXPECT_TRUE(ProcessInController(non_convert));
1067 EXPECT_EQ(2, delegate->handle_switch_ime_count()); 1067 EXPECT_EQ(2, delegate->handle_switch_ime_count());
1068 EXPECT_TRUE(ProcessInController(wide_half_1)); 1068 EXPECT_TRUE(ProcessInController(wide_half_1));
1069 EXPECT_EQ(3, delegate->handle_switch_ime_count()); 1069 EXPECT_EQ(3, delegate->handle_switch_ime_count());
1070 EXPECT_TRUE(ProcessInController(wide_half_2)); 1070 EXPECT_TRUE(ProcessInController(wide_half_2));
1071 EXPECT_EQ(4, delegate->handle_switch_ime_count()); 1071 EXPECT_EQ(4, delegate->handle_switch_ime_count());
1072 EXPECT_TRUE(ProcessInController(hangul)); 1072 EXPECT_TRUE(ProcessInController(hangul));
1073 EXPECT_EQ(5, delegate->handle_switch_ime_count()); 1073 EXPECT_EQ(5, delegate->handle_switch_ime_count());
1074 } 1074 }
1075 1075
1076 // The Old NEXT_IME accelerators have been disabled on ChromeOS.
1077 #if !defined(OS_CHROMEOS)
1076 // Test IME shortcuts that are triggered on key release. 1078 // Test IME shortcuts that are triggered on key release.
1077 { 1079 {
1078 const ui::Accelerator shift_alt_press(ui::VKEY_MENU, 1080 const ui::Accelerator shift_alt_press(ui::VKEY_MENU,
1079 ui::EF_SHIFT_DOWN | ui::EF_ALT_DOWN); 1081 ui::EF_SHIFT_DOWN | ui::EF_ALT_DOWN);
1080 const ReleaseAccelerator shift_alt(ui::VKEY_MENU, ui::EF_SHIFT_DOWN); 1082 const ReleaseAccelerator shift_alt(ui::VKEY_MENU, ui::EF_SHIFT_DOWN);
1081 const ui::Accelerator alt_shift_press(ui::VKEY_SHIFT, 1083 const ui::Accelerator alt_shift_press(ui::VKEY_SHIFT,
1082 ui::EF_SHIFT_DOWN | ui::EF_ALT_DOWN); 1084 ui::EF_SHIFT_DOWN | ui::EF_ALT_DOWN);
1083 const ReleaseAccelerator alt_shift(ui::VKEY_SHIFT, ui::EF_ALT_DOWN); 1085 const ReleaseAccelerator alt_shift(ui::VKEY_SHIFT, ui::EF_ALT_DOWN);
1084 1086
1085 DummyImeControlDelegate* delegate = new DummyImeControlDelegate; 1087 DummyImeControlDelegate* delegate = new DummyImeControlDelegate;
(...skipping 42 matching lines...) Expand 10 before | Expand all | Expand 10 after
1128 const ReleaseAccelerator shift_alt_space( 1130 const ReleaseAccelerator shift_alt_space(
1129 ui::VKEY_SPACE, 1131 ui::VKEY_SPACE,
1130 ui::EF_SHIFT_DOWN | ui::EF_ALT_DOWN); 1132 ui::EF_SHIFT_DOWN | ui::EF_ALT_DOWN);
1131 1133
1132 EXPECT_FALSE(ProcessInController(shift_alt_press)); 1134 EXPECT_FALSE(ProcessInController(shift_alt_press));
1133 EXPECT_FALSE(ProcessInController(shift_alt_space_press)); 1135 EXPECT_FALSE(ProcessInController(shift_alt_space_press));
1134 EXPECT_FALSE(ProcessInController(shift_alt_space)); 1136 EXPECT_FALSE(ProcessInController(shift_alt_space));
1135 EXPECT_TRUE(ProcessInController(shift_alt)); 1137 EXPECT_TRUE(ProcessInController(shift_alt));
1136 EXPECT_EQ(5, delegate->handle_next_ime_count()); 1138 EXPECT_EQ(5, delegate->handle_next_ime_count());
1137 } 1139 }
1138 1140 #endif // defined(OS_CHROMEOS)
1139 #if defined(OS_CHROMEOS)
1140 // Test IME shortcuts again with unnormalized accelerators (Chrome OS only).
1141 {
1142 const ui::Accelerator shift_alt_press(ui::VKEY_MENU, ui::EF_SHIFT_DOWN);
1143 const ReleaseAccelerator shift_alt(ui::VKEY_MENU, ui::EF_SHIFT_DOWN);
1144 const ui::Accelerator alt_shift_press(ui::VKEY_SHIFT, ui::EF_ALT_DOWN);
1145 const ReleaseAccelerator alt_shift(ui::VKEY_SHIFT, ui::EF_ALT_DOWN);
1146
1147 DummyImeControlDelegate* delegate = new DummyImeControlDelegate;
1148 GetController()->SetImeControlDelegate(
1149 std::unique_ptr<ImeControlDelegate>(delegate));
1150 EXPECT_EQ(0, delegate->handle_next_ime_count());
1151 EXPECT_FALSE(ProcessInController(shift_alt_press));
1152 EXPECT_TRUE(ProcessInController(shift_alt));
1153 EXPECT_EQ(1, delegate->handle_next_ime_count());
1154 EXPECT_FALSE(ProcessInController(alt_shift_press));
1155 EXPECT_TRUE(ProcessInController(alt_shift));
1156 EXPECT_EQ(2, delegate->handle_next_ime_count());
1157
1158 // We should NOT switch IME when e.g. Shift+Alt+X is pressed and X is
1159 // released.
1160 const ui::Accelerator shift_alt_x_press(
1161 ui::VKEY_X,
1162 ui::EF_SHIFT_DOWN | ui::EF_ALT_DOWN);
1163 const ReleaseAccelerator shift_alt_x(ui::VKEY_X,
1164 ui::EF_SHIFT_DOWN | ui::EF_ALT_DOWN);
1165
1166 EXPECT_FALSE(ProcessInController(shift_alt_press));
1167 EXPECT_FALSE(ProcessInController(shift_alt_x_press));
1168 EXPECT_FALSE(ProcessInController(shift_alt_x));
1169 EXPECT_TRUE(ProcessInController(shift_alt));
1170 EXPECT_EQ(3, delegate->handle_next_ime_count());
1171 }
1172 #endif
1173 } 1141 }
1174 1142
1175 // TODO(nona|mazda): Remove this when crbug.com/139556 in a better way. 1143 // TODO(nona|mazda): Remove this when crbug.com/139556 in a better way.
1176 TEST_F(AcceleratorControllerTest, ImeGlobalAcceleratorsWorkaround139556) { 1144 TEST_F(AcceleratorControllerTest, ImeGlobalAcceleratorsWorkaround139556) {
1177 // The workaround for crbug.com/139556 depends on the fact that we don't 1145 // The workaround for crbug.com/139556 depends on the fact that we don't
1178 // use Shift+Alt+Enter/Space with ET_KEY_PRESSED as an accelerator. Test it. 1146 // use Shift+Alt+Enter/Space with ET_KEY_PRESSED as an accelerator. Test it.
1179 const ui::Accelerator shift_alt_return_press( 1147 const ui::Accelerator shift_alt_return_press(
1180 ui::VKEY_RETURN, 1148 ui::VKEY_RETURN,
1181 ui::EF_SHIFT_DOWN | ui::EF_ALT_DOWN); 1149 ui::EF_SHIFT_DOWN | ui::EF_ALT_DOWN);
1182 EXPECT_FALSE(ProcessInController(shift_alt_return_press)); 1150 EXPECT_FALSE(ProcessInController(shift_alt_return_press));
1183 const ui::Accelerator shift_alt_space_press( 1151 const ui::Accelerator shift_alt_space_press(
1184 ui::VKEY_SPACE, 1152 ui::VKEY_SPACE,
1185 ui::EF_SHIFT_DOWN | ui::EF_ALT_DOWN); 1153 ui::EF_SHIFT_DOWN | ui::EF_ALT_DOWN);
1186 EXPECT_FALSE(ProcessInController(shift_alt_space_press)); 1154 EXPECT_FALSE(ProcessInController(shift_alt_space_press));
1187 } 1155 }
1188 1156
1157 // The Old NEXT_IME accelerators have been disabled on ChromeOS.
1158 #if !defined(OS_CHROMEOS)
1189 // Makes sure that the next IME accelerators doesn't conflict with other 1159 // Makes sure that the next IME accelerators doesn't conflict with other
1190 // accelerators that contain Alt+Shift when the wrong sequence is pressed. 1160 // accelerators that contain Alt+Shift when the wrong sequence is pressed.
1191 // crbug.com/527154. 1161 // crbug.com/527154.
1192 TEST_F(AcceleratorControllerTest, ImeGlobalAcceleratorsNoConflict) { 1162 TEST_F(AcceleratorControllerTest, ImeGlobalAcceleratorsNoConflict) {
1193 DummyImeControlDelegate* delegate = new DummyImeControlDelegate; 1163 DummyImeControlDelegate* delegate = new DummyImeControlDelegate;
1194 GetController()->SetImeControlDelegate( 1164 GetController()->SetImeControlDelegate(
1195 std::unique_ptr<ImeControlDelegate>(delegate)); 1165 std::unique_ptr<ImeControlDelegate>(delegate));
1196 ui::test::EventGenerator& generator = GetEventGenerator(); 1166 ui::test::EventGenerator& generator = GetEventGenerator();
1197 1167
1198 // Correct sequence of a conflicting accelerator must not trigger next IME. 1168 // Correct sequence of a conflicting accelerator must not trigger next IME.
(...skipping 39 matching lines...) Expand 10 before | Expand all | Expand 10 after
1238 generator.ReleaseKey(ui::VKEY_SHIFT, ui::EF_NONE); 1208 generator.ReleaseKey(ui::VKEY_SHIFT, ui::EF_NONE);
1239 EXPECT_EQ(1, delegate->handle_next_ime_count()); 1209 EXPECT_EQ(1, delegate->handle_next_ime_count());
1240 1210
1241 // 2- Shift (press) + Alt (press) + Alt (release) + Shift (release). 1211 // 2- Shift (press) + Alt (press) + Alt (release) + Shift (release).
1242 generator.PressKey(ui::VKEY_SHIFT, ui::EF_SHIFT_DOWN); 1212 generator.PressKey(ui::VKEY_SHIFT, ui::EF_SHIFT_DOWN);
1243 generator.PressKey(ui::VKEY_MENU, ui::EF_SHIFT_DOWN | ui::EF_ALT_DOWN); 1213 generator.PressKey(ui::VKEY_MENU, ui::EF_SHIFT_DOWN | ui::EF_ALT_DOWN);
1244 generator.ReleaseKey(ui::VKEY_SHIFT, ui::EF_ALT_DOWN); 1214 generator.ReleaseKey(ui::VKEY_SHIFT, ui::EF_ALT_DOWN);
1245 generator.ReleaseKey(ui::VKEY_MENU, ui::EF_NONE); 1215 generator.ReleaseKey(ui::VKEY_MENU, ui::EF_NONE);
1246 EXPECT_EQ(2, delegate->handle_next_ime_count()); 1216 EXPECT_EQ(2, delegate->handle_next_ime_count());
1247 } 1217 }
1218 #endif // defined(OS_CHROMEOS)
1248 1219
1249 TEST_F(AcceleratorControllerTest, PreferredReservedAccelerators) { 1220 TEST_F(AcceleratorControllerTest, PreferredReservedAccelerators) {
1250 #if defined(OS_CHROMEOS) 1221 #if defined(OS_CHROMEOS)
1251 // Power key is reserved on chromeos. 1222 // Power key is reserved on chromeos.
1252 EXPECT_TRUE(GetController()->IsReserved( 1223 EXPECT_TRUE(GetController()->IsReserved(
1253 ui::Accelerator(ui::VKEY_POWER, ui::EF_NONE))); 1224 ui::Accelerator(ui::VKEY_POWER, ui::EF_NONE)));
1254 EXPECT_FALSE(GetController()->IsPreferred( 1225 EXPECT_FALSE(GetController()->IsPreferred(
1255 ui::Accelerator(ui::VKEY_POWER, ui::EF_NONE))); 1226 ui::Accelerator(ui::VKEY_POWER, ui::EF_NONE)));
1256 #endif 1227 #endif
1257 // ALT+Tab are not reserved but preferred. 1228 // ALT+Tab are not reserved but preferred.
(...skipping 321 matching lines...) Expand 10 before | Expand all | Expand 10 after
1579 EXPECT_TRUE(IsMessageCenterEmpty()); 1550 EXPECT_TRUE(IsMessageCenterEmpty());
1580 1551
1581 // If the action is LOCK_SCREEN, we must reset the state by unlocking the 1552 // If the action is LOCK_SCREEN, we must reset the state by unlocking the
1582 // screen before we proceed testing the rest of accelerators. 1553 // screen before we proceed testing the rest of accelerators.
1583 ResetStateIfNeeded(); 1554 ResetStateIfNeeded();
1584 } 1555 }
1585 } 1556 }
1586 #endif // defined(OS_CHROMEOS) 1557 #endif // defined(OS_CHROMEOS)
1587 1558
1588 } // namespace ash 1559 } // namespace ash
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698