| OLD | NEW |
| 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 "chrome/test/base/testing_profile.h" | 5 #include "chrome/test/base/testing_profile.h" |
| 6 | 6 |
| 7 #include "build/build_config.h" | 7 #include "build/build_config.h" |
| 8 | 8 |
| 9 #include "base/base_paths.h" | 9 #include "base/base_paths.h" |
| 10 #include "base/command_line.h" | 10 #include "base/command_line.h" |
| (...skipping 11 matching lines...) Expand all Loading... |
| 22 #include "chrome/browser/content_settings/host_content_settings_map.h" | 22 #include "chrome/browser/content_settings/host_content_settings_map.h" |
| 23 #include "chrome/browser/extensions/extension_service.h" | 23 #include "chrome/browser/extensions/extension_service.h" |
| 24 #include "chrome/browser/extensions/extension_special_storage_policy.h" | 24 #include "chrome/browser/extensions/extension_special_storage_policy.h" |
| 25 #include "chrome/browser/extensions/extension_system_factory.h" | 25 #include "chrome/browser/extensions/extension_system_factory.h" |
| 26 #include "chrome/browser/extensions/test_extension_system.h" | 26 #include "chrome/browser/extensions/test_extension_system.h" |
| 27 #include "chrome/browser/favicon/favicon_service.h" | 27 #include "chrome/browser/favicon/favicon_service.h" |
| 28 #include "chrome/browser/favicon/favicon_service_factory.h" | 28 #include "chrome/browser/favicon/favicon_service_factory.h" |
| 29 #include "chrome/browser/geolocation/chrome_geolocation_permission_context.h" | 29 #include "chrome/browser/geolocation/chrome_geolocation_permission_context.h" |
| 30 #include "chrome/browser/geolocation/chrome_geolocation_permission_context_facto
ry.h" | 30 #include "chrome/browser/geolocation/chrome_geolocation_permission_context_facto
ry.h" |
| 31 #include "chrome/browser/guest_view/guest_view_manager.h" | 31 #include "chrome/browser/guest_view/guest_view_manager.h" |
| 32 #include "chrome/browser/history/chrome_history_client.h" |
| 32 #include "chrome/browser/history/history_backend.h" | 33 #include "chrome/browser/history/history_backend.h" |
| 33 #include "chrome/browser/history/history_db_task.h" | 34 #include "chrome/browser/history/history_db_task.h" |
| 34 #include "chrome/browser/history/history_service.h" | 35 #include "chrome/browser/history/history_service.h" |
| 35 #include "chrome/browser/history/history_service_factory.h" | 36 #include "chrome/browser/history/history_service_factory.h" |
| 36 #include "chrome/browser/history/top_sites.h" | 37 #include "chrome/browser/history/top_sites.h" |
| 37 #include "chrome/browser/history/web_history_service_factory.h" | 38 #include "chrome/browser/history/web_history_service_factory.h" |
| 38 #include "chrome/browser/net/pref_proxy_config_tracker.h" | 39 #include "chrome/browser/net/pref_proxy_config_tracker.h" |
| 39 #include "chrome/browser/net/proxy_service_factory.h" | 40 #include "chrome/browser/net/proxy_service_factory.h" |
| 40 #include "chrome/browser/notifications/desktop_notification_service.h" | 41 #include "chrome/browser/notifications/desktop_notification_service.h" |
| 41 #include "chrome/browser/notifications/desktop_notification_service_factory.h" | 42 #include "chrome/browser/notifications/desktop_notification_service_factory.h" |
| (...skipping 46 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 88 #endif // defined(ENABLE_CONFIGURATION_POLICY) | 89 #endif // defined(ENABLE_CONFIGURATION_POLICY) |
| 89 | 90 |
| 90 #if defined(ENABLE_MANAGED_USERS) | 91 #if defined(ENABLE_MANAGED_USERS) |
| 91 #include "chrome/browser/managed_mode/managed_user_settings_service.h" | 92 #include "chrome/browser/managed_mode/managed_user_settings_service.h" |
| 92 #include "chrome/browser/managed_mode/managed_user_settings_service_factory.h" | 93 #include "chrome/browser/managed_mode/managed_user_settings_service_factory.h" |
| 93 #endif | 94 #endif |
| 94 | 95 |
| 95 using base::Time; | 96 using base::Time; |
| 96 using content::BrowserThread; | 97 using content::BrowserThread; |
| 97 using content::DownloadManagerDelegate; | 98 using content::DownloadManagerDelegate; |
| 99 using history::ChromeHistoryClient; |
| 98 using testing::NiceMock; | 100 using testing::NiceMock; |
| 99 using testing::Return; | 101 using testing::Return; |
| 100 | 102 |
| 101 namespace { | 103 namespace { |
| 102 | 104 |
| 103 // Task used to make sure history has finished processing a request. Intended | 105 // Task used to make sure history has finished processing a request. Intended |
| 104 // for use with BlockUntilHistoryProcessesPendingRequests. | 106 // for use with BlockUntilHistoryProcessesPendingRequests. |
| 105 | 107 |
| 106 class QuittingHistoryDBTask : public history::HistoryDBTask { | 108 class QuittingHistoryDBTask : public history::HistoryDBTask { |
| 107 public: | 109 public: |
| (...skipping 312 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 420 return new FaviconService(static_cast<Profile*>(profile)); | 422 return new FaviconService(static_cast<Profile*>(profile)); |
| 421 } | 423 } |
| 422 | 424 |
| 423 void TestingProfile::CreateFaviconService() { | 425 void TestingProfile::CreateFaviconService() { |
| 424 // It is up to the caller to create the history service if one is needed. | 426 // It is up to the caller to create the history service if one is needed. |
| 425 FaviconServiceFactory::GetInstance()->SetTestingFactory( | 427 FaviconServiceFactory::GetInstance()->SetTestingFactory( |
| 426 this, BuildFaviconService); | 428 this, BuildFaviconService); |
| 427 } | 429 } |
| 428 | 430 |
| 429 static KeyedService* BuildHistoryService(content::BrowserContext* profile) { | 431 static KeyedService* BuildHistoryService(content::BrowserContext* profile) { |
| 430 return new HistoryService(static_cast<Profile*>(profile)); | 432 return new ChromeHistoryClient(static_cast<Profile*>(profile)); |
| 431 } | 433 } |
| 432 | 434 |
| 433 bool TestingProfile::CreateHistoryService(bool delete_file, bool no_db) { | 435 bool TestingProfile::CreateHistoryService(bool delete_file, bool no_db) { |
| 434 DestroyHistoryService(); | 436 DestroyHistoryService(); |
| 435 if (delete_file) { | 437 if (delete_file) { |
| 436 base::FilePath path = GetPath(); | 438 base::FilePath path = GetPath(); |
| 437 path = path.Append(chrome::kHistoryFilename); | 439 path = path.Append(chrome::kHistoryFilename); |
| 438 if (!base::DeleteFile(path, false) || base::PathExists(path)) | 440 if (!base::DeleteFile(path, false) || base::PathExists(path)) |
| 439 return false; | 441 return false; |
| 440 } | 442 } |
| 441 // This will create and init the history service. | 443 // This will create and init the history service. |
| 442 HistoryService* history_service = static_cast<HistoryService*>( | 444 ChromeHistoryClient* history_client = static_cast<ChromeHistoryClient*>( |
| 443 HistoryServiceFactory::GetInstance()->SetTestingFactoryAndUse( | 445 HistoryServiceFactory::GetInstance()->SetTestingFactoryAndUse( |
| 444 this, BuildHistoryService)); | 446 this, BuildHistoryService)); |
| 445 if (!history_service->Init(this->GetPath(), | 447 HistoryService* history_service = history_client->history_service(); |
| 446 BookmarkModelFactory::GetForProfile(this), | 448 if (!history_service->Init(this->GetPath(), no_db)) { |
| 447 no_db)) { | |
| 448 HistoryServiceFactory::GetInstance()->SetTestingFactoryAndUse(this, NULL); | 449 HistoryServiceFactory::GetInstance()->SetTestingFactoryAndUse(this, NULL); |
| 449 } | 450 } |
| 450 // Disable WebHistoryService by default, since it makes network requests. | 451 // Disable WebHistoryService by default, since it makes network requests. |
| 451 WebHistoryServiceFactory::GetInstance()->SetTestingFactory(this, NULL); | 452 WebHistoryServiceFactory::GetInstance()->SetTestingFactory(this, NULL); |
| 452 return true; | 453 return true; |
| 453 } | 454 } |
| 454 | 455 |
| 455 void TestingProfile::DestroyHistoryService() { | 456 void TestingProfile::DestroyHistoryService() { |
| 456 HistoryService* history_service = | 457 HistoryService* history_service = |
| 457 HistoryServiceFactory::GetForProfileWithoutCreating(this); | 458 HistoryServiceFactory::GetForProfileWithoutCreating(this); |
| (...skipping 49 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 507 content::BrowserThread::UI)); | 508 content::BrowserThread::UI)); |
| 508 return bookmark_client; | 509 return bookmark_client; |
| 509 } | 510 } |
| 510 | 511 |
| 511 void TestingProfile::CreateBookmarkModel(bool delete_file) { | 512 void TestingProfile::CreateBookmarkModel(bool delete_file) { |
| 512 if (delete_file) { | 513 if (delete_file) { |
| 513 base::FilePath path = GetPath().Append(bookmarks::kBookmarksFileName); | 514 base::FilePath path = GetPath().Append(bookmarks::kBookmarksFileName); |
| 514 base::DeleteFile(path, false); | 515 base::DeleteFile(path, false); |
| 515 } | 516 } |
| 516 // This will create a bookmark model. | 517 // This will create a bookmark model. |
| 517 BookmarkModel* bookmark_service = | 518 BookmarkModelFactory::GetInstance()->SetTestingFactoryAndUse( |
| 518 static_cast<ChromeBookmarkClient*>( | 519 this, BuildBookmarkModel); |
| 519 BookmarkModelFactory::GetInstance()->SetTestingFactoryAndUse( | |
| 520 this, BuildBookmarkModel))->model(); | |
| 521 | |
| 522 HistoryService* history_service = | |
| 523 HistoryServiceFactory::GetForProfileWithoutCreating(this); | |
| 524 if (history_service) { | |
| 525 history_service->history_backend_->bookmark_service_ = bookmark_service; | |
| 526 history_service->history_backend_->expirer_.bookmark_service_ = | |
| 527 bookmark_service; | |
| 528 } | |
| 529 } | 520 } |
| 530 | 521 |
| 531 static KeyedService* BuildWebDataService(content::BrowserContext* profile) { | 522 static KeyedService* BuildWebDataService(content::BrowserContext* profile) { |
| 532 return new WebDataServiceWrapper(static_cast<Profile*>(profile)); | 523 return new WebDataServiceWrapper(static_cast<Profile*>(profile)); |
| 533 } | 524 } |
| 534 | 525 |
| 535 void TestingProfile::CreateWebDataService() { | 526 void TestingProfile::CreateWebDataService() { |
| 536 WebDataServiceFactory::GetInstance()->SetTestingFactory( | 527 WebDataServiceFactory::GetInstance()->SetTestingFactory( |
| 537 this, BuildWebDataService); | 528 this, BuildWebDataService); |
| 538 } | 529 } |
| (...skipping 446 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 985 path_, | 976 path_, |
| 986 delegate_, | 977 delegate_, |
| 987 extension_policy_, | 978 extension_policy_, |
| 988 pref_service_.Pass(), | 979 pref_service_.Pass(), |
| 989 incognito_, | 980 incognito_, |
| 990 guest_session_, | 981 guest_session_, |
| 991 managed_user_id_, | 982 managed_user_id_, |
| 992 policy_service_.Pass(), | 983 policy_service_.Pass(), |
| 993 testing_factories_)); | 984 testing_factories_)); |
| 994 } | 985 } |
| OLD | NEW |