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

Side by Side Diff: chrome/browser/sync/profile_sync_service_autofill_unittest.cc

Issue 8184001: The AutofillProfileSyncableService's lifetime should be managed by the WebDataService (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Fix compile after http://crrev.com/104990 Created 9 years, 2 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 | Annotate | Revision Log
OLDNEW
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 <set> 5 #include <set>
6 #include <string> 6 #include <string>
7 #include <vector> 7 #include <vector>
8 8
9 #include "testing/gtest/include/gtest/gtest.h" 9 #include "testing/gtest/include/gtest/gtest.h"
10 10
11 #include "base/bind.h"
11 #include "base/callback.h" 12 #include "base/callback.h"
12 #include "base/location.h" 13 #include "base/location.h"
13 #include "base/memory/ref_counted.h" 14 #include "base/memory/ref_counted.h"
14 #include "base/memory/scoped_ptr.h" 15 #include "base/memory/scoped_ptr.h"
15 #include "base/message_loop.h" 16 #include "base/message_loop.h"
16 #include "base/string16.h" 17 #include "base/string16.h"
17 #include "base/synchronization/waitable_event.h" 18 #include "base/synchronization/waitable_event.h"
18 #include "base/task.h" 19 #include "base/task.h"
19 #include "base/time.h" 20 #include "base/time.h"
20 #include "base/utf_string_conversions.h" 21 #include "base/utf_string_conversions.h"
(...skipping 32 matching lines...) Expand 10 before | Expand all | Expand 10 after
53 #include "content/browser/browser_thread.h" 54 #include "content/browser/browser_thread.h"
54 #include "content/common/notification_source.h" 55 #include "content/common/notification_source.h"
55 #include "testing/gmock/include/gmock/gmock.h" 56 #include "testing/gmock/include/gmock/gmock.h"
56 57
57 using base::Time; 58 using base::Time;
58 using base::WaitableEvent; 59 using base::WaitableEvent;
59 using browser_sync::AutofillChangeProcessor; 60 using browser_sync::AutofillChangeProcessor;
60 using browser_sync::AutofillDataTypeController; 61 using browser_sync::AutofillDataTypeController;
61 using browser_sync::AutofillModelAssociator; 62 using browser_sync::AutofillModelAssociator;
62 using browser_sync::AutofillProfileDataTypeController; 63 using browser_sync::AutofillProfileDataTypeController;
63 using browser_sync::AutofillProfileSyncableService;
64 using browser_sync::DataTypeController; 64 using browser_sync::DataTypeController;
65 using browser_sync::GenericChangeProcessor; 65 using browser_sync::GenericChangeProcessor;
66 using browser_sync::SyncableServiceAdapter; 66 using browser_sync::SyncableServiceAdapter;
67 using browser_sync::GROUP_DB; 67 using browser_sync::GROUP_DB;
68 using browser_sync::kAutofillTag; 68 using browser_sync::kAutofillTag;
69 using browser_sync::SyncBackendHostForProfileSyncTest; 69 using browser_sync::SyncBackendHostForProfileSyncTest;
70 using browser_sync::UnrecoverableErrorHandler; 70 using browser_sync::UnrecoverableErrorHandler;
71 using syncable::CREATE_NEW_UPDATE_ITEM; 71 using syncable::CREATE_NEW_UPDATE_ITEM;
72 using syncable::AUTOFILL; 72 using syncable::AUTOFILL;
73 using syncable::BASE_VERSION; 73 using syncable::BASE_VERSION;
(...skipping 72 matching lines...) Expand 10 before | Expand all | Expand 10 after
146 } 146 }
147 147
148 template<> 148 template<>
149 syncable::ModelType GetModelType<AutofillProfile>() { 149 syncable::ModelType GetModelType<AutofillProfile>() {
150 return syncable::AUTOFILL_PROFILE; 150 return syncable::AUTOFILL_PROFILE;
151 } 151 }
152 152
153 class WebDataServiceFake : public WebDataService { 153 class WebDataServiceFake : public WebDataService {
154 public: 154 public:
155 explicit WebDataServiceFake(WebDatabase* web_database) 155 explicit WebDataServiceFake(WebDatabase* web_database)
156 : web_database_(web_database) {} 156 : web_database_(web_database),
157 syncable_service_created_or_destroyed_(false, false) {
158 }
159
160 void StartSyncableService() {
161 // The |autofill_profile_syncable_service_| must be constructed on the DB
162 // thread.
163 BrowserThread::PostTask(BrowserThread::DB, FROM_HERE,
164 base::Bind(&WebDataServiceFake::CreateSyncableService,
165 base::Unretained(this)));
166 syncable_service_created_or_destroyed_.Wait();
167 }
168
169 void ShutdownSyncableService() {
170 // The |autofill_profile_syncable_service_| must be destructed on the DB
171 // thread.
172 BrowserThread::PostTask(BrowserThread::DB, FROM_HERE,
173 base::Bind(&WebDataServiceFake::DestroySyncableService,
174 base::Unretained(this)));
175 syncable_service_created_or_destroyed_.Wait();
176 }
177
157 virtual bool IsDatabaseLoaded() { 178 virtual bool IsDatabaseLoaded() {
158 return true; 179 return true;
159 } 180 }
160 181
161 virtual WebDatabase* GetDatabase() { 182 virtual WebDatabase* GetDatabase() {
162 return web_database_; 183 return web_database_;
163 } 184 }
164 185
186 virtual AutofillProfileSyncableService*
187 GetAutofillProfileSyncableService() const OVERRIDE {
188 EXPECT_TRUE(BrowserThread::CurrentlyOn(BrowserThread::DB));
189 EXPECT_TRUE(autofill_profile_syncable_service_);
190
191 return autofill_profile_syncable_service_;
192 }
193
165 private: 194 private:
195 void CreateSyncableService() {
196 ASSERT_TRUE(BrowserThread::CurrentlyOn(BrowserThread::DB));
197 autofill_profile_syncable_service_ =
198 new AutofillProfileSyncableService(this);
199 syncable_service_created_or_destroyed_.Signal();
200 }
201
202 void DestroySyncableService() {
203 ASSERT_TRUE(BrowserThread::CurrentlyOn(BrowserThread::DB));
204 delete autofill_profile_syncable_service_;
205 syncable_service_created_or_destroyed_.Signal();
206 }
207
166 WebDatabase* web_database_; 208 WebDatabase* web_database_;
209
210 // We own the syncable service, but don't use a |scoped_ptr| because the
211 // lifetime must be managed on the DB thread.
212 AutofillProfileSyncableService* autofill_profile_syncable_service_;
213 WaitableEvent syncable_service_created_or_destroyed_;
167 }; 214 };
168 215
169 ACTION_P3(MakeAutofillSyncComponents, service, wd, dtc) { 216 ACTION_P3(MakeAutofillSyncComponents, service, wd, dtc) {
170 EXPECT_TRUE(BrowserThread::CurrentlyOn(BrowserThread::DB)); 217 EXPECT_TRUE(BrowserThread::CurrentlyOn(BrowserThread::DB));
171 if (!BrowserThread::CurrentlyOn(BrowserThread::DB)) 218 if (!BrowserThread::CurrentlyOn(BrowserThread::DB))
172 return ProfileSyncFactory::SyncComponents(NULL, NULL); 219 return ProfileSyncFactory::SyncComponents(NULL, NULL);
173 AutofillModelAssociator* model_associator = 220 AutofillModelAssociator* model_associator =
174 new AutofillModelAssociator(service, wd, service->profile()); 221 new AutofillModelAssociator(service, wd, service->profile());
175 AutofillChangeProcessor* change_processor = 222 AutofillChangeProcessor* change_processor =
176 new AutofillChangeProcessor(model_associator, wd, 223 new AutofillChangeProcessor(model_associator, wd,
177 service->profile(), dtc); 224 service->profile(), dtc);
178 return ProfileSyncFactory::SyncComponents(model_associator, 225 return ProfileSyncFactory::SyncComponents(model_associator,
179 change_processor); 226 change_processor);
180 } 227 }
181 228
182 ACTION_P3(MakeAutofillProfileSyncComponents, service, wds, dtc) { 229 ACTION_P3(MakeAutofillProfileSyncComponents, service, wds, dtc) {
183 EXPECT_TRUE(BrowserThread::CurrentlyOn(BrowserThread::DB)); 230 EXPECT_TRUE(BrowserThread::CurrentlyOn(BrowserThread::DB));
184 if (!BrowserThread::CurrentlyOn(BrowserThread::DB)) 231 if (!BrowserThread::CurrentlyOn(BrowserThread::DB))
185 return ProfileSyncFactory::SyncComponents(NULL, NULL); 232 return ProfileSyncFactory::SyncComponents(NULL, NULL);
186 AutofillProfileSyncableService* sync_service = 233 AutofillProfileSyncableService* sync_service =
187 new AutofillProfileSyncableService(wds); 234 wds->GetAutofillProfileSyncableService();
188 sync_api::UserShare* user_share = service->GetUserShare(); 235 sync_api::UserShare* user_share = service->GetUserShare();
189 GenericChangeProcessor* change_processor = 236 GenericChangeProcessor* change_processor =
190 new GenericChangeProcessor(sync_service, dtc, user_share); 237 new GenericChangeProcessor(sync_service, dtc, user_share);
191 SyncableServiceAdapter* sync_service_adapter = 238 SyncableServiceAdapter* sync_service_adapter =
192 new SyncableServiceAdapter(syncable::AUTOFILL_PROFILE, 239 new SyncableServiceAdapter(syncable::AUTOFILL_PROFILE,
193 sync_service, 240 sync_service,
194 change_processor); 241 change_processor);
195 return ProfileSyncFactory::SyncComponents(sync_service_adapter, 242 return ProfileSyncFactory::SyncComponents(sync_service_adapter,
196 change_processor); 243 change_processor);
197 } 244 }
(...skipping 10 matching lines...) Expand all
208 DataTypeController* dtc) = 0; 255 DataTypeController* dtc) = 0;
209 virtual ~AbstractAutofillFactory() {} 256 virtual ~AbstractAutofillFactory() {}
210 }; 257 };
211 258
212 class AutofillEntryFactory : public AbstractAutofillFactory { 259 class AutofillEntryFactory : public AbstractAutofillFactory {
213 public: 260 public:
214 browser_sync::AutofillDataTypeController* CreateDataTypeController( 261 browser_sync::AutofillDataTypeController* CreateDataTypeController(
215 ProfileSyncFactory* factory, 262 ProfileSyncFactory* factory,
216 ProfileMock* profile, 263 ProfileMock* profile,
217 ProfileSyncService* service) { 264 ProfileSyncService* service) {
218 return new AutofillDataTypeController(factory, 265 return new AutofillDataTypeController(factory, profile);
219 profile);
220 } 266 }
221 267
222 void SetExpectation(ProfileSyncFactoryMock* factory, 268 void SetExpectation(ProfileSyncFactoryMock* factory,
223 ProfileSyncService* service, 269 ProfileSyncService* service,
224 WebDataService* wds, 270 WebDataService* wds,
225 DataTypeController* dtc) { 271 DataTypeController* dtc) {
226 EXPECT_CALL(*factory, CreateAutofillSyncComponents(_,_,_)). 272 EXPECT_CALL(*factory, CreateAutofillSyncComponents(_,_,_)).
227 WillOnce(MakeAutofillSyncComponents(service, wds->GetDatabase(), dtc)); 273 WillOnce(MakeAutofillSyncComponents(service, wds->GetDatabase(), dtc));
228 } 274 }
229 }; 275 };
230 276
231 class AutofillProfileFactory : public AbstractAutofillFactory { 277 class AutofillProfileFactory : public AbstractAutofillFactory {
232 public: 278 public:
233 browser_sync::AutofillDataTypeController* CreateDataTypeController( 279 browser_sync::AutofillDataTypeController* CreateDataTypeController(
234 ProfileSyncFactory* factory, 280 ProfileSyncFactory* factory,
235 ProfileMock* profile, 281 ProfileMock* profile,
236 ProfileSyncService* service) { 282 ProfileSyncService* service) {
237 return new AutofillProfileDataTypeController(factory, 283 return new AutofillProfileDataTypeController(factory, profile);
238 profile);
239 } 284 }
240 285
241 void SetExpectation(ProfileSyncFactoryMock* factory, 286 void SetExpectation(ProfileSyncFactoryMock* factory,
242 ProfileSyncService* service, 287 ProfileSyncService* service,
243 WebDataService* wds, 288 WebDataService* wds,
244 DataTypeController* dtc) { 289 DataTypeController* dtc) {
245 EXPECT_CALL(*factory, CreateAutofillProfileSyncComponents(_,_,_)). 290 EXPECT_CALL(*factory, CreateAutofillProfileSyncComponents(_,_,_)).
246 WillOnce(MakeAutofillProfileSyncComponents(service, wds, dtc)); 291 WillOnce(MakeAutofillProfileSyncComponents(service, wds, dtc));
247 } 292 }
248 }; 293 };
249 294
250 class PersonalDataManagerMock: public PersonalDataManager { 295 class PersonalDataManagerMock: public PersonalDataManager {
251 public: 296 public:
252 static ProfileKeyedService* Build(Profile* profile) { 297 static ProfileKeyedService* Build(Profile* profile) {
253 return new PersonalDataManagerMock; 298 return new PersonalDataManagerMock;
254 } 299 }
255 300
256 MOCK_CONST_METHOD0(IsDataLoaded, bool()); 301 MOCK_CONST_METHOD0(IsDataLoaded, bool());
257 MOCK_METHOD0(LoadProfiles, void()); 302 MOCK_METHOD0(LoadProfiles, void());
258 MOCK_METHOD0(LoadCreditCards, void()); 303 MOCK_METHOD0(LoadCreditCards, void());
259 MOCK_METHOD0(Refresh, void()); 304 MOCK_METHOD0(Refresh, void());
260 }; 305 };
261 template <class T> class AddAutofillTask; 306 template <class T> class AddAutofillTask;
262 307
263 class ProfileSyncServiceAutofillTest : public AbstractProfileSyncServiceTest { 308 class ProfileSyncServiceAutofillTest : public AbstractProfileSyncServiceTest {
264 protected: 309 protected:
265 ProfileSyncServiceAutofillTest() {} 310 ProfileSyncServiceAutofillTest() {
311 }
266 312
267 AutofillProfileFactory profile_factory_; 313 AutofillProfileFactory profile_factory_;
268 AutofillEntryFactory entry_factory_; 314 AutofillEntryFactory entry_factory_;
269 315
270 AbstractAutofillFactory* GetFactory(syncable::ModelType type) { 316 AbstractAutofillFactory* GetFactory(syncable::ModelType type) {
271 if (type == syncable::AUTOFILL) { 317 if (type == syncable::AUTOFILL) {
272 return &entry_factory_; 318 return &entry_factory_;
273 } else if (type == syncable::AUTOFILL_PROFILE) { 319 } else if (type == syncable::AUTOFILL_PROFILE) {
274 return &profile_factory_; 320 return &profile_factory_;
275 } else { 321 } else {
(...skipping 15 matching lines...) Expand all
291 EXPECT_CALL(profile_, GetWebDataService(_)). 337 EXPECT_CALL(profile_, GetWebDataService(_)).
292 // TokenService::Initialize 338 // TokenService::Initialize
293 // AutofillDataTypeController::StartModels() 339 // AutofillDataTypeController::StartModels()
294 // In some tests: 340 // In some tests:
295 // AutofillProfileSyncableService::AutofillProfileSyncableService() 341 // AutofillProfileSyncableService::AutofillProfileSyncableService()
296 WillRepeatedly(Return(web_data_service_.get())); 342 WillRepeatedly(Return(web_data_service_.get()));
297 personal_data_manager_->Init(&profile_); 343 personal_data_manager_->Init(&profile_);
298 344
299 notification_service_ = new ThreadNotificationService(&db_thread_); 345 notification_service_ = new ThreadNotificationService(&db_thread_);
300 notification_service_->Init(); 346 notification_service_->Init();
347
348 // Note: This must be called *after* the notification service is created.
349 web_data_service_->StartSyncableService();
301 } 350 }
302 351
303 virtual void TearDown() { 352 virtual void TearDown() {
353 // Note: The tear down order is important.
304 service_.reset(); 354 service_.reset();
355 web_data_service_->ShutdownSyncableService();
305 notification_service_->TearDown(); 356 notification_service_->TearDown();
306 profile_.ResetRequestContext(); 357 profile_.ResetRequestContext();
307 AbstractProfileSyncServiceTest::TearDown(); 358 AbstractProfileSyncServiceTest::TearDown();
308 } 359 }
309 360
310 void StartSyncService(Task* task, 361 void StartSyncService(Task* task,
311 bool will_fail_association, 362 bool will_fail_association,
312 syncable::ModelType type) { 363 syncable::ModelType type) {
313 AbstractAutofillFactory* factory = GetFactory(type); 364 AbstractAutofillFactory* factory = GetFactory(type);
314 service_.reset( 365 service_.reset(
(...skipping 13 matching lines...) Expand all
328 web_data_service_.get(), 379 web_data_service_.get(),
329 data_type_controller); 380 data_type_controller);
330 381
331 EXPECT_CALL(factory_, CreateDataTypeManager(_, _)). 382 EXPECT_CALL(factory_, CreateDataTypeManager(_, _)).
332 WillOnce(ReturnNewDataTypeManager()); 383 WillOnce(ReturnNewDataTypeManager());
333 384
334 EXPECT_CALL(*personal_data_manager_, IsDataLoaded()). 385 EXPECT_CALL(*personal_data_manager_, IsDataLoaded()).
335 WillRepeatedly(Return(true)); 386 WillRepeatedly(Return(true));
336 387
337 // We need tokens to get the tests going 388 // We need tokens to get the tests going
338 token_service_->IssueAuthTokenForTest( 389 token_service_->IssueAuthTokenForTest(GaiaConstants::kSyncService, "token");
339 GaiaConstants::kSyncService, "token");
340 390
341 EXPECT_CALL(profile_, GetTokenService()). 391 EXPECT_CALL(profile_, GetTokenService()).
342 WillRepeatedly(Return(token_service_.get())); 392 WillRepeatedly(Return(token_service_.get()));
343 393
344 service_->RegisterDataTypeController(data_type_controller); 394 service_->RegisterDataTypeController(data_type_controller);
345 service_->Initialize(); 395 service_->Initialize();
346 MessageLoop::current()->Run(); 396 MessageLoop::current()->Run();
347 } 397 }
348 398
349 bool AddAutofillSyncNode(const AutofillEntry& entry) { 399 bool AddAutofillSyncNode(const AutofillEntry& entry) {
350 sync_api::WriteTransaction trans(FROM_HERE, service_->GetUserShare()); 400 sync_api::WriteTransaction trans(FROM_HERE, service_->GetUserShare());
351 sync_api::ReadNode autofill_root(&trans); 401 sync_api::ReadNode autofill_root(&trans);
352 if (!autofill_root.InitByTagLookup(browser_sync::kAutofillTag)) 402 if (!autofill_root.InitByTagLookup(browser_sync::kAutofillTag))
353 return false; 403 return false;
354 404
355 sync_api::WriteNode node(&trans); 405 sync_api::WriteNode node(&trans);
356 std::string tag = AutofillModelAssociator::KeyToTag(entry.key().name(), 406 std::string tag = AutofillModelAssociator::KeyToTag(entry.key().name(),
357 entry.key().value()); 407 entry.key().value());
358 if (!node.InitUniqueByCreation(syncable::AUTOFILL, autofill_root, tag)) 408 if (!node.InitUniqueByCreation(syncable::AUTOFILL, autofill_root, tag))
359 return false; 409 return false;
360 410
361 AutofillChangeProcessor::WriteAutofillEntry(entry, &node); 411 AutofillChangeProcessor::WriteAutofillEntry(entry, &node);
362 return true; 412 return true;
363 } 413 }
364 414
365 bool AddAutofillSyncNode(const AutofillProfile& profile) { 415 bool AddAutofillSyncNode(const AutofillProfile& profile) {
366 sync_api::WriteTransaction trans(FROM_HERE, service_->GetUserShare()); 416 sync_api::WriteTransaction trans(FROM_HERE, service_->GetUserShare());
367 sync_api::ReadNode autofill_root(&trans); 417 sync_api::ReadNode autofill_root(&trans);
368 if (!autofill_root.InitByTagLookup(browser_sync::kAutofillProfileTag)) 418 if (!autofill_root.InitByTagLookup(kAutofillProfileTag))
369 return false; 419 return false;
370 sync_api::WriteNode node(&trans); 420 sync_api::WriteNode node(&trans);
371 std::string tag = profile.guid(); 421 std::string tag = profile.guid();
372 if (!node.InitUniqueByCreation(syncable::AUTOFILL_PROFILE, 422 if (!node.InitUniqueByCreation(syncable::AUTOFILL_PROFILE,
373 autofill_root, tag)) 423 autofill_root, tag))
374 return false; 424 return false;
375 sync_pb::EntitySpecifics specifics; 425 sync_pb::EntitySpecifics specifics;
376 AutofillProfileSyncableService::WriteAutofillProfile(profile, &specifics); 426 AutofillProfileSyncableService::WriteAutofillProfile(profile, &specifics);
377 sync_pb::AutofillProfileSpecifics* profile_specifics = 427 sync_pb::AutofillProfileSpecifics* profile_specifics =
378 specifics.MutableExtension(sync_pb::autofill_profile); 428 specifics.MutableExtension(sync_pb::autofill_profile);
(...skipping 35 matching lines...) Expand 10 before | Expand all | Expand 10 after
414 } 464 }
415 child_id = child_node.GetSuccessorId(); 465 child_id = child_node.GetSuccessorId();
416 } 466 }
417 return true; 467 return true;
418 } 468 }
419 469
420 bool GetAutofillProfilesFromSyncDBUnderProfileNode( 470 bool GetAutofillProfilesFromSyncDBUnderProfileNode(
421 std::vector<AutofillProfile>* profiles) { 471 std::vector<AutofillProfile>* profiles) {
422 sync_api::ReadTransaction trans(FROM_HERE, service_->GetUserShare()); 472 sync_api::ReadTransaction trans(FROM_HERE, service_->GetUserShare());
423 sync_api::ReadNode autofill_root(&trans); 473 sync_api::ReadNode autofill_root(&trans);
424 if (!autofill_root.InitByTagLookup(browser_sync::kAutofillProfileTag)) 474 if (!autofill_root.InitByTagLookup(kAutofillProfileTag))
425 return false; 475 return false;
426 476
427 int64 child_id = autofill_root.GetFirstChildId(); 477 int64 child_id = autofill_root.GetFirstChildId();
428 while (child_id != sync_api::kInvalidId) { 478 while (child_id != sync_api::kInvalidId) {
429 sync_api::ReadNode child_node(&trans); 479 sync_api::ReadNode child_node(&trans);
430 if (!child_node.InitByIdLookup(child_id)) 480 if (!child_node.InitByIdLookup(child_id))
431 return false; 481 return false;
432 482
433 const sync_pb::AutofillProfileSpecifics& autofill( 483 const sync_pb::AutofillProfileSpecifics& autofill(
434 child_node.GetAutofillProfileSpecifics()); 484 child_node.GetAutofillProfileSpecifics());
(...skipping 34 matching lines...) Expand 10 before | Expand all | Expand 10 after
469 519
470 friend class AddAutofillTask<AutofillEntry>; 520 friend class AddAutofillTask<AutofillEntry>;
471 friend class AddAutofillTask<AutofillProfile>; 521 friend class AddAutofillTask<AutofillProfile>;
472 friend class FakeServerUpdater; 522 friend class FakeServerUpdater;
473 523
474 scoped_refptr<ThreadNotificationService> notification_service_; 524 scoped_refptr<ThreadNotificationService> notification_service_;
475 525
476 ProfileMock profile_; 526 ProfileMock profile_;
477 AutofillTableMock autofill_table_; 527 AutofillTableMock autofill_table_;
478 scoped_ptr<WebDatabaseFake> web_database_; 528 scoped_ptr<WebDatabaseFake> web_database_;
479 scoped_refptr<WebDataService> web_data_service_; 529 scoped_refptr<WebDataServiceFake> web_data_service_;
480 PersonalDataManagerMock* personal_data_manager_; 530 PersonalDataManagerMock* personal_data_manager_;
481 }; 531 };
482 532
483 template <class T> 533 template <class T>
484 class AddAutofillTask : public Task { 534 class AddAutofillTask : public Task {
485 public: 535 public:
486 AddAutofillTask(ProfileSyncServiceAutofillTest* test, 536 AddAutofillTask(ProfileSyncServiceAutofillTest* test,
487 const std::vector<T>& entries) 537 const std::vector<T>& entries)
488 : test_(test), entries_(entries), success_(false) { 538 : test_(test), entries_(entries), success_(false) {
489 } 539 }
490 540
491 virtual void Run() { 541 virtual void Run() {
492 if (!test_->CreateRoot(GetModelType<T>())) 542 if (!test_->CreateRoot(GetModelType<T>()))
493 return; 543 return;
494 for (size_t i = 0; i < entries_.size(); ++i) { 544 for (size_t i = 0; i < entries_.size(); ++i) {
495 if (!test_->AddAutofillSyncNode(entries_[i])) 545 if (!test_->AddAutofillSyncNode(entries_[i]))
496 return; 546 return;
497 } 547 }
(...skipping 595 matching lines...) Expand 10 before | Expand all | Expand 10 after
1093 std::vector<AutofillEntry> sync_entries; 1143 std::vector<AutofillEntry> sync_entries;
1094 std::vector<AutofillProfile> sync_profiles; 1144 std::vector<AutofillProfile> sync_profiles;
1095 ASSERT_TRUE(GetAutofillEntriesFromSyncDB(&sync_entries, &sync_profiles)); 1145 ASSERT_TRUE(GetAutofillEntriesFromSyncDB(&sync_entries, &sync_profiles));
1096 EXPECT_EQ(3U, sync_entries.size()); 1146 EXPECT_EQ(3U, sync_entries.size());
1097 EXPECT_EQ(0U, sync_profiles.size()); 1147 EXPECT_EQ(0U, sync_profiles.size());
1098 for (size_t i = 0; i < sync_entries.size(); i++) { 1148 for (size_t i = 0; i < sync_entries.size(); i++) {
1099 VLOG(1) << "Entry " << i << ": " << sync_entries[i].key().name() 1149 VLOG(1) << "Entry " << i << ": " << sync_entries[i].key().name()
1100 << ", " << sync_entries[i].key().value(); 1150 << ", " << sync_entries[i].key().value();
1101 } 1151 }
1102 } 1152 }
OLDNEW
« no previous file with comments | « chrome/browser/sync/profile_sync_factory_impl.cc ('k') | chrome/browser/webdata/autofill_profile_syncable_service.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698