| 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 <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 |
| (...skipping 12 matching lines...) Expand all Loading... |
| 23 #include "chrome/browser/autofill/personal_data_manager_factory.h" | 23 #include "chrome/browser/autofill/personal_data_manager_factory.h" |
| 24 #include "chrome/browser/sync/abstract_profile_sync_service_test.h" | 24 #include "chrome/browser/sync/abstract_profile_sync_service_test.h" |
| 25 #include "chrome/browser/sync/engine/model_changing_syncer_command.h" | 25 #include "chrome/browser/sync/engine/model_changing_syncer_command.h" |
| 26 #include "chrome/browser/sync/glue/autofill_change_processor.h" | 26 #include "chrome/browser/sync/glue/autofill_change_processor.h" |
| 27 #include "chrome/browser/sync/glue/autofill_data_type_controller.h" | 27 #include "chrome/browser/sync/glue/autofill_data_type_controller.h" |
| 28 #include "chrome/browser/sync/glue/autofill_model_associator.h" | 28 #include "chrome/browser/sync/glue/autofill_model_associator.h" |
| 29 #include "chrome/browser/sync/glue/autofill_profile_data_type_controller.h" | 29 #include "chrome/browser/sync/glue/autofill_profile_data_type_controller.h" |
| 30 #include "chrome/browser/sync/glue/autofill_profile_syncable_service.h" | 30 #include "chrome/browser/sync/glue/autofill_profile_syncable_service.h" |
| 31 #include "chrome/browser/sync/glue/data_type_controller.h" | 31 #include "chrome/browser/sync/glue/data_type_controller.h" |
| 32 #include "chrome/browser/sync/glue/generic_change_processor.h" | 32 #include "chrome/browser/sync/glue/generic_change_processor.h" |
| 33 #include "chrome/browser/sync/glue/shared_change_processor.h" |
| 33 #include "chrome/browser/sync/glue/syncable_service_adapter.h" | 34 #include "chrome/browser/sync/glue/syncable_service_adapter.h" |
| 34 #include "chrome/browser/sync/internal_api/read_node.h" | 35 #include "chrome/browser/sync/internal_api/read_node.h" |
| 35 #include "chrome/browser/sync/internal_api/read_transaction.h" | 36 #include "chrome/browser/sync/internal_api/read_transaction.h" |
| 36 #include "chrome/browser/sync/internal_api/write_node.h" | 37 #include "chrome/browser/sync/internal_api/write_node.h" |
| 37 #include "chrome/browser/sync/internal_api/write_transaction.h" | 38 #include "chrome/browser/sync/internal_api/write_transaction.h" |
| 38 #include "chrome/browser/sync/profile_sync_factory.h" | 39 #include "chrome/browser/sync/profile_sync_factory.h" |
| 39 #include "chrome/browser/sync/profile_sync_service.h" | 40 #include "chrome/browser/sync/profile_sync_service.h" |
| 40 #include "chrome/browser/sync/profile_sync_test_util.h" | 41 #include "chrome/browser/sync/profile_sync_test_util.h" |
| 41 #include "chrome/browser/sync/protocol/autofill_specifics.pb.h" | 42 #include "chrome/browser/sync/protocol/autofill_specifics.pb.h" |
| 42 #include "chrome/browser/sync/syncable/directory_manager.h" | 43 #include "chrome/browser/sync/syncable/directory_manager.h" |
| (...skipping 13 matching lines...) Expand all Loading... |
| 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::AutofillProfileSyncableService; |
| 64 using browser_sync::DataTypeController; | 65 using browser_sync::DataTypeController; |
| 65 using browser_sync::GenericChangeProcessor; | 66 using browser_sync::GenericChangeProcessor; |
| 67 using browser_sync::SharedChangeProcessor; |
| 66 using browser_sync::SyncableServiceAdapter; | 68 using browser_sync::SyncableServiceAdapter; |
| 67 using browser_sync::GROUP_DB; | 69 using browser_sync::GROUP_DB; |
| 68 using browser_sync::kAutofillTag; | 70 using browser_sync::kAutofillTag; |
| 69 using browser_sync::SyncBackendHostForProfileSyncTest; | 71 using browser_sync::SyncBackendHostForProfileSyncTest; |
| 70 using browser_sync::UnrecoverableErrorHandler; | 72 using browser_sync::UnrecoverableErrorHandler; |
| 71 using syncable::CREATE_NEW_UPDATE_ITEM; | 73 using syncable::CREATE_NEW_UPDATE_ITEM; |
| 72 using syncable::AUTOFILL; | 74 using syncable::AUTOFILL; |
| 73 using syncable::BASE_VERSION; | 75 using syncable::BASE_VERSION; |
| 74 using syncable::CREATE; | 76 using syncable::CREATE; |
| 75 using syncable::GET_BY_SERVER_TAG; | 77 using syncable::GET_BY_SERVER_TAG; |
| (...skipping 96 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 172 return ProfileSyncFactory::SyncComponents(NULL, NULL); | 174 return ProfileSyncFactory::SyncComponents(NULL, NULL); |
| 173 AutofillModelAssociator* model_associator = | 175 AutofillModelAssociator* model_associator = |
| 174 new AutofillModelAssociator(service, wd, service->profile()); | 176 new AutofillModelAssociator(service, wd, service->profile()); |
| 175 AutofillChangeProcessor* change_processor = | 177 AutofillChangeProcessor* change_processor = |
| 176 new AutofillChangeProcessor(model_associator, wd, | 178 new AutofillChangeProcessor(model_associator, wd, |
| 177 service->profile(), dtc); | 179 service->profile(), dtc); |
| 178 return ProfileSyncFactory::SyncComponents(model_associator, | 180 return ProfileSyncFactory::SyncComponents(model_associator, |
| 179 change_processor); | 181 change_processor); |
| 180 } | 182 } |
| 181 | 183 |
| 184 ACTION(MakeGenericChangeProcessor) { |
| 185 sync_api::UserShare* user_share = arg0->GetUserShare(); |
| 186 return new GenericChangeProcessor(arg1, arg2, user_share); |
| 187 } |
| 188 |
| 189 ACTION(MakeSharedChangeProcessor) { |
| 190 return new SharedChangeProcessor(); |
| 191 } |
| 192 |
| 182 ACTION_P3(MakeAutofillProfileSyncComponents, service, wd, dtc) { | 193 ACTION_P3(MakeAutofillProfileSyncComponents, service, wd, dtc) { |
| 183 EXPECT_TRUE(BrowserThread::CurrentlyOn(BrowserThread::DB)); | 194 EXPECT_TRUE(BrowserThread::CurrentlyOn(BrowserThread::DB)); |
| 184 if (!BrowserThread::CurrentlyOn(BrowserThread::DB)) | 195 if (!BrowserThread::CurrentlyOn(BrowserThread::DB)) |
| 185 return ProfileSyncFactory::SyncComponents(NULL, NULL); | 196 return NULL; |
| 186 AutofillProfileSyncableService* sync_service = | 197 AutofillProfileSyncableService* sync_service = |
| 187 new AutofillProfileSyncableService(wd, service->profile()); | 198 new AutofillProfileSyncableService(wd, service->profile()); |
| 188 sync_api::UserShare* user_share = service->GetUserShare(); | 199 return sync_service; |
| 189 GenericChangeProcessor* change_processor = | |
| 190 new GenericChangeProcessor(sync_service, dtc, user_share); | |
| 191 SyncableServiceAdapter* sync_service_adapter = | |
| 192 new SyncableServiceAdapter(syncable::AUTOFILL_PROFILE, | |
| 193 sync_service, | |
| 194 change_processor); | |
| 195 return ProfileSyncFactory::SyncComponents(sync_service_adapter, | |
| 196 change_processor); | |
| 197 } | 200 } |
| 198 | 201 |
| 199 class AbstractAutofillFactory { | 202 class AbstractAutofillFactory { |
| 200 public: | 203 public: |
| 201 virtual AutofillDataTypeController* CreateDataTypeController( | 204 virtual DataTypeController* CreateDataTypeController( |
| 202 ProfileSyncFactory* factory, | 205 ProfileSyncFactory* factory, |
| 203 ProfileMock* profile, | 206 ProfileMock* profile, |
| 204 ProfileSyncService* service) = 0; | 207 ProfileSyncService* service) = 0; |
| 205 virtual void SetExpectation(ProfileSyncFactoryMock* factory, | 208 virtual void SetExpectation(ProfileSyncFactoryMock* factory, |
| 206 ProfileSyncService* service, | 209 ProfileSyncService* service, |
| 207 WebDatabase* wd, | 210 WebDatabase* wd, |
| 208 DataTypeController* dtc) = 0; | 211 DataTypeController* dtc) = 0; |
| 209 virtual ~AbstractAutofillFactory() {} | 212 virtual ~AbstractAutofillFactory() {} |
| 210 }; | 213 }; |
| 211 | 214 |
| 212 class AutofillEntryFactory : public AbstractAutofillFactory { | 215 class AutofillEntryFactory : public AbstractAutofillFactory { |
| 213 public: | 216 public: |
| 214 browser_sync::AutofillDataTypeController* CreateDataTypeController( | 217 browser_sync::DataTypeController* CreateDataTypeController( |
| 215 ProfileSyncFactory* factory, | 218 ProfileSyncFactory* factory, |
| 216 ProfileMock* profile, | 219 ProfileMock* profile, |
| 217 ProfileSyncService* service) { | 220 ProfileSyncService* service) { |
| 218 return new AutofillDataTypeController(factory, | 221 return new AutofillDataTypeController(factory, profile); |
| 219 profile); | |
| 220 } | 222 } |
| 221 | 223 |
| 222 void SetExpectation(ProfileSyncFactoryMock* factory, | 224 void SetExpectation(ProfileSyncFactoryMock* factory, |
| 223 ProfileSyncService* service, | 225 ProfileSyncService* service, |
| 224 WebDatabase* wd, | 226 WebDatabase* wd, |
| 225 DataTypeController* dtc) { | 227 DataTypeController* dtc) { |
| 226 EXPECT_CALL(*factory, CreateAutofillSyncComponents(_,_,_)). | 228 EXPECT_CALL(*factory, CreateAutofillSyncComponents(_,_,_)). |
| 227 WillOnce(MakeAutofillSyncComponents(service, wd, dtc)); | 229 WillOnce(MakeAutofillSyncComponents(service, wd, dtc)); |
| 228 } | 230 } |
| 229 }; | 231 }; |
| 230 | 232 |
| 231 class AutofillProfileFactory : public AbstractAutofillFactory { | 233 class AutofillProfileFactory : public AbstractAutofillFactory { |
| 232 public: | 234 public: |
| 233 browser_sync::AutofillDataTypeController* CreateDataTypeController( | 235 browser_sync::DataTypeController* CreateDataTypeController( |
| 234 ProfileSyncFactory* factory, | 236 ProfileSyncFactory* factory, |
| 235 ProfileMock* profile, | 237 ProfileMock* profile, |
| 236 ProfileSyncService* service) { | 238 ProfileSyncService* service) { |
| 237 return new AutofillProfileDataTypeController(factory, | 239 return new AutofillProfileDataTypeController(factory, profile); |
| 238 profile); | |
| 239 } | 240 } |
| 240 | 241 |
| 241 void SetExpectation(ProfileSyncFactoryMock* factory, | 242 void SetExpectation(ProfileSyncFactoryMock* factory, |
| 242 ProfileSyncService* service, | 243 ProfileSyncService* service, |
| 243 WebDatabase* wd, | 244 WebDatabase* wd, |
| 244 DataTypeController* dtc) { | 245 DataTypeController* dtc) { |
| 245 EXPECT_CALL(*factory, CreateAutofillProfileSyncComponents(_,_,_)). | 246 EXPECT_CALL(*factory, CreateGenericChangeProcessor(_,_,_)). |
| 247 WillOnce(MakeGenericChangeProcessor()); |
| 248 EXPECT_CALL(*factory, CreateSharedChangeProcessor()). |
| 249 WillOnce(MakeSharedChangeProcessor()); |
| 250 EXPECT_CALL(*factory, CreateAutofillProfileSyncComponents(_,_)). |
| 246 WillOnce(MakeAutofillProfileSyncComponents(service, wd, dtc)); | 251 WillOnce(MakeAutofillProfileSyncComponents(service, wd, dtc)); |
| 247 } | 252 } |
| 248 }; | 253 }; |
| 249 | 254 |
| 250 class PersonalDataManagerMock: public PersonalDataManager { | 255 class PersonalDataManagerMock: public PersonalDataManager { |
| 251 public: | 256 public: |
| 252 static ProfileKeyedService* Build(Profile* profile) { | 257 static ProfileKeyedService* Build(Profile* profile) { |
| 253 return new PersonalDataManagerMock; | 258 return new PersonalDataManagerMock; |
| 254 } | 259 } |
| 255 | 260 |
| (...skipping 53 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 309 | 314 |
| 310 void StartSyncService(Task* task, | 315 void StartSyncService(Task* task, |
| 311 bool will_fail_association, | 316 bool will_fail_association, |
| 312 syncable::ModelType type) { | 317 syncable::ModelType type) { |
| 313 AbstractAutofillFactory* factory = GetFactory(type); | 318 AbstractAutofillFactory* factory = GetFactory(type); |
| 314 service_.reset( | 319 service_.reset( |
| 315 new TestProfileSyncService(&factory_, &profile_, "test_user", false, | 320 new TestProfileSyncService(&factory_, &profile_, "test_user", false, |
| 316 task)); | 321 task)); |
| 317 EXPECT_CALL(profile_, GetProfileSyncService()).WillRepeatedly( | 322 EXPECT_CALL(profile_, GetProfileSyncService()).WillRepeatedly( |
| 318 Return(service_.get())); | 323 Return(service_.get())); |
| 319 AutofillDataTypeController* data_type_controller = | 324 DataTypeController* data_type_controller = |
| 320 factory->CreateDataTypeController(&factory_, | 325 factory->CreateDataTypeController(&factory_, |
| 321 &profile_, | 326 &profile_, |
| 322 service_.get()); | 327 service_.get()); |
| 323 SyncBackendHostForProfileSyncTest:: | 328 SyncBackendHostForProfileSyncTest:: |
| 324 SetDefaultExpectationsForWorkerCreation(&profile_); | 329 SetDefaultExpectationsForWorkerCreation(&profile_); |
| 325 | 330 |
| 326 factory->SetExpectation(&factory_, | 331 factory->SetExpectation(&factory_, |
| 327 service_.get(), | 332 service_.get(), |
| 328 web_database_.get(), | 333 web_database_.get(), |
| 329 data_type_controller); | 334 data_type_controller); |
| (...skipping 763 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 1093 std::vector<AutofillEntry> sync_entries; | 1098 std::vector<AutofillEntry> sync_entries; |
| 1094 std::vector<AutofillProfile> sync_profiles; | 1099 std::vector<AutofillProfile> sync_profiles; |
| 1095 ASSERT_TRUE(GetAutofillEntriesFromSyncDB(&sync_entries, &sync_profiles)); | 1100 ASSERT_TRUE(GetAutofillEntriesFromSyncDB(&sync_entries, &sync_profiles)); |
| 1096 EXPECT_EQ(3U, sync_entries.size()); | 1101 EXPECT_EQ(3U, sync_entries.size()); |
| 1097 EXPECT_EQ(0U, sync_profiles.size()); | 1102 EXPECT_EQ(0U, sync_profiles.size()); |
| 1098 for (size_t i = 0; i < sync_entries.size(); i++) { | 1103 for (size_t i = 0; i < sync_entries.size(); i++) { |
| 1099 VLOG(1) << "Entry " << i << ": " << sync_entries[i].key().name() | 1104 VLOG(1) << "Entry " << i << ": " << sync_entries[i].key().name() |
| 1100 << ", " << sync_entries[i].key().value(); | 1105 << ", " << sync_entries[i].key().value(); |
| 1101 } | 1106 } |
| 1102 } | 1107 } |
| OLD | NEW |