| OLD | NEW |
| 1 // Copyright (c) 2010 The Chromium OS Authors. All rights reserved. | 1 // Copyright (c) 2010 The Chromium OS 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 // How to run the test: | 5 // How to run the test: |
| 6 // $ FEATURES="test" emerge-x86-generic -a libcros | 6 // $ FEATURES="test" emerge-x86-generic -a libcros |
| 7 | 7 |
| 8 #include "chromeos_keyboard.h" | 8 #include "chromeos_keyboard.h" |
| 9 | 9 |
| 10 #include <algorithm> | 10 #include <algorithm> |
| (...skipping 164 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 175 for (int i = 0; i < static_cast<int>(kNumModifierKeys); ++i) { | 175 for (int i = 0; i < static_cast<int>(kNumModifierKeys); ++i) { |
| 176 for (int j = 0; j < static_cast<int>(kNumModifierKeys); ++j) { | 176 for (int j = 0; j < static_cast<int>(kNumModifierKeys); ++j) { |
| 177 for (int k = 0; k < static_cast<int>(kNumModifierKeys); ++k) { | 177 for (int k = 0; k < static_cast<int>(kNumModifierKeys); ++k) { |
| 178 const std::string layout = CreateFullXkbLayoutName( | 178 const std::string layout = CreateFullXkbLayoutName( |
| 179 "us", GetMap(ModifierKey(i), ModifierKey(j), ModifierKey(k)), true); | 179 "us", GetMap(ModifierKey(i), ModifierKey(j), ModifierKey(k)), true); |
| 180 // CreateFullXkbLayoutName should succeed (i.e. should not return "".) | 180 // CreateFullXkbLayoutName should succeed (i.e. should not return "".) |
| 181 EXPECT_STREQ("us+", layout.substr(0, 3).c_str()) | 181 EXPECT_STREQ("us+", layout.substr(0, 3).c_str()) |
| 182 << "layout: " << layout; | 182 << "layout: " << layout; |
| 183 // All 4*3*3 layouts should be different. | 183 // All 4*3*3 layouts should be different. |
| 184 EXPECT_TRUE(layouts.insert(layout).second) << "layout: " << layout; | 184 EXPECT_TRUE(layouts.insert(layout).second) << "layout: " << layout; |
| 185 // Round-trip conversion should be possible. | |
| 186 EXPECT_STREQ( | |
| 187 "us", ExtractLayoutNameFromFullXkbLayoutName(layout).c_str()) | |
| 188 << "layout: " << layout; | |
| 189 } | 185 } |
| 190 } | 186 } |
| 191 } | 187 } |
| 192 } | |
| 193 | |
| 194 // Tests ExtractLayoutNameFromFullXkbLayoutName() function. | |
| 195 TEST(ChromeOSKeyboardTest, TestExtractLayoutNameFromFullXkbLayoutName) { | |
| 196 EXPECT_STREQ("us", ExtractLayoutNameFromFullXkbLayoutName( | |
| 197 "us+chromeos(foo)").c_str()); | |
| 198 EXPECT_STREQ("us(dvorak)", ExtractLayoutNameFromFullXkbLayoutName( | |
| 199 "us(dvorak)+chromeos(foo)").c_str()); | |
| 200 EXPECT_STREQ("", ExtractLayoutNameFromFullXkbLayoutName("").c_str()); | |
| 201 // ExtractLayoutNameFromFullXkbLayoutName should not accept layout without +. | |
| 202 EXPECT_STREQ("", ExtractLayoutNameFromFullXkbLayoutName("us").c_str()); | |
| 203 } | |
| 204 | |
| 205 // Tests ExtractModifierMapFromFullXkbLayoutName() function. | |
| 206 TEST(ChromeOSKeyboardTest, TestExtractModifierMapFromFullXkbLayoutName) { | |
| 207 StringToModifierMap string_to_modifier_map; | |
| 208 InitializeStringToModifierMap(&string_to_modifier_map); | |
| 209 | |
| 210 ModifierMap modifier_map; | |
| 211 EXPECT_FALSE(ExtractModifierMapFromFullXkbLayoutName( | |
| 212 "", string_to_modifier_map, &modifier_map)); | |
| 213 EXPECT_FALSE(ExtractModifierMapFromFullXkbLayoutName( | |
| 214 "us", string_to_modifier_map, &modifier_map)); | |
| 215 EXPECT_FALSE(ExtractModifierMapFromFullXkbLayoutName( | |
| 216 "us(dvorak)", string_to_modifier_map, &modifier_map)); | |
| 217 EXPECT_FALSE(ExtractModifierMapFromFullXkbLayoutName( | |
| 218 "us(dvorak)+", string_to_modifier_map, &modifier_map)); | |
| 219 EXPECT_FALSE(ExtractModifierMapFromFullXkbLayoutName( | |
| 220 "us(dvorak)+chromeos(", string_to_modifier_map, &modifier_map)); | |
| 221 EXPECT_FALSE(ExtractModifierMapFromFullXkbLayoutName( | |
| 222 "us(dvorak)+chromeos()", string_to_modifier_map, &modifier_map)); | |
| 223 EXPECT_FALSE(ExtractModifierMapFromFullXkbLayoutName( | |
| 224 "us(dvorak)+chromeos(f", string_to_modifier_map, &modifier_map)); | |
| 225 EXPECT_FALSE(ExtractModifierMapFromFullXkbLayoutName( | |
| 226 "us(dvorak)+chromeos(foo", string_to_modifier_map, &modifier_map)); | |
| 227 EXPECT_FALSE(ExtractModifierMapFromFullXkbLayoutName( | |
| 228 "us(dvorak)+chromeos(foo)", string_to_modifier_map, &modifier_map)); | |
| 229 | |
| 230 EXPECT_TRUE(ExtractModifierMapFromFullXkbLayoutName( | |
| 231 "us(dvorak)+chromeos(disabled_disabled_disabled)", | |
| 232 string_to_modifier_map, &modifier_map)); | |
| 233 EXPECT_EQ(3, modifier_map.size()); | |
| 234 EXPECT_TRUE(CheckMap(modifier_map, kVoidKey, kVoidKey, kVoidKey)); | |
| 235 | |
| 236 EXPECT_TRUE(ExtractModifierMapFromFullXkbLayoutName( | |
| 237 "us(dvorak)+chromeos(disabled_disabled_disabled)+", | |
| 238 string_to_modifier_map, &modifier_map)); | |
| 239 EXPECT_EQ(3, modifier_map.size()); | |
| 240 EXPECT_TRUE(CheckMap(modifier_map, kVoidKey, kVoidKey, kVoidKey)); | |
| 241 | |
| 242 EXPECT_TRUE(ExtractModifierMapFromFullXkbLayoutName( | |
| 243 "us(dvorak)+chromeos(disabled_disabled_disabled)+inet(pc105)", | |
| 244 string_to_modifier_map, &modifier_map)); | |
| 245 EXPECT_EQ(3, modifier_map.size()); | |
| 246 EXPECT_TRUE(CheckMap(modifier_map, kVoidKey, kVoidKey, kVoidKey)); | |
| 247 | |
| 248 EXPECT_TRUE(ExtractModifierMapFromFullXkbLayoutName( | |
| 249 "+chromeos(disabled_disabled_disabled)", | |
| 250 string_to_modifier_map, &modifier_map)); | |
| 251 EXPECT_EQ(3, modifier_map.size()); | |
| 252 EXPECT_TRUE(CheckMap(modifier_map, kVoidKey, kVoidKey, kVoidKey)); | |
| 253 | |
| 254 EXPECT_TRUE(ExtractModifierMapFromFullXkbLayoutName( | |
| 255 "+chromeos(disabled_disabled_disabled)+inet(pc105)", | |
| 256 string_to_modifier_map, &modifier_map)); | |
| 257 EXPECT_EQ(3, modifier_map.size()); | |
| 258 EXPECT_TRUE(CheckMap(modifier_map, kVoidKey, kVoidKey, kVoidKey)); | |
| 259 | |
| 260 // Check all cases just in case. | |
| 261 for (int i = 0; i < static_cast<int>(kNumModifierKeys); ++i) { | |
| 262 for (int j = 0; j < static_cast<int>(kNumModifierKeys); ++j) { | |
| 263 for (int k = 0; k < static_cast<int>(kNumModifierKeys); ++k) { | |
| 264 const std::string layout = CreateFullXkbLayoutName( | |
| 265 "us", GetMap(ModifierKey(i), ModifierKey(j), ModifierKey(k)), true); | |
| 266 EXPECT_TRUE(ExtractModifierMapFromFullXkbLayoutName( | |
| 267 layout, string_to_modifier_map, &modifier_map)) | |
| 268 << "layout: " << layout; | |
| 269 EXPECT_EQ(3, modifier_map.size()) << "layout: " << layout; | |
| 270 EXPECT_TRUE(CheckMap( | |
| 271 modifier_map, ModifierKey(i), ModifierKey(j), ModifierKey(k))) | |
| 272 << "layout: " << layout; | |
| 273 } | |
| 274 } | |
| 275 } | |
| 276 } | 188 } |
| 277 | 189 |
| 278 TEST(ChromeOSKeyboardTest, TestSetCapsLockIsEnabled) { | 190 TEST(ChromeOSKeyboardTest, TestSetCapsLockIsEnabled) { |
| 279 if (!DisplayAvailable()) { | 191 if (!DisplayAvailable()) { |
| 280 return; | 192 return; |
| 281 } | 193 } |
| 282 const bool initial_lock_state = CapsLockIsEnabled(); | 194 const bool initial_lock_state = CapsLockIsEnabled(); |
| 283 SetCapsLockEnabled(true); | 195 SetCapsLockEnabled(true); |
| 284 EXPECT_TRUE(CapsLockIsEnabled()); | 196 EXPECT_TRUE(CapsLockIsEnabled()); |
| 285 SetCapsLockEnabled(false); | 197 SetCapsLockEnabled(false); |
| (...skipping 16 matching lines...) Expand all Loading... |
| 302 GetMap(kVoidKey, kVoidKey, kCapsLockKey), kCapsLockKey)); | 214 GetMap(kVoidKey, kVoidKey, kCapsLockKey), kCapsLockKey)); |
| 303 EXPECT_TRUE(ContainsModifierKeyAsReplacement( | 215 EXPECT_TRUE(ContainsModifierKeyAsReplacement( |
| 304 GetMap(kCapsLockKey, kCapsLockKey, kVoidKey), kCapsLockKey)); | 216 GetMap(kCapsLockKey, kCapsLockKey, kVoidKey), kCapsLockKey)); |
| 305 EXPECT_TRUE(ContainsModifierKeyAsReplacement( | 217 EXPECT_TRUE(ContainsModifierKeyAsReplacement( |
| 306 GetMap(kCapsLockKey, kCapsLockKey, kCapsLockKey), kCapsLockKey)); | 218 GetMap(kCapsLockKey, kCapsLockKey, kCapsLockKey), kCapsLockKey)); |
| 307 EXPECT_TRUE(ContainsModifierKeyAsReplacement( | 219 EXPECT_TRUE(ContainsModifierKeyAsReplacement( |
| 308 GetMap(kSearchKey, kVoidKey, kVoidKey), kSearchKey)); | 220 GetMap(kSearchKey, kVoidKey, kVoidKey), kSearchKey)); |
| 309 } | 221 } |
| 310 | 222 |
| 311 } // namespace chromeos | 223 } // namespace chromeos |
| OLD | NEW |