| OLD | NEW |
| 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 "ui/base/ime/input_method_chromeos.h" | 5 #include "ui/base/ime/input_method_chromeos.h" |
| 6 | 6 |
| 7 #include <X11/Xlib.h> | 7 #include <X11/Xlib.h> |
| 8 #undef Bool | 8 #undef Bool |
| 9 #undef FocusIn | 9 #undef FocusIn |
| 10 #undef FocusOut | 10 #undef FocusOut |
| (...skipping 185 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 196 const uint32 expected_anchor_position_; | 196 const uint32 expected_anchor_position_; |
| 197 | 197 |
| 198 DISALLOW_COPY_AND_ASSIGN(SetSurroundingTextVerifier); | 198 DISALLOW_COPY_AND_ASSIGN(SetSurroundingTextVerifier); |
| 199 }; | 199 }; |
| 200 | 200 |
| 201 class InputMethodChromeOSTest : public internal::InputMethodDelegate, | 201 class InputMethodChromeOSTest : public internal::InputMethodDelegate, |
| 202 public testing::Test, | 202 public testing::Test, |
| 203 public TextInputClient { | 203 public TextInputClient { |
| 204 public: | 204 public: |
| 205 InputMethodChromeOSTest() | 205 InputMethodChromeOSTest() |
| 206 : dispatched_key_event_(ui::ET_UNKNOWN, ui::VKEY_UNKNOWN, 0, false) { | 206 : dispatched_key_event_(ui::ET_UNKNOWN, ui::VKEY_UNKNOWN, ui::EF_NONE) { |
| 207 ResetFlags(); | 207 ResetFlags(); |
| 208 } | 208 } |
| 209 | 209 |
| 210 virtual ~InputMethodChromeOSTest() { | 210 virtual ~InputMethodChromeOSTest() { |
| 211 } | 211 } |
| 212 | 212 |
| 213 virtual void SetUp() OVERRIDE { | 213 virtual void SetUp() OVERRIDE { |
| 214 chromeos::IMEBridge::Initialize(); | 214 chromeos::IMEBridge::Initialize(); |
| 215 | 215 |
| 216 mock_ime_engine_handler_.reset( | 216 mock_ime_engine_handler_.reset( |
| (...skipping 111 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 328 virtual bool IsEditingCommandEnabled(int command_id) OVERRIDE { | 328 virtual bool IsEditingCommandEnabled(int command_id) OVERRIDE { |
| 329 return false; | 329 return false; |
| 330 } | 330 } |
| 331 virtual void ExecuteEditingCommand(int command_id) OVERRIDE {} | 331 virtual void ExecuteEditingCommand(int command_id) OVERRIDE {} |
| 332 | 332 |
| 333 bool HasNativeEvent() const { | 333 bool HasNativeEvent() const { |
| 334 return dispatched_key_event_.HasNativeEvent(); | 334 return dispatched_key_event_.HasNativeEvent(); |
| 335 } | 335 } |
| 336 | 336 |
| 337 void ResetFlags() { | 337 void ResetFlags() { |
| 338 dispatched_key_event_ = ui::KeyEvent(ui::ET_UNKNOWN, ui::VKEY_UNKNOWN, 0, | 338 dispatched_key_event_ = ui::KeyEvent(ui::ET_UNKNOWN, ui::VKEY_UNKNOWN, |
| 339 false); | 339 ui::EF_NONE); |
| 340 | 340 |
| 341 composition_text_.Clear(); | 341 composition_text_.Clear(); |
| 342 confirmed_text_.Clear(); | 342 confirmed_text_.Clear(); |
| 343 inserted_text_.clear(); | 343 inserted_text_.clear(); |
| 344 inserted_char_ = 0; | 344 inserted_char_ = 0; |
| 345 inserted_char_flags_ = 0; | 345 inserted_char_flags_ = 0; |
| 346 on_input_method_changed_call_count_ = 0; | 346 on_input_method_changed_call_count_ = 0; |
| 347 | 347 |
| 348 input_type_ = TEXT_INPUT_TYPE_NONE; | 348 input_type_ = TEXT_INPUT_TYPE_NONE; |
| 349 input_mode_ = TEXT_INPUT_MODE_DEFAULT; | 349 input_mode_ = TEXT_INPUT_MODE_DEFAULT; |
| (...skipping 600 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 950 ime_->Init(true); | 950 ime_->Init(true); |
| 951 } | 951 } |
| 952 | 952 |
| 953 DISALLOW_COPY_AND_ASSIGN(InputMethodChromeOSKeyEventTest); | 953 DISALLOW_COPY_AND_ASSIGN(InputMethodChromeOSKeyEventTest); |
| 954 }; | 954 }; |
| 955 | 955 |
| 956 TEST_F(InputMethodChromeOSKeyEventTest, KeyEventDelayResponseTest) { | 956 TEST_F(InputMethodChromeOSKeyEventTest, KeyEventDelayResponseTest) { |
| 957 const int kFlags = ui::EF_SHIFT_DOWN; | 957 const int kFlags = ui::EF_SHIFT_DOWN; |
| 958 ScopedXI2Event xevent; | 958 ScopedXI2Event xevent; |
| 959 xevent.InitKeyEvent(ui::ET_KEY_PRESSED, ui::VKEY_A, kFlags); | 959 xevent.InitKeyEvent(ui::ET_KEY_PRESSED, ui::VKEY_A, kFlags); |
| 960 const ui::KeyEvent event(xevent, true); | 960 const ui::KeyEvent event(xevent); |
| 961 | 961 |
| 962 // Do key event. | 962 // Do key event. |
| 963 input_type_ = TEXT_INPUT_TYPE_TEXT; | 963 input_type_ = TEXT_INPUT_TYPE_TEXT; |
| 964 ime_->OnTextInputTypeChanged(this); | 964 ime_->OnTextInputTypeChanged(this); |
| 965 ime_->DispatchKeyEvent(event); | 965 ime_->DispatchKeyEvent(event); |
| 966 | 966 |
| 967 // Check before state. | 967 // Check before state. |
| 968 const ui::KeyEvent* key_event = | 968 const ui::KeyEvent* key_event = |
| 969 mock_ime_engine_handler_->last_processed_key_event(); | 969 mock_ime_engine_handler_->last_processed_key_event(); |
| 970 EXPECT_EQ(1, mock_ime_engine_handler_->process_key_event_call_count()); | 970 EXPECT_EQ(1, mock_ime_engine_handler_->process_key_event_call_count()); |
| (...skipping 15 matching lines...) Expand all Loading... |
| 986 } | 986 } |
| 987 | 987 |
| 988 TEST_F(InputMethodChromeOSKeyEventTest, MultiKeyEventDelayResponseTest) { | 988 TEST_F(InputMethodChromeOSKeyEventTest, MultiKeyEventDelayResponseTest) { |
| 989 // Preparation | 989 // Preparation |
| 990 input_type_ = TEXT_INPUT_TYPE_TEXT; | 990 input_type_ = TEXT_INPUT_TYPE_TEXT; |
| 991 ime_->OnTextInputTypeChanged(this); | 991 ime_->OnTextInputTypeChanged(this); |
| 992 | 992 |
| 993 const int kFlags = ui::EF_SHIFT_DOWN; | 993 const int kFlags = ui::EF_SHIFT_DOWN; |
| 994 ScopedXI2Event xevent; | 994 ScopedXI2Event xevent; |
| 995 xevent.InitKeyEvent(ui::ET_KEY_PRESSED, ui::VKEY_B, kFlags); | 995 xevent.InitKeyEvent(ui::ET_KEY_PRESSED, ui::VKEY_B, kFlags); |
| 996 const ui::KeyEvent event(xevent, true); | 996 const ui::KeyEvent event(xevent); |
| 997 | 997 |
| 998 // Do key event. | 998 // Do key event. |
| 999 ime_->DispatchKeyEvent(event); | 999 ime_->DispatchKeyEvent(event); |
| 1000 const ui::KeyEvent* key_event = | 1000 const ui::KeyEvent* key_event = |
| 1001 mock_ime_engine_handler_->last_processed_key_event(); | 1001 mock_ime_engine_handler_->last_processed_key_event(); |
| 1002 EXPECT_EQ(ui::VKEY_B, key_event->key_code()); | 1002 EXPECT_EQ(ui::VKEY_B, key_event->key_code()); |
| 1003 EXPECT_EQ("KeyB", key_event->code()); | 1003 EXPECT_EQ("KeyB", key_event->code()); |
| 1004 EXPECT_EQ(kFlags, key_event->flags()); | 1004 EXPECT_EQ(kFlags, key_event->flags()); |
| 1005 | 1005 |
| 1006 KeyEventCallback first_callback = | 1006 KeyEventCallback first_callback = |
| 1007 mock_ime_engine_handler_->last_passed_callback(); | 1007 mock_ime_engine_handler_->last_passed_callback(); |
| 1008 | 1008 |
| 1009 // Do key event again. | 1009 // Do key event again. |
| 1010 ScopedXI2Event xevent2; | 1010 ScopedXI2Event xevent2; |
| 1011 xevent2.InitKeyEvent(ui::ET_KEY_PRESSED, ui::VKEY_C, kFlags); | 1011 xevent2.InitKeyEvent(ui::ET_KEY_PRESSED, ui::VKEY_C, kFlags); |
| 1012 const ui::KeyEvent event2(xevent2, true); | 1012 const ui::KeyEvent event2(xevent2); |
| 1013 | 1013 |
| 1014 ime_->DispatchKeyEvent(event2); | 1014 ime_->DispatchKeyEvent(event2); |
| 1015 const ui::KeyEvent* key_event2 = | 1015 const ui::KeyEvent* key_event2 = |
| 1016 mock_ime_engine_handler_->last_processed_key_event(); | 1016 mock_ime_engine_handler_->last_processed_key_event(); |
| 1017 EXPECT_EQ(ui::VKEY_C, key_event2->key_code()); | 1017 EXPECT_EQ(ui::VKEY_C, key_event2->key_code()); |
| 1018 EXPECT_EQ("KeyC", key_event2->code()); | 1018 EXPECT_EQ("KeyC", key_event2->code()); |
| 1019 EXPECT_EQ(kFlags, key_event2->flags()); | 1019 EXPECT_EQ(kFlags, key_event2->flags()); |
| 1020 | 1020 |
| 1021 // Check before state. | 1021 // Check before state. |
| 1022 EXPECT_EQ(2, | 1022 EXPECT_EQ(2, |
| (...skipping 18 matching lines...) Expand all Loading... |
| 1041 EXPECT_EQ(2, ime_->process_key_event_post_ime_call_count()); | 1041 EXPECT_EQ(2, ime_->process_key_event_post_ime_call_count()); |
| 1042 stored_event = ime_->process_key_event_post_ime_args().event; | 1042 stored_event = ime_->process_key_event_post_ime_args().event; |
| 1043 EXPECT_TRUE(stored_event->HasNativeEvent()); | 1043 EXPECT_TRUE(stored_event->HasNativeEvent()); |
| 1044 EXPECT_TRUE(IsEqualXKeyEvent(*xevent2, *(stored_event->native_event()))); | 1044 EXPECT_TRUE(IsEqualXKeyEvent(*xevent2, *(stored_event->native_event()))); |
| 1045 EXPECT_FALSE(ime_->process_key_event_post_ime_args().handled); | 1045 EXPECT_FALSE(ime_->process_key_event_post_ime_args().handled); |
| 1046 } | 1046 } |
| 1047 | 1047 |
| 1048 TEST_F(InputMethodChromeOSKeyEventTest, KeyEventDelayResponseResetTest) { | 1048 TEST_F(InputMethodChromeOSKeyEventTest, KeyEventDelayResponseResetTest) { |
| 1049 ScopedXI2Event xevent; | 1049 ScopedXI2Event xevent; |
| 1050 xevent.InitKeyEvent(ui::ET_KEY_PRESSED, ui::VKEY_A, ui::EF_SHIFT_DOWN); | 1050 xevent.InitKeyEvent(ui::ET_KEY_PRESSED, ui::VKEY_A, ui::EF_SHIFT_DOWN); |
| 1051 const ui::KeyEvent event(xevent, true); | 1051 const ui::KeyEvent event(xevent); |
| 1052 | 1052 |
| 1053 // Do key event. | 1053 // Do key event. |
| 1054 input_type_ = TEXT_INPUT_TYPE_TEXT; | 1054 input_type_ = TEXT_INPUT_TYPE_TEXT; |
| 1055 ime_->OnTextInputTypeChanged(this); | 1055 ime_->OnTextInputTypeChanged(this); |
| 1056 ime_->DispatchKeyEvent(event); | 1056 ime_->DispatchKeyEvent(event); |
| 1057 | 1057 |
| 1058 // Check before state. | 1058 // Check before state. |
| 1059 EXPECT_EQ(1, mock_ime_engine_handler_->process_key_event_call_count()); | 1059 EXPECT_EQ(1, mock_ime_engine_handler_->process_key_event_call_count()); |
| 1060 EXPECT_EQ(0, ime_->process_key_event_post_ime_call_count()); | 1060 EXPECT_EQ(0, ime_->process_key_event_post_ime_call_count()); |
| 1061 | 1061 |
| 1062 ime_->ResetContext(); | 1062 ime_->ResetContext(); |
| 1063 | 1063 |
| 1064 // Do callback. | 1064 // Do callback. |
| 1065 mock_ime_engine_handler_->last_passed_callback().Run(true); | 1065 mock_ime_engine_handler_->last_passed_callback().Run(true); |
| 1066 | 1066 |
| 1067 EXPECT_EQ(0, ime_->process_key_event_post_ime_call_count()); | 1067 EXPECT_EQ(0, ime_->process_key_event_post_ime_call_count()); |
| 1068 } | 1068 } |
| 1069 // TODO(nona): Introduce ProcessKeyEventPostIME tests(crbug.com/156593). | 1069 // TODO(nona): Introduce ProcessKeyEventPostIME tests(crbug.com/156593). |
| 1070 | 1070 |
| 1071 } // namespace ui | 1071 } // namespace ui |
| OLD | NEW |