summaryrefslogtreecommitdiffstats
path: root/chrome/browser/extensions/test_extension_system.cc
diff options
context:
space:
mode:
authorkalman@chromium.org <kalman@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2012-11-15 20:49:39 +0000
committerkalman@chromium.org <kalman@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2012-11-15 20:49:39 +0000
commitfdd679ba41268871b72cb48e5cda976c1ab7daaf (patch)
treee5ddf049d4c6526dfc512b2ea99e97e3031f4759 /chrome/browser/extensions/test_extension_system.cc
parent97399a6604a14398deadcffd30745da1d9f47d7d (diff)
downloadchromium_src-fdd679ba41268871b72cb48e5cda976c1ab7daaf.zip
chromium_src-fdd679ba41268871b72cb48e5cda976c1ab7daaf.tar.gz
chromium_src-fdd679ba41268871b72cb48e5cda976c1ab7daaf.tar.bz2
Pull extension blacklist and policy logic out of ExtensionPrefs and into two
new classes: Blacklist for the blacklist logic, and StandardManagementPolicyProvider for the management policy component. This is a preliminary step to making the extension blacklist backed by safe browsing. Dumb blacklisting code will still live in ExtensionPrefs until the migration is complete. BUG=154149 TBR=ben@chromium.org Review URL: https://chromiumcodereview.appspot.com/11410048 git-svn-id: svn://svn.chromium.org/chrome/trunk/src@168020 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'chrome/browser/extensions/test_extension_system.cc')
-rw-r--r--chrome/browser/extensions/test_extension_system.cc29
1 files changed, 18 insertions, 11 deletions
diff --git a/chrome/browser/extensions/test_extension_system.cc b/chrome/browser/extensions/test_extension_system.cc
index f050864..1b8ccd7 100644
--- a/chrome/browser/extensions/test_extension_system.cc
+++ b/chrome/browser/extensions/test_extension_system.cc
@@ -7,6 +7,7 @@
#include "base/command_line.h"
#include "chrome/browser/extensions/api/alarms/alarm_manager.h"
#include "chrome/browser/extensions/api/messaging/message_service.h"
+#include "chrome/browser/extensions/blacklist.h"
#include "chrome/browser/extensions/event_router.h"
#include "chrome/browser/extensions/extension_devtools_manager.h"
#include "chrome/browser/extensions/extension_info_map.h"
@@ -15,7 +16,9 @@
#include "chrome/browser/extensions/extension_process_manager.h"
#include "chrome/browser/extensions/extension_service.h"
#include "chrome/browser/extensions/extension_system.h"
+#include "chrome/browser/extensions/management_policy.h"
#include "chrome/browser/extensions/shell_window_geometry_cache.h"
+#include "chrome/browser/extensions/standard_management_policy_provider.h"
#include "chrome/browser/extensions/state_store.h"
#include "chrome/browser/extensions/user_script_master.h"
#include "chrome/browser/profiles/profile.h"
@@ -71,32 +74,32 @@ ExtensionService* TestExtensionSystem::CreateExtensionService(
// are not reflected in the pref service. One would need to
// inject a new ExtensionPrefStore(extension_pref_value_map, false).
- extension_prefs_.reset(new ExtensionPrefs(
+ extension_prefs_ = ExtensionPrefs::Create(
profile_->GetPrefs(),
install_directory,
- ExtensionPrefValueMapFactory::GetForProfile(profile_)));
+ ExtensionPrefValueMapFactory::GetForProfile(profile_),
+ extensions_disabled);
state_store_.reset(new StateStore(profile_, new TestingValueStore()));
shell_window_geometry_cache_.reset(
new ShellWindowGeometryCache(profile_, state_store_.get()));
- extension_prefs_->Init(extensions_disabled);
+ blacklist_.reset(new Blacklist(extension_prefs_.get()));
+ standard_management_policy_provider_.reset(
+ new StandardManagementPolicyProvider(extension_prefs_.get(),
+ blacklist_.get()));
+ management_policy_.reset(new ManagementPolicy());
+ management_policy_->RegisterProvider(
+ standard_management_policy_provider_.get());
extension_service_.reset(new ExtensionService(profile_,
command_line,
install_directory,
extension_prefs_.get(),
+ blacklist_.get(),
autoupdate_enabled,
true));
extension_service_->ClearProvidersForTesting();
return extension_service_.get();
}
-ManagementPolicy* TestExtensionSystem::CreateManagementPolicy() {
- management_policy_.reset(new ManagementPolicy());
- DCHECK(extension_prefs_.get());
- management_policy_->RegisterProvider(extension_prefs_.get());
-
- return management_policy();
-}
-
ExtensionService* TestExtensionSystem::extension_service() {
return extension_service_.get();
}
@@ -172,6 +175,10 @@ ExtensionWarningService* TestExtensionSystem::warning_service() {
return NULL;
}
+Blacklist* TestExtensionSystem::blacklist() {
+ return blacklist_.get();
+}
+
// static
ProfileKeyedService* TestExtensionSystem::Build(Profile* profile) {
return new TestExtensionSystem(profile);