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

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: Removing the old accelerators entirely. 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
« no previous file with comments | « ash/accelerators/accelerator_controller.cc ('k') | ash/accelerators/accelerator_table.cc » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
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 1017 matching lines...) Expand 10 before | Expand all | Expand 10 after
1028 ui::EF_NONE))); 1028 ui::EF_NONE)));
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 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); 1039 control_space_down.set_type(ui::ET_KEY_PRESSED);
1040 control_space_down.set_type(ui::ET_KEY_PRESSED); 1040 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); 1041 control_space_up.set_type(ui::ET_KEY_RELEASED);
1042 control_space_up.set_type(ui::ET_KEY_RELEASED); 1042 const ui::Accelerator convert(ui::VKEY_CONVERT, ui::EF_NONE);
1043 const ui::Accelerator convert(ui::VKEY_CONVERT, ui::EF_NONE); 1043 const ui::Accelerator non_convert(ui::VKEY_NONCONVERT, ui::EF_NONE);
1044 const ui::Accelerator non_convert(ui::VKEY_NONCONVERT, ui::EF_NONE); 1044 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); 1045 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); 1046 const ui::Accelerator hangul(ui::VKEY_HANGUL, ui::EF_NONE);
1047 const ui::Accelerator hangul(ui::VKEY_HANGUL, ui::EF_NONE); 1047 EXPECT_FALSE(ProcessInController(control_space_down));
1048 EXPECT_FALSE(ProcessInController(control_space_down)); 1048 EXPECT_FALSE(ProcessInController(control_space_up));
1049 EXPECT_FALSE(ProcessInController(control_space_up)); 1049 EXPECT_FALSE(ProcessInController(convert));
1050 EXPECT_FALSE(ProcessInController(convert)); 1050 EXPECT_FALSE(ProcessInController(non_convert));
1051 EXPECT_FALSE(ProcessInController(non_convert)); 1051 EXPECT_FALSE(ProcessInController(wide_half_1));
1052 EXPECT_FALSE(ProcessInController(wide_half_1)); 1052 EXPECT_FALSE(ProcessInController(wide_half_2));
1053 EXPECT_FALSE(ProcessInController(wide_half_2)); 1053 EXPECT_FALSE(ProcessInController(hangul));
1054 EXPECT_FALSE(ProcessInController(hangul)); 1054 DummyImeControlDelegate* delegate = new DummyImeControlDelegate;
1055 DummyImeControlDelegate* delegate = new DummyImeControlDelegate; 1055 GetController()->SetImeControlDelegate(
1056 GetController()->SetImeControlDelegate( 1056 std::unique_ptr<ImeControlDelegate>(delegate));
1057 std::unique_ptr<ImeControlDelegate>(delegate)); 1057 EXPECT_EQ(0, delegate->handle_previous_ime_count());
1058 EXPECT_EQ(0, delegate->handle_previous_ime_count()); 1058 EXPECT_TRUE(ProcessInController(control_space_down));
1059 EXPECT_TRUE(ProcessInController(control_space_down)); 1059 EXPECT_EQ(1, delegate->handle_previous_ime_count());
1060 EXPECT_EQ(1, delegate->handle_previous_ime_count()); 1060 EXPECT_TRUE(ProcessInController(control_space_up));
1061 EXPECT_TRUE(ProcessInController(control_space_up)); 1061 EXPECT_EQ(1, delegate->handle_previous_ime_count());
1062 EXPECT_EQ(1, delegate->handle_previous_ime_count()); 1062 EXPECT_EQ(0, delegate->handle_switch_ime_count());
1063 EXPECT_EQ(0, delegate->handle_switch_ime_count()); 1063 EXPECT_TRUE(ProcessInController(convert));
1064 EXPECT_TRUE(ProcessInController(convert)); 1064 EXPECT_EQ(1, delegate->handle_switch_ime_count());
1065 EXPECT_EQ(1, delegate->handle_switch_ime_count()); 1065 EXPECT_TRUE(ProcessInController(non_convert));
1066 EXPECT_TRUE(ProcessInController(non_convert)); 1066 EXPECT_EQ(2, delegate->handle_switch_ime_count());
1067 EXPECT_EQ(2, delegate->handle_switch_ime_count()); 1067 EXPECT_TRUE(ProcessInController(wide_half_1));
1068 EXPECT_TRUE(ProcessInController(wide_half_1)); 1068 EXPECT_EQ(3, delegate->handle_switch_ime_count());
1069 EXPECT_EQ(3, delegate->handle_switch_ime_count()); 1069 EXPECT_TRUE(ProcessInController(wide_half_2));
1070 EXPECT_TRUE(ProcessInController(wide_half_2)); 1070 EXPECT_EQ(4, delegate->handle_switch_ime_count());
1071 EXPECT_EQ(4, delegate->handle_switch_ime_count()); 1071 EXPECT_TRUE(ProcessInController(hangul));
1072 EXPECT_TRUE(ProcessInController(hangul)); 1072 EXPECT_EQ(5, delegate->handle_switch_ime_count());
1073 EXPECT_EQ(5, delegate->handle_switch_ime_count());
1074 }
1075
1076 // Test IME shortcuts that are triggered on key release.
1077 {
1078 const ui::Accelerator shift_alt_press(ui::VKEY_MENU,
1079 ui::EF_SHIFT_DOWN | ui::EF_ALT_DOWN);
1080 const ReleaseAccelerator shift_alt(ui::VKEY_MENU, ui::EF_SHIFT_DOWN);
1081 const ui::Accelerator alt_shift_press(ui::VKEY_SHIFT,
1082 ui::EF_SHIFT_DOWN | ui::EF_ALT_DOWN);
1083 const ReleaseAccelerator alt_shift(ui::VKEY_SHIFT, ui::EF_ALT_DOWN);
1084
1085 DummyImeControlDelegate* delegate = new DummyImeControlDelegate;
1086 GetController()->SetImeControlDelegate(
1087 std::unique_ptr<ImeControlDelegate>(delegate));
1088 EXPECT_EQ(0, delegate->handle_next_ime_count());
1089 EXPECT_FALSE(ProcessInController(shift_alt_press));
1090 EXPECT_TRUE(ProcessInController(shift_alt));
1091 EXPECT_EQ(1, delegate->handle_next_ime_count());
1092 EXPECT_FALSE(ProcessInController(alt_shift_press));
1093 EXPECT_TRUE(ProcessInController(alt_shift));
1094 EXPECT_EQ(2, delegate->handle_next_ime_count());
1095
1096 // We should NOT switch IME when e.g. Shift+Alt+X is pressed and X is
1097 // released.
1098 const ui::Accelerator shift_alt_x_press(
1099 ui::VKEY_X,
1100 ui::EF_SHIFT_DOWN | ui::EF_ALT_DOWN);
1101 const ReleaseAccelerator shift_alt_x(ui::VKEY_X,
1102 ui::EF_SHIFT_DOWN | ui::EF_ALT_DOWN);
1103
1104 EXPECT_FALSE(ProcessInController(shift_alt_press));
1105 EXPECT_FALSE(ProcessInController(shift_alt_x_press));
1106 EXPECT_FALSE(ProcessInController(shift_alt_x));
1107 EXPECT_TRUE(ProcessInController(shift_alt));
1108 EXPECT_EQ(3, delegate->handle_next_ime_count());
1109
1110 // But we _should_ if X is either VKEY_RETURN or VKEY_SPACE.
1111 // TODO(nona|mazda): Remove this when crbug.com/139556 in a better way.
1112 const ui::Accelerator shift_alt_return_press(
1113 ui::VKEY_RETURN,
1114 ui::EF_SHIFT_DOWN | ui::EF_ALT_DOWN);
1115 const ReleaseAccelerator shift_alt_return(
1116 ui::VKEY_RETURN,
1117 ui::EF_SHIFT_DOWN | ui::EF_ALT_DOWN);
1118
1119 EXPECT_FALSE(ProcessInController(shift_alt_press));
1120 EXPECT_FALSE(ProcessInController(shift_alt_return_press));
1121 EXPECT_FALSE(ProcessInController(shift_alt_return));
1122 EXPECT_TRUE(ProcessInController(shift_alt));
1123 EXPECT_EQ(4, delegate->handle_next_ime_count());
1124
1125 const ui::Accelerator shift_alt_space_press(
1126 ui::VKEY_SPACE,
1127 ui::EF_SHIFT_DOWN | ui::EF_ALT_DOWN);
1128 const ReleaseAccelerator shift_alt_space(
1129 ui::VKEY_SPACE,
1130 ui::EF_SHIFT_DOWN | ui::EF_ALT_DOWN);
1131
1132 EXPECT_FALSE(ProcessInController(shift_alt_press));
1133 EXPECT_FALSE(ProcessInController(shift_alt_space_press));
1134 EXPECT_FALSE(ProcessInController(shift_alt_space));
1135 EXPECT_TRUE(ProcessInController(shift_alt));
1136 EXPECT_EQ(5, delegate->handle_next_ime_count());
1137 }
1138
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 } 1073 }
1174 1074
1175 // TODO(nona|mazda): Remove this when crbug.com/139556 in a better way. 1075 // TODO(nona|mazda): Remove this when crbug.com/139556 in a better way.
1176 TEST_F(AcceleratorControllerTest, ImeGlobalAcceleratorsWorkaround139556) { 1076 TEST_F(AcceleratorControllerTest, ImeGlobalAcceleratorsWorkaround139556) {
1177 // The workaround for crbug.com/139556 depends on the fact that we don't 1077 // 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. 1078 // use Shift+Alt+Enter/Space with ET_KEY_PRESSED as an accelerator. Test it.
1179 const ui::Accelerator shift_alt_return_press( 1079 const ui::Accelerator shift_alt_return_press(
1180 ui::VKEY_RETURN, 1080 ui::VKEY_RETURN,
1181 ui::EF_SHIFT_DOWN | ui::EF_ALT_DOWN); 1081 ui::EF_SHIFT_DOWN | ui::EF_ALT_DOWN);
1182 EXPECT_FALSE(ProcessInController(shift_alt_return_press)); 1082 EXPECT_FALSE(ProcessInController(shift_alt_return_press));
1183 const ui::Accelerator shift_alt_space_press( 1083 const ui::Accelerator shift_alt_space_press(
1184 ui::VKEY_SPACE, 1084 ui::VKEY_SPACE,
1185 ui::EF_SHIFT_DOWN | ui::EF_ALT_DOWN); 1085 ui::EF_SHIFT_DOWN | ui::EF_ALT_DOWN);
1186 EXPECT_FALSE(ProcessInController(shift_alt_space_press)); 1086 EXPECT_FALSE(ProcessInController(shift_alt_space_press));
1187 } 1087 }
1188 1088
1189 // Makes sure that the next IME accelerators doesn't conflict with other
1190 // accelerators that contain Alt+Shift when the wrong sequence is pressed.
1191 // crbug.com/527154.
1192 TEST_F(AcceleratorControllerTest, ImeGlobalAcceleratorsNoConflict) {
1193 DummyImeControlDelegate* delegate = new DummyImeControlDelegate;
1194 GetController()->SetImeControlDelegate(
1195 std::unique_ptr<ImeControlDelegate>(delegate));
1196 ui::test::EventGenerator& generator = GetEventGenerator();
1197
1198 // Correct sequence of a conflicting accelerator must not trigger next IME.
1199 // Alt (press) + Shift (press) + S (press) + S (release) + Shift (release) +
1200 // Alt (release).
1201 generator.PressKey(ui::VKEY_MENU, ui::EF_ALT_DOWN);
1202 generator.PressKey(ui::VKEY_SHIFT, ui::EF_SHIFT_DOWN | ui::EF_ALT_DOWN);
1203 generator.PressKey(ui::VKEY_S, ui::EF_SHIFT_DOWN | ui::EF_ALT_DOWN);
1204 generator.ReleaseKey(ui::VKEY_S, ui::EF_SHIFT_DOWN | ui::EF_ALT_DOWN);
1205 generator.ReleaseKey(ui::VKEY_SHIFT, ui::EF_ALT_DOWN);
1206 generator.ReleaseKey(ui::VKEY_MENU, ui::EF_NONE);
1207 EXPECT_EQ(0, delegate->handle_next_ime_count());
1208
1209 // Neither wrong sequences.
1210 // Wrong sequence 1:
1211 // Alt (press) + Shift (press) + S (press) + Shift (release) + S (release) +
1212 // Alt (release).
1213 generator.PressKey(ui::VKEY_MENU, ui::EF_ALT_DOWN);
1214 generator.PressKey(ui::VKEY_SHIFT, ui::EF_SHIFT_DOWN | ui::EF_ALT_DOWN);
1215 generator.PressKey(ui::VKEY_S, ui::EF_SHIFT_DOWN | ui::EF_ALT_DOWN);
1216 generator.ReleaseKey(ui::VKEY_SHIFT, ui::EF_ALT_DOWN);
1217 generator.ReleaseKey(ui::VKEY_S, ui::EF_ALT_DOWN);
1218 generator.ReleaseKey(ui::VKEY_MENU, ui::EF_NONE);
1219 EXPECT_EQ(0, delegate->handle_next_ime_count());
1220
1221 // Wrong sequence 2:
1222 // Alt (press) + Shift (press) + S (press) + Alt (release) + S (release) +
1223 // Shift (release).
1224 generator.PressKey(ui::VKEY_MENU, ui::EF_ALT_DOWN);
1225 generator.PressKey(ui::VKEY_SHIFT, ui::EF_SHIFT_DOWN | ui::EF_ALT_DOWN);
1226 generator.PressKey(ui::VKEY_S, ui::EF_SHIFT_DOWN | ui::EF_ALT_DOWN);
1227 generator.ReleaseKey(ui::VKEY_MENU, ui::EF_SHIFT_DOWN);
1228 generator.ReleaseKey(ui::VKEY_S, ui::EF_SHIFT_DOWN);
1229 generator.ReleaseKey(ui::VKEY_SHIFT, ui::EF_NONE);
1230 EXPECT_EQ(0, delegate->handle_next_ime_count());
1231
1232 // The two possible sequences of Alt+Shift both work for triggering the next
1233 // IME.
1234 // 1- Alt (press) + Shift (press) + Shift (release) + Alt (release).
1235 generator.PressKey(ui::VKEY_MENU, ui::EF_ALT_DOWN);
1236 generator.PressKey(ui::VKEY_SHIFT, ui::EF_SHIFT_DOWN | ui::EF_ALT_DOWN);
1237 generator.ReleaseKey(ui::VKEY_MENU, ui::EF_SHIFT_DOWN);
1238 generator.ReleaseKey(ui::VKEY_SHIFT, ui::EF_NONE);
1239 EXPECT_EQ(1, delegate->handle_next_ime_count());
1240
1241 // 2- Shift (press) + Alt (press) + Alt (release) + Shift (release).
1242 generator.PressKey(ui::VKEY_SHIFT, ui::EF_SHIFT_DOWN);
1243 generator.PressKey(ui::VKEY_MENU, ui::EF_SHIFT_DOWN | ui::EF_ALT_DOWN);
1244 generator.ReleaseKey(ui::VKEY_SHIFT, ui::EF_ALT_DOWN);
1245 generator.ReleaseKey(ui::VKEY_MENU, ui::EF_NONE);
1246 EXPECT_EQ(2, delegate->handle_next_ime_count());
1247 }
1248
1249 TEST_F(AcceleratorControllerTest, PreferredReservedAccelerators) { 1089 TEST_F(AcceleratorControllerTest, PreferredReservedAccelerators) {
1250 #if defined(OS_CHROMEOS) 1090 #if defined(OS_CHROMEOS)
1251 // Power key is reserved on chromeos. 1091 // Power key is reserved on chromeos.
1252 EXPECT_TRUE(GetController()->IsReserved( 1092 EXPECT_TRUE(GetController()->IsReserved(
1253 ui::Accelerator(ui::VKEY_POWER, ui::EF_NONE))); 1093 ui::Accelerator(ui::VKEY_POWER, ui::EF_NONE)));
1254 EXPECT_FALSE(GetController()->IsPreferred( 1094 EXPECT_FALSE(GetController()->IsPreferred(
1255 ui::Accelerator(ui::VKEY_POWER, ui::EF_NONE))); 1095 ui::Accelerator(ui::VKEY_POWER, ui::EF_NONE)));
1256 #endif 1096 #endif
1257 // ALT+Tab are not reserved but preferred. 1097 // ALT+Tab are not reserved but preferred.
1258 EXPECT_FALSE(GetController()->IsReserved( 1098 EXPECT_FALSE(GetController()->IsReserved(
(...skipping 320 matching lines...) Expand 10 before | Expand all | Expand 10 after
1579 EXPECT_TRUE(IsMessageCenterEmpty()); 1419 EXPECT_TRUE(IsMessageCenterEmpty());
1580 1420
1581 // If the action is LOCK_SCREEN, we must reset the state by unlocking the 1421 // If the action is LOCK_SCREEN, we must reset the state by unlocking the
1582 // screen before we proceed testing the rest of accelerators. 1422 // screen before we proceed testing the rest of accelerators.
1583 ResetStateIfNeeded(); 1423 ResetStateIfNeeded();
1584 } 1424 }
1585 } 1425 }
1586 #endif // defined(OS_CHROMEOS) 1426 #endif // defined(OS_CHROMEOS)
1587 1427
1588 } // namespace ash 1428 } // namespace ash
OLDNEW
« no previous file with comments | « ash/accelerators/accelerator_controller.cc ('k') | ash/accelerators/accelerator_table.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698