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

Side by Side Diff: chrome/browser/autofill/autofill_external_delegate_unittest.cc

Issue 10443084: Add Datalist Support to New Autofill UI (Closed) Base URL: http://git.chromium.org/chromium/src.git@master
Patch Set: Created 8 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
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 <vector> 5 #include <vector>
6 6
7 #include "base/compiler_specific.h" 7 #include "base/compiler_specific.h"
8 #include "base/memory/ref_counted.h" 8 #include "base/memory/ref_counted.h"
9 #include "base/string16.h" 9 #include "base/string16.h"
10 #include "chrome/browser/autofill/autofill_manager.h" 10 #include "chrome/browser/autofill/autofill_manager.h"
(...skipping 70 matching lines...) Expand 10 before | Expand all | Expand 10 after
81 81
82 virtual void SetUp() OVERRIDE { 82 virtual void SetUp() OVERRIDE {
83 TabContentsWrapperTestHarness::SetUp(); 83 TabContentsWrapperTestHarness::SetUp();
84 autofill_manager_ = new MockAutofillManager(contents_wrapper()); 84 autofill_manager_ = new MockAutofillManager(contents_wrapper());
85 external_delegate_.reset(new MockAutofillExternalDelegate( 85 external_delegate_.reset(new MockAutofillExternalDelegate(
86 contents_wrapper(), 86 contents_wrapper(),
87 autofill_manager_)); 87 autofill_manager_));
88 } 88 }
89 89
90 protected: 90 protected:
91 // Setup the expectation for a platform specific OnQuery call and then execute
Ilya Sherman 2012/06/06 22:25:45 nit: "Setup" -> "Set up"
csharp 2012/06/07 14:57:43 Done.
92 // it with the given QueryId.
93 void SetupOnQuery(int query_id) {
Ilya Sherman 2012/06/06 22:25:45 nit: Perhaps name this "IssueOnQuery()" or just "O
csharp 2012/06/07 14:57:43 Done.
94 const FormData form;
95 FormField field;
96 field.is_focusable = true;
97 field.should_autocomplete = true;
98 const gfx::Rect bounds;
99
100 EXPECT_CALL(*external_delegate_,
101 OnQueryPlatformSpecific(query_id, form, field, bounds));
Ilya Sherman 2012/06/06 22:25:45 nit: I would move this back into the TestExternalD
csharp 2012/06/07 14:57:43 I agree that its not too relevant to other tests,
Ilya Sherman 2012/06/07 22:56:05 Ok, I'm convinced :)
102
103 // This should call OnQueryPlatform specific.
104 external_delegate_->OnQuery(query_id, form, field, bounds, false);
105 }
106
91 scoped_refptr<MockAutofillManager> autofill_manager_; 107 scoped_refptr<MockAutofillManager> autofill_manager_;
92 scoped_ptr<MockAutofillExternalDelegate> external_delegate_; 108 scoped_ptr<MockAutofillExternalDelegate> external_delegate_;
93 109
94 private: 110 private:
95 content::TestBrowserThread ui_thread_; 111 content::TestBrowserThread ui_thread_;
96 112
97 DISALLOW_COPY_AND_ASSIGN(AutofillExternalDelegateUnitTest); 113 DISALLOW_COPY_AND_ASSIGN(AutofillExternalDelegateUnitTest);
98 }; 114 };
99 115
100 // Test that our external delegate called the virtual methods at the right time. 116 // Test that our external delegate called the virtual methods at the right time.
101 TEST_F(AutofillExternalDelegateUnitTest, TestExternalDelegateVirtualCalls) { 117 TEST_F(AutofillExternalDelegateUnitTest, TestExternalDelegateVirtualCalls) {
102 const int kQueryId = 5; 118 const int kQueryId = 5;
Ilya Sherman 2012/06/06 22:25:45 nit: Why not define this outside the test, so that
csharp 2012/06/07 14:57:43 Done.
103 const FormData form; 119 SetupOnQuery(kQueryId);
104 FormField field;
105 field.is_focusable = true;
106 field.should_autocomplete = true;
107 const gfx::Rect bounds;
108
109 EXPECT_CALL(*external_delegate_,
110 OnQueryPlatformSpecific(kQueryId, form, field, bounds));
111
112 // This should call OnQueryPlatform specific.
113 external_delegate_->OnQuery(kQueryId, form, field, bounds, false);
114 120
115 EXPECT_CALL(*external_delegate_, ApplyAutofillSuggestions(_, _, _, _)); 121 EXPECT_CALL(*external_delegate_, ApplyAutofillSuggestions(_, _, _, _));
116 122
117 // This should call ApplyAutofillSuggestions. 123 // This should call ApplyAutofillSuggestions.
118 std::vector<string16> autofill_item; 124 std::vector<string16> autofill_item;
119 autofill_item.push_back(string16()); 125 autofill_item.push_back(string16());
120 std::vector<int> autofill_ids; 126 std::vector<int> autofill_ids;
121 autofill_ids.push_back(1); 127 autofill_ids.push_back(1);
122 external_delegate_->OnSuggestionsReturned(kQueryId, 128 external_delegate_->OnSuggestionsReturned(kQueryId,
123 autofill_item, 129 autofill_item,
124 autofill_item, 130 autofill_item,
125 autofill_item, 131 autofill_item,
126 autofill_ids); 132 autofill_ids);
127 133
128 134
129 EXPECT_CALL(*external_delegate_, HideAutofillPopup()); 135 EXPECT_CALL(*external_delegate_, HideAutofillPopup());
130 136
131 // Called by DidAutofillSuggestions, add expectation to remove warning. 137 // Called by DidAutofillSuggestions, add expectation to remove warning.
132 EXPECT_CALL(*autofill_manager_, OnFillAutofillFormData(_, _, _, _)); 138 EXPECT_CALL(*autofill_manager_, OnFillAutofillFormData(_, _, _, _));
133 139
134 // This should trigger a call to hide the popup since 140 // This should trigger a call to hide the popup since
135 // we've selected an option. 141 // we've selected an option.
136 external_delegate_->DidAcceptAutofillSuggestions(autofill_item[0], 142 external_delegate_->DidAcceptAutofillSuggestions(autofill_item[0],
137 autofill_ids[0], 0); 143 autofill_ids[0], 0);
138 } 144 }
139 145
146 // Test that data list elements for a node will appear in the Autofill popup.
147 TEST_F(AutofillExternalDelegateUnitTest, ExternalDelegateDataList) {
148 const int kQueryId = 5;
149 SetupOnQuery(kQueryId);
150
151 std::vector<string16> data_list_items;
152 data_list_items.push_back(string16());
153 std::vector<int> data_list_ids;
154 data_list_ids.push_back(WebAutofillClient::MenuItemIDDataListEntry);
155
156 external_delegate_->SetCurrentDataListValues(data_list_items,
157 data_list_items,
158 data_list_items,
159 data_list_ids);
160
161 EXPECT_CALL(*external_delegate_,
162 ApplyAutofillSuggestions(
163 _, _, _, testing::Contains(
164 WebAutofillClient::MenuItemIDDataListEntry)));
165
166 // This should call ApplyAutofillSuggestions.
167 std::vector<string16> autofill_item;
168 autofill_item.push_back(string16());
169 std::vector<int> autofill_ids;
170 autofill_ids.push_back(1);
171 external_delegate_->OnSuggestionsReturned(kQueryId,
172 autofill_item,
173 autofill_item,
174 autofill_item,
175 autofill_ids);
176 }
Ilya Sherman 2012/06/06 22:25:45 There are a lot more branches in the code than thi
csharp 2012/06/07 14:57:43 Updated some of the tests to ensure the placement
177
140 // Test that the Autofill delegate doesn't try and fill a form with a 178 // Test that the Autofill delegate doesn't try and fill a form with a
141 // negative unique id. 179 // negative unique id.
142 TEST_F(AutofillExternalDelegateUnitTest, ExternalDelegateInvalidUniqueId) { 180 TEST_F(AutofillExternalDelegateUnitTest, ExternalDelegateInvalidUniqueId) {
143 // Ensure it doesn't try to preview the negative id. 181 // Ensure it doesn't try to preview the negative id.
144 EXPECT_CALL(*autofill_manager_, OnFillAutofillFormData(_, _, _, _)).Times(0); 182 EXPECT_CALL(*autofill_manager_, OnFillAutofillFormData(_, _, _, _)).Times(0);
145 external_delegate_->SelectAutofillSuggestionAtIndex(-1); 183 external_delegate_->SelectAutofillSuggestionAtIndex(-1);
146 184
147 // Ensure it doesn't try to fill the form in with the negative id. 185 // Ensure it doesn't try to fill the form in with the negative id.
148 EXPECT_CALL(*autofill_manager_, OnFillAutofillFormData(_, _, _, _)).Times(0); 186 EXPECT_CALL(*autofill_manager_, OnFillAutofillFormData(_, _, _, _)).Times(0);
149 external_delegate_->DidAcceptAutofillSuggestions(string16(), -1, 0); 187 external_delegate_->DidAcceptAutofillSuggestions(string16(), -1, 0);
(...skipping 16 matching lines...) Expand all
166 external_delegate_->SelectAutofillSuggestionAtIndex(1); 204 external_delegate_->SelectAutofillSuggestionAtIndex(1);
167 } 205 }
168 206
169 // Test that the popup is hidden once we are done editing the autofill field. 207 // Test that the popup is hidden once we are done editing the autofill field.
170 TEST_F(AutofillExternalDelegateUnitTest, 208 TEST_F(AutofillExternalDelegateUnitTest,
171 ExternalDelegateHidePopupAfterEditing) { 209 ExternalDelegateHidePopupAfterEditing) {
172 EXPECT_CALL(*external_delegate_, HideAutofillPopup()); 210 EXPECT_CALL(*external_delegate_, HideAutofillPopup());
173 211
174 external_delegate_->DidEndTextFieldEditing(); 212 external_delegate_->DidEndTextFieldEditing();
175 } 213 }
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698