Index: chrome/browser/extensions/test_extension_prefs.cc |
=================================================================== |
--- chrome/browser/extensions/test_extension_prefs.cc (revision 0) |
+++ chrome/browser/extensions/test_extension_prefs.cc (revision 0) |
@@ -0,0 +1,69 @@ |
+// Copyright (c) 2010 The Chromium Authors. All rights reserved. |
+// Use of this source code is governed by a BSD-style license that can be |
+// found in the LICENSE file. |
+ |
+#include "chrome/browser/extensions/test_extension_prefs.h" |
+ |
+#include "base/file_util.h" |
+#include "base/logging.h" |
+#include "base/message_loop.h" |
+#include "chrome/browser/chrome_thread.h" |
+#include "chrome/browser/extensions/extension_prefs.h" |
+#include "chrome/browser/json_pref_store.h" |
+#include "chrome/browser/pref_service.h" |
+#include "chrome/common/extensions/extension.h" |
+#include "chrome/common/extensions/extension_constants.h" |
+#include "testing/gtest/include/gtest/gtest.h" |
+ |
+TestExtensionPrefs::TestExtensionPrefs() { |
+ EXPECT_TRUE(temp_dir_.CreateUniqueTempDir()); |
+ preferences_file_ = temp_dir_.path().AppendASCII("Preferences"); |
+ extensions_dir_ = temp_dir_.path().AppendASCII("Extensions"); |
+ EXPECT_TRUE(file_util::CreateDirectory(extensions_dir_)); |
+ |
+ RecreateExtensionPrefs(); |
+} |
+ |
+TestExtensionPrefs::~TestExtensionPrefs() {} |
+ |
+void TestExtensionPrefs::RecreateExtensionPrefs() { |
+ if (pref_service_.get()) { |
+ // The PrefService writes its persistent file on the file thread, so we |
+ // need to wait for any pending I/O to complete before creating a new |
+ // PrefService. |
+ MessageLoop file_loop; |
+ ChromeThread file_thread(ChromeThread::FILE, &file_loop); |
+ pref_service_->SavePersistentPrefs(); |
+ file_loop.RunAllPending(); |
+ } |
+ |
+ pref_service_.reset(new PrefService(new JsonPrefStore(preferences_file_))); |
+ ExtensionPrefs::RegisterUserPrefs(pref_service_.get()); |
+ prefs_.reset(new ExtensionPrefs(pref_service_.get(), temp_dir_.path())); |
+} |
+ |
+Extension* TestExtensionPrefs::AddExtension(std::string name) { |
+ DictionaryValue dictionary; |
+ dictionary.SetString(extension_manifest_keys::kName, name); |
+ dictionary.SetString(extension_manifest_keys::kVersion, "0.1"); |
+ return AddExtensionWithManifest(dictionary); |
+} |
+ |
+Extension* TestExtensionPrefs::AddExtensionWithManifest( |
+ const DictionaryValue& manifest) { |
+ std::string name; |
+ EXPECT_TRUE(manifest.GetString(extension_manifest_keys::kName, &name)); |
+ FilePath path = extensions_dir_.AppendASCII(name); |
+ Extension* extension = new Extension(path); |
+ std::string errors; |
+ EXPECT_TRUE(extension->InitFromValue(manifest, false, &errors)); |
+ extension->set_location(Extension::INTERNAL); |
+ EXPECT_TRUE(Extension::IdIsValid(extension->id())); |
+ prefs_->OnExtensionInstalled(extension); |
+ return extension; |
+} |
+ |
+std::string TestExtensionPrefs::AddExtensionAndReturnId(std::string name) { |
+ scoped_ptr<Extension> extension(AddExtension(name)); |
+ return extension->id(); |
+} |
Property changes on: chrome/browser/extensions/test_extension_prefs.cc |
___________________________________________________________________ |
Name: svn:eol-style |
+ LF |