| OLD | NEW |
| 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 Loading... |
| 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 Loading... |
| 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 Loading... |
| 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 Loading... |
| 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 Loading... |
| 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 |
| OLD | NEW |