OLD | NEW |
1 // Copyright (c) 2011 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2011 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 "base/basictypes.h" | 5 #include "base/basictypes.h" |
6 #include "components/autofill/content/renderer/page_click_listener.h" | 6 #include "components/autofill/content/renderer/page_click_listener.h" |
7 #include "components/autofill/content/renderer/page_click_tracker.h" | 7 #include "components/autofill/content/renderer/page_click_tracker.h" |
8 #include "content/public/renderer/render_view.h" | 8 #include "content/public/renderer/render_view.h" |
9 #include "content/public/test/render_view_test.h" | 9 #include "content/public/test/render_view_test.h" |
10 #include "testing/gtest/include/gtest/gtest.h" | 10 #include "testing/gtest/include/gtest/gtest.h" |
11 #include "third_party/WebKit/public/web/WebDocument.h" | 11 #include "third_party/WebKit/public/web/WebDocument.h" |
12 #include "third_party/WebKit/public/web/WebInputElement.h" | 12 #include "third_party/WebKit/public/web/WebInputElement.h" |
13 #include "third_party/WebKit/public/web/WebView.h" | 13 #include "third_party/WebKit/public/web/WebView.h" |
14 #include "third_party/WebKit/public/platform/WebSize.h" | 14 #include "third_party/WebKit/public/platform/WebSize.h" |
15 #include "ui/events/keycodes/keyboard_codes.h" | 15 #include "ui/events/keycodes/keyboard_codes.h" |
16 | 16 |
17 namespace autofill { | 17 namespace autofill { |
18 | 18 |
19 class TestPageClickListener : public PageClickListener { | 19 class TestPageClickListener : public PageClickListener { |
20 public: | 20 public: |
21 TestPageClickListener() | 21 TestPageClickListener() |
22 : input_element_clicked_called_(false), | 22 : input_element_clicked_called_(false), |
23 input_element_lost_focus_called_(false), | 23 input_element_lost_focus_called_(false), |
24 was_focused_(false), | 24 was_focused_(false), |
25 is_focused_(false) { | 25 is_focused_(false) { |
26 } | 26 } |
27 | 27 |
28 virtual void InputElementClicked(const WebKit::WebInputElement& element, | 28 virtual void InputElementClicked(const blink::WebInputElement& element, |
29 bool was_focused, | 29 bool was_focused, |
30 bool is_focused) OVERRIDE { | 30 bool is_focused) OVERRIDE { |
31 input_element_clicked_called_ = true; | 31 input_element_clicked_called_ = true; |
32 element_clicked_ = element; | 32 element_clicked_ = element; |
33 was_focused_ = was_focused; | 33 was_focused_ = was_focused; |
34 is_focused_ = is_focused; | 34 is_focused_ = is_focused; |
35 } | 35 } |
36 | 36 |
37 virtual void InputElementLostFocus() OVERRIDE { | 37 virtual void InputElementLostFocus() OVERRIDE { |
38 input_element_lost_focus_called_ = true; | 38 input_element_lost_focus_called_ = true; |
39 } | 39 } |
40 | 40 |
41 void ClearResults() { | 41 void ClearResults() { |
42 input_element_clicked_called_ = false; | 42 input_element_clicked_called_ = false; |
43 input_element_lost_focus_called_ = false; | 43 input_element_lost_focus_called_ = false; |
44 element_clicked_.reset(); | 44 element_clicked_.reset(); |
45 was_focused_ = false; | 45 was_focused_ = false; |
46 is_focused_ = false; | 46 is_focused_ = false; |
47 } | 47 } |
48 | 48 |
49 bool input_element_clicked_called_; | 49 bool input_element_clicked_called_; |
50 bool input_element_lost_focus_called_; | 50 bool input_element_lost_focus_called_; |
51 WebKit::WebInputElement element_clicked_; | 51 blink::WebInputElement element_clicked_; |
52 bool was_focused_; | 52 bool was_focused_; |
53 bool is_focused_; | 53 bool is_focused_; |
54 }; | 54 }; |
55 | 55 |
56 class PageClickTrackerTest : public content::RenderViewTest { | 56 class PageClickTrackerTest : public content::RenderViewTest { |
57 protected: | 57 protected: |
58 virtual void SetUp() OVERRIDE { | 58 virtual void SetUp() OVERRIDE { |
59 content::RenderViewTest::SetUp(); | 59 content::RenderViewTest::SetUp(); |
60 | 60 |
61 // RenderView creates PageClickTracker but it doesn't keep it around. | 61 // RenderView creates PageClickTracker but it doesn't keep it around. |
62 // Rather than make it do so for the test, we create a new object. | 62 // Rather than make it do so for the test, we create a new object. |
63 page_click_tracker_.reset(new PageClickTracker(view_, &test_listener_)); | 63 page_click_tracker_.reset(new PageClickTracker(view_, &test_listener_)); |
64 | 64 |
65 LoadHTML("<form>" | 65 LoadHTML("<form>" |
66 " <input type='text' id='text_1'></input><br>" | 66 " <input type='text' id='text_1'></input><br>" |
67 " <input type='text' id='text_2'></input><br>" | 67 " <input type='text' id='text_2'></input><br>" |
68 " <input type='button' id='button'></input><br>" | 68 " <input type='button' id='button'></input><br>" |
69 "</form>"); | 69 "</form>"); |
70 GetWebWidget()->resize(WebKit::WebSize(500, 500)); | 70 GetWebWidget()->resize(blink::WebSize(500, 500)); |
71 GetWebWidget()->setFocus(true); | 71 GetWebWidget()->setFocus(true); |
72 WebKit::WebDocument document = view_->GetWebView()->mainFrame()->document(); | 72 blink::WebDocument document = view_->GetWebView()->mainFrame()->document(); |
73 text_ = document.getElementById("text_1"); | 73 text_ = document.getElementById("text_1"); |
74 ASSERT_FALSE(text_.isNull()); | 74 ASSERT_FALSE(text_.isNull()); |
75 } | 75 } |
76 | 76 |
77 virtual void TearDown() OVERRIDE { | 77 virtual void TearDown() OVERRIDE { |
78 text_.reset(); | 78 text_.reset(); |
79 test_listener_.ClearResults(); | 79 test_listener_.ClearResults(); |
80 page_click_tracker_.reset(); | 80 page_click_tracker_.reset(); |
81 content::RenderViewTest::TearDown(); | 81 content::RenderViewTest::TearDown(); |
82 } | 82 } |
83 | 83 |
84 // Send all the messages required for a complete key press. | 84 // Send all the messages required for a complete key press. |
85 void SendKeyPress(int key_code) { | 85 void SendKeyPress(int key_code) { |
86 WebKit::WebKeyboardEvent keyboard_event; | 86 blink::WebKeyboardEvent keyboard_event; |
87 keyboard_event.windowsKeyCode = key_code; | 87 keyboard_event.windowsKeyCode = key_code; |
88 keyboard_event.setKeyIdentifierFromWindowsKeyCode(); | 88 keyboard_event.setKeyIdentifierFromWindowsKeyCode(); |
89 | 89 |
90 keyboard_event.type = WebKit::WebInputEvent::RawKeyDown; | 90 keyboard_event.type = blink::WebInputEvent::RawKeyDown; |
91 SendWebKeyboardEvent(keyboard_event); | 91 SendWebKeyboardEvent(keyboard_event); |
92 | 92 |
93 keyboard_event.type = WebKit::WebInputEvent::Char; | 93 keyboard_event.type = blink::WebInputEvent::Char; |
94 SendWebKeyboardEvent(keyboard_event); | 94 SendWebKeyboardEvent(keyboard_event); |
95 | 95 |
96 keyboard_event.type = WebKit::WebInputEvent::KeyUp; | 96 keyboard_event.type = blink::WebInputEvent::KeyUp; |
97 SendWebKeyboardEvent(keyboard_event); | 97 SendWebKeyboardEvent(keyboard_event); |
98 } | 98 } |
99 | 99 |
100 scoped_ptr<PageClickTracker> page_click_tracker_; | 100 scoped_ptr<PageClickTracker> page_click_tracker_; |
101 TestPageClickListener test_listener_; | 101 TestPageClickListener test_listener_; |
102 WebKit::WebElement text_; | 102 blink::WebElement text_; |
103 }; | 103 }; |
104 | 104 |
105 // Tests that PageClickTracker does notify correctly when a node is clicked. | 105 // Tests that PageClickTracker does notify correctly when a node is clicked. |
106 TEST_F(PageClickTrackerTest, PageClickTrackerInputClicked) { | 106 TEST_F(PageClickTrackerTest, PageClickTrackerInputClicked) { |
107 // Click the text field once. | 107 // Click the text field once. |
108 EXPECT_TRUE(SimulateElementClick("text_1")); | 108 EXPECT_TRUE(SimulateElementClick("text_1")); |
109 EXPECT_TRUE(test_listener_.input_element_clicked_called_); | 109 EXPECT_TRUE(test_listener_.input_element_clicked_called_); |
110 EXPECT_FALSE(test_listener_.was_focused_); | 110 EXPECT_FALSE(test_listener_.was_focused_); |
111 EXPECT_TRUE(test_listener_.is_focused_); | 111 EXPECT_TRUE(test_listener_.is_focused_); |
112 EXPECT_TRUE(text_ == test_listener_.element_clicked_); | 112 EXPECT_TRUE(text_ == test_listener_.element_clicked_); |
(...skipping 42 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
155 EXPECT_TRUE(test_listener_.input_element_lost_focus_called_); | 155 EXPECT_TRUE(test_listener_.input_element_lost_focus_called_); |
156 test_listener_.ClearResults(); | 156 test_listener_.ClearResults(); |
157 | 157 |
158 // Click on a text field while the button has focus and ensure no lost focus | 158 // Click on a text field while the button has focus and ensure no lost focus |
159 // notification is sent. | 159 // notification is sent. |
160 EXPECT_TRUE(SimulateElementClick("text_1")); | 160 EXPECT_TRUE(SimulateElementClick("text_1")); |
161 EXPECT_FALSE(test_listener_.input_element_lost_focus_called_); | 161 EXPECT_FALSE(test_listener_.input_element_lost_focus_called_); |
162 } | 162 } |
163 | 163 |
164 } // namespace autofill | 164 } // namespace autofill |
OLD | NEW |