Index: chrome/browser/extensions/extension_prefs_unittest.cc |
diff --git a/chrome/browser/extensions/extension_prefs_unittest.cc b/chrome/browser/extensions/extension_prefs_unittest.cc |
index c8d1967a70a3efd26e5eb88d3d55f62c1198e218..325ca9139bbd5e4b49279fd8eb7f3008cdb7f989 100644 |
--- a/chrome/browser/extensions/extension_prefs_unittest.cc |
+++ b/chrome/browser/extensions/extension_prefs_unittest.cc |
@@ -10,9 +10,14 @@ |
#include "chrome/browser/browser_thread.h" |
#include "chrome/browser/extensions/extension_prefs.h" |
#include "chrome/browser/extensions/test_extension_prefs.h" |
+#include "chrome/browser/prefs/pref_change_registrar.h" |
#include "chrome/browser/prefs/pref_service.h" |
#include "chrome/common/chrome_paths.h" |
#include "chrome/common/extensions/extension_constants.h" |
+#include "chrome/common/notification_details.h" |
+#include "chrome/common/notification_source.h" |
+#include "chrome/common/notification_type.h" |
+#include "testing/gmock/include/gmock/gmock.h" |
#include "testing/gtest/include/gtest/gtest.h" |
using base::Time; |
@@ -32,7 +37,11 @@ class ExtensionPrefsTest : public testing::Test { |
// things don't break after any ExtensionPrefs startup work. |
virtual void Verify() = 0; |
+ // This function is called to Register preference default values. |
+ virtual void RegisterPreferences() {} |
+ |
virtual void SetUp() { |
+ RegisterPreferences(); |
Initialize(); |
} |
@@ -41,6 +50,7 @@ class ExtensionPrefsTest : public testing::Test { |
// Reset ExtensionPrefs, and re-verify. |
prefs_.RecreateExtensionPrefs(); |
+ RegisterPreferences(); |
Verify(); |
} |
@@ -53,6 +63,16 @@ class ExtensionPrefsTest : public testing::Test { |
DISALLOW_COPY_AND_ASSIGN(ExtensionPrefsTest); |
}; |
+// Mock MockObserver that allows the notifications to be tracked. |
+class MockObserver : public NotificationObserver { |
Mattias Nissler (ping if slow)
2010/11/19 10:36:12
Drop this in favor of chrome/test/mock_notificatio
battre (please use the other)
2010/11/19 16:03:18
Done.
|
+ public: |
+ MockObserver() {} |
+ virtual ~MockObserver() {} |
+ MOCK_METHOD3(Observe, void(NotificationType type, |
+ const NotificationSource& source, |
+ const NotificationDetails& details)); |
+}; |
+ |
// Tests the LastPingDay/SetLastPingDay functions. |
class ExtensionPrefsLastPingDay : public ExtensionPrefsTest { |
public: |
@@ -185,6 +205,10 @@ class ExtensionPrefsBlacklist : public ExtensionPrefsTest { |
std::set<std::string> blacklisted_ids; |
blacklisted_ids.insert(extensions_[0]->id()); |
blacklisted_ids.insert(not_installed_id_); |
+ |
+ // TODO(battre) This prints some nasty "Error parsing installation time of |
+ // extension" messages because the extension preferences have incomplete |
+ // dictionaries (they contain only the blacklist-property). |
Mattias Nissler (ping if slow)
2010/11/19 10:36:12
Triggering error messages in unit_tests is a commo
battre (please use the other)
2010/11/19 16:03:18
Done.
|
prefs()->UpdateBlacklist(blacklisted_ids); |
} |
@@ -336,7 +360,7 @@ TEST_F(ExtensionPrefsOnExtensionInstalled, |
ExtensionPrefsOnExtensionInstalled) {} |
class ExtensionPrefsAppLaunchIndex : public ExtensionPrefsTest { |
-public: |
+ public: |
virtual void Initialize() { |
// No extensions yet. |
EXPECT_EQ(0, prefs()->GetNextAppLaunchIndex()); |
@@ -363,7 +387,346 @@ public: |
EXPECT_EQ(-1, prefs()->GetAppLaunchIndex("foo")); |
} |
-private: |
+ private: |
scoped_refptr<Extension> extension_; |
}; |
TEST_F(ExtensionPrefsAppLaunchIndex, ExtensionPrefsAppLaunchIndex) {} |
+ |
+namespace keys = extension_manifest_keys; |
+ |
+// Use constants to avoid confusing std::map with hard-coded strings. |
Mattias Nissler (ping if slow)
2010/11/19 10:36:12
I don't understand? Constants are good, but not fo
battre (please use the other)
2010/11/19 16:03:18
just copy and pasted that comment. I have removed
|
+const char kPref1[] = "path1.subpath"; |
+const char kPref2[] = "path2"; |
+const char kPref3[] = "path3"; |
+const char kPref4[] = "path4"; |
+ |
+// Default values in case an extension pref value is not overridden. |
+const char kDefaultPref1[] = "default pref 1"; |
+const char kDefaultPref2[] = "default pref 2"; |
+const char kDefaultPref3[] = "default pref 3"; |
+const char kDefaultPref4[] = "default pref 4"; |
Mattias Nissler (ping if slow)
2010/11/19 10:36:12
These declarations should be moved to the top of t
battre (please use the other)
2010/11/19 16:03:18
Moved it, but did not find anything in the style g
|
+ |
+class ExtensionPrefsPreferencesBase : public ExtensionPrefsTest { |
+ public: |
+ ExtensionPrefsPreferencesBase() |
+ : ExtensionPrefsTest(), |
+ ext1(NULL), |
+ ext2(NULL), |
+ ext3(NULL), |
+ installed() { |
+ DictionaryValue simple_dict; |
+ std::string error; |
+ |
+ simple_dict.SetString(keys::kVersion, "1.0.0.0"); |
+ simple_dict.SetString(keys::kName, "unused"); |
+ |
+ ext1_scoped_ = Extension::Create( |
+ prefs_.temp_dir().AppendASCII("ext1"), Extension::INVALID, |
+ simple_dict, false, &error); |
+ ext2_scoped_ = Extension::Create( |
+ prefs_.temp_dir().AppendASCII("ext2"), Extension::INVALID, |
+ simple_dict, false, &error); |
+ ext3_scoped_ = Extension::Create( |
+ prefs_.temp_dir().AppendASCII("ext3"), Extension::INVALID, |
+ simple_dict, false, &error); |
+ |
+ ext1 = ext1_scoped_.get(); |
+ ext2 = ext2_scoped_.get(); |
+ ext3 = ext3_scoped_.get(); |
+ |
+ for (size_t i = 0; i < arraysize(installed); ++i) |
+ installed[i] = false; |
+ } |
+ |
+ void RegisterPreferences() { |
+ prefs()->pref_service()->RegisterStringPref(kPref1, kDefaultPref1); |
+ prefs()->pref_service()->RegisterStringPref(kPref2, kDefaultPref2); |
+ prefs()->pref_service()->RegisterStringPref(kPref3, kDefaultPref3); |
+ prefs()->pref_service()->RegisterStringPref(kPref4, kDefaultPref4); |
+ } |
+ |
+ void InstallExtControlledPref(Extension *ext, |
Mattias Nissler (ping if slow)
2010/11/19 10:36:12
Instead of shortening to Ext, why not just Install
battre (please use the other)
2010/11/19 16:03:18
Unfortunately, Extension Preferences have a differ
Mattias Nissler (ping if slow)
2010/11/19 16:52:20
I see.
|
+ const std::string& key, |
+ Value* val) { |
Mattias Nissler (ping if slow)
2010/11/19 10:36:12
fix indentation.
battre (please use the other)
2010/11/19 16:03:18
Done.
Mattias Nissler (ping if slow)
2010/11/19 16:52:20
Not done?
battre (please use the other)
2010/11/19 18:00:39
Done.
|
+ // Install extension the first time a preference is set for it. |
+ Extension* extensions[] = {ext1, ext2, ext3}; |
+ for (int i = 0; i < 3; ++i) { |
+ if (ext == extensions[i] && !installed[i]) { |
+ prefs()->OnExtensionInstalled(ext, Extension::ENABLED, true); |
+ installed[i] = true; |
+ break; |
+ } |
+ } |
+ |
+ prefs()->SetExtensionControlledPref(ext->id(), key, val); |
+ } |
+ |
+ void UninstallExtension(const std::string& extension_id) { |
+ prefs()->OnExtensionUninstalled(extension_id, Extension::INTERNAL, false); |
+ } |
+ |
+ // Weak references, for convenience. |
+ Extension* ext1; |
+ Extension* ext2; |
+ Extension* ext3; |
Mattias Nissler (ping if slow)
2010/11/19 10:36:12
Missing trailing _
battre (please use the other)
2010/11/19 16:03:18
Was just copy&pasted, but changed now.
Done.
Mattias Nissler (ping if slow)
2010/11/19 16:52:20
Not done?
battre (please use the other)
2010/11/19 18:00:39
Done.
|
+ |
+ // Flags indicating whether each of the extensions has been installed, yet. |
+ bool installed[3]; |
+ |
+ private: |
+ scoped_refptr<Extension> ext1_scoped_; |
+ scoped_refptr<Extension> ext2_scoped_; |
+ scoped_refptr<Extension> ext3_scoped_; |
+}; |
+ |
+class ExtensionPrefsInstallOneExtension |
+ : public ExtensionPrefsPreferencesBase { |
+ virtual void Initialize() { |
+ InstallExtControlledPref(ext1, kPref1, Value::CreateStringValue("val1")); |
+ } |
+ virtual void Verify() { |
+ std::string actual = prefs()->pref_service()->GetString(kPref1); |
+ EXPECT_EQ("val1", actual); |
+ } |
+}; |
+TEST_F(ExtensionPrefsInstallOneExtension, ExtensionPrefsInstallOneExtension) {} |
+ |
+// Make sure the last-installed extension wins. |
+class ExtensionPrefsInstallMultipleExtensions |
+ : public ExtensionPrefsPreferencesBase { |
+ virtual void Initialize() { |
+ InstallExtControlledPref(ext1, kPref1, Value::CreateStringValue("val1")); |
+ InstallExtControlledPref(ext2, kPref1, Value::CreateStringValue("val2")); |
+ InstallExtControlledPref(ext3, kPref1, Value::CreateStringValue("val3")); |
+ } |
+ virtual void Verify() { |
+ std::string actual = prefs()->pref_service()->GetString(kPref1); |
+ EXPECT_EQ("val3", actual); |
+ } |
+}; |
+TEST_F(ExtensionPrefsInstallMultipleExtensions, |
+ ExtensionPrefsInstallMultipleExtensions) {} |
+ |
+// Make sure the last-installed extension wins for each preference. |
+class ExtensionPrefsInstallOverwrittenExtensions |
Mattias Nissler (ping if slow)
2010/11/19 10:36:12
I could argue that this test case covers also what
battre (please use the other)
2010/11/19 16:03:18
Done.
Mattias Nissler (ping if slow)
2010/11/19 16:52:20
No change?
battre (please use the other)
2010/11/19 18:00:39
Done.
|
+ : public ExtensionPrefsPreferencesBase { |
+ virtual void Initialize() { |
+ InstallExtControlledPref(ext1, kPref1, Value::CreateStringValue("val1")); |
+ InstallExtControlledPref(ext2, kPref1, Value::CreateStringValue("val2")); |
+ InstallExtControlledPref(ext3, kPref1, Value::CreateStringValue("val3")); |
+ |
+ InstallExtControlledPref(ext1, kPref2, Value::CreateStringValue("val4")); |
+ InstallExtControlledPref(ext2, kPref2, Value::CreateStringValue("val5")); |
+ |
+ InstallExtControlledPref(ext1, kPref1, Value::CreateStringValue("val6")); |
+ InstallExtControlledPref(ext1, kPref2, Value::CreateStringValue("val7")); |
+ InstallExtControlledPref(ext1, kPref3, Value::CreateStringValue("val8")); |
+ } |
+ virtual void Verify() { |
+ std::string actual; |
+ actual = prefs()->pref_service()->GetString(kPref1); |
+ EXPECT_EQ("val3", actual); |
+ actual = prefs()->pref_service()->GetString(kPref2); |
+ EXPECT_EQ("val5", actual); |
+ actual = prefs()->pref_service()->GetString(kPref3); |
+ EXPECT_EQ("val8", actual); |
+ } |
+}; |
+TEST_F(ExtensionPrefsInstallOverwrittenExtensions, |
+ ExtensionPrefsInstallOverwrittenExtensions) {} |
+ |
+// Make sure the last-installed extension wins even if other extensions set |
+// the same or different preferences later. |
+class ExtensionPrefsInstallInterleavedExtensions |
+ : public ExtensionPrefsPreferencesBase { |
+ virtual void Initialize() { |
+ InstallExtControlledPref(ext1, kPref1, Value::CreateStringValue("val1")); |
+ InstallExtControlledPref(ext2, kPref2, Value::CreateStringValue("val2")); |
+ InstallExtControlledPref(ext3, kPref3, Value::CreateStringValue("val3")); |
+ |
+ InstallExtControlledPref(ext3, kPref3, Value::CreateStringValue("val4")); |
+ InstallExtControlledPref(ext2, kPref3, Value::CreateStringValue("val5")); |
+ InstallExtControlledPref(ext1, kPref3, Value::CreateStringValue("val6")); |
+ |
+ InstallExtControlledPref(ext3, kPref1, Value::CreateStringValue("val7")); |
+ } |
+ virtual void Verify() { |
+ std::string actual; |
+ actual = prefs()->pref_service()->GetString(kPref1); |
+ EXPECT_EQ("val7", actual); |
+ actual = prefs()->pref_service()->GetString(kPref2); |
+ EXPECT_EQ("val2", actual); |
+ actual = prefs()->pref_service()->GetString(kPref3); |
+ EXPECT_EQ("val4", actual); |
+ } |
+}; |
+TEST_F(ExtensionPrefsInstallInterleavedExtensions, |
+ ExtensionPrefsInstallInterleavedExtensions) {} |
+ |
+class ExtensionPrefsUninstallOnlyExtension |
+ : public ExtensionPrefsPreferencesBase { |
+ virtual void Initialize() { |
+ InstallExtControlledPref(ext1, kPref1, Value::CreateStringValue("val1")); |
+ InstallExtControlledPref(ext1, kPref2, Value::CreateStringValue("val2")); |
+ |
+ UninstallExtension(ext1->id()); |
+ } |
+ virtual void Verify() { |
+ std::string actual; |
+ actual = prefs()->pref_service()->GetString(kPref1); |
+ EXPECT_EQ(kDefaultPref1, actual); |
+ actual = prefs()->pref_service()->GetString(kPref2); |
+ EXPECT_EQ(kDefaultPref2, actual); |
+ } |
+}; |
+TEST_F(ExtensionPrefsUninstallOnlyExtension, |
+ ExtensionPrefsUninstallOnlyExtension) {} |
+ |
+// Tests uninstalling an extension that wasn't winning for any preferences. |
+class ExtensionPrefsUninstallIrrelevantExtension |
+ : public ExtensionPrefsPreferencesBase { |
+ virtual void Initialize() { |
+ InstallExtControlledPref(ext1, kPref1, Value::CreateStringValue("val1")); |
+ InstallExtControlledPref(ext2, kPref1, Value::CreateStringValue("val2")); |
+ |
+ InstallExtControlledPref(ext1, kPref2, Value::CreateStringValue("val3")); |
+ InstallExtControlledPref(ext2, kPref2, Value::CreateStringValue("val4")); |
+ |
+ UninstallExtension(ext1->id()); |
+ } |
+ virtual void Verify() { |
+ std::string actual; |
+ actual = prefs()->pref_service()->GetString(kPref1); |
+ EXPECT_EQ("val2", actual); |
+ actual = prefs()->pref_service()->GetString(kPref2); |
+ EXPECT_EQ("val4", actual); |
+ } |
+}; |
+TEST_F(ExtensionPrefsUninstallIrrelevantExtension, |
+ ExtensionPrefsUninstallIrrelevantExtension) {} |
+ |
+// Tests uninstalling an extension that was winning for all preferences. |
+class ExtensionPrefsUninstallExtensionFromTop |
+ : public ExtensionPrefsPreferencesBase { |
+ virtual void Initialize() { |
+ InstallExtControlledPref(ext1, kPref1, Value::CreateStringValue("val1")); |
+ InstallExtControlledPref(ext2, kPref1, Value::CreateStringValue("val2")); |
+ InstallExtControlledPref(ext3, kPref1, Value::CreateStringValue("val3")); |
+ |
+ InstallExtControlledPref(ext1, kPref2, Value::CreateStringValue("val4")); |
+ InstallExtControlledPref(ext3, kPref2, Value::CreateStringValue("val5")); |
+ |
+ UninstallExtension(ext3->id()); |
+ } |
+ virtual void Verify() { |
+ std::string actual; |
+ actual = prefs()->pref_service()->GetString(kPref1); |
+ EXPECT_EQ("val2", actual); |
+ actual = prefs()->pref_service()->GetString(kPref2); |
+ EXPECT_EQ("val4", actual); |
+ } |
+}; |
+TEST_F(ExtensionPrefsUninstallExtensionFromTop, |
+ ExtensionPrefsUninstallExtensionFromTop) {} |
+ |
+// Tests uninstalling an extension that was winning for only some preferences. |
+class ExtensionPrefsUninstallExtensionFromMiddle |
+ : public ExtensionPrefsPreferencesBase { |
+ virtual void Initialize() { |
+ InstallExtControlledPref(ext1, kPref1, Value::CreateStringValue("val1")); |
+ InstallExtControlledPref(ext2, kPref1, Value::CreateStringValue("val2")); |
+ InstallExtControlledPref(ext3, kPref1, Value::CreateStringValue("val3")); |
+ |
+ InstallExtControlledPref(ext1, kPref2, Value::CreateStringValue("val4")); |
+ InstallExtControlledPref(ext2, kPref2, Value::CreateStringValue("val5")); |
+ |
+ InstallExtControlledPref(ext1, kPref3, Value::CreateStringValue("val6")); |
+ |
+ InstallExtControlledPref(ext2, kPref4, Value::CreateStringValue("val7")); |
+ |
+ UninstallExtension(ext2->id()); |
+ } |
+ virtual void Verify() { |
+ std::string actual; |
+ actual = prefs()->pref_service()->GetString(kPref1); |
+ EXPECT_EQ("val3", actual); |
+ actual = prefs()->pref_service()->GetString(kPref2); |
+ EXPECT_EQ("val4", actual); |
+ actual = prefs()->pref_service()->GetString(kPref3); |
+ EXPECT_EQ("val6", actual); |
+ actual = prefs()->pref_service()->GetString(kPref4); |
+ EXPECT_EQ(kDefaultPref4, actual); |
+ } |
+}; |
+TEST_F(ExtensionPrefsUninstallExtensionFromMiddle, |
+ ExtensionPrefsUninstallExtensionFromMiddle) {} |
+ |
+// Tests uninstalling an extension that was winning for only some preferences. |
Mattias Nissler (ping if slow)
2010/11/19 10:36:12
Update comment.
battre (please use the other)
2010/11/19 16:03:18
Done.
Mattias Nissler (ping if slow)
2010/11/19 16:52:20
Not done?
battre (please use the other)
2010/11/19 18:00:39
Done.
|
+class ExtensionPrefsNotifyWhenNeeded |
+ : public ExtensionPrefsPreferencesBase { |
+ virtual void Initialize() { |
+ using testing::_; |
+ using testing::Mock; |
+ using testing::StrEq; |
+ |
+ scoped_ptr<MockObserver> observer(new MockObserver()); |
+ PrefChangeRegistrar registrar; |
+ registrar.Init(prefs()->pref_service()); |
+ registrar.Add(kPref1, observer.get()); |
+ |
+ EXPECT_CALL(*observer, Observe(_, _, _)); |
+ InstallExtControlledPref(ext1, kPref1, |
+ Value::CreateStringValue("https://www.chromium.org")); |
+ Mock::VerifyAndClearExpectations(observer.get()); |
+ |
+ EXPECT_CALL(*observer, Observe(_, _, _)).Times(0); |
+ InstallExtControlledPref(ext1, kPref1, |
+ Value::CreateStringValue("https://www.chromium.org")); |
+ Mock::VerifyAndClearExpectations(observer.get()); |
+ |
+ EXPECT_CALL(*observer, Observe(_, _, _)).Times(2); |
+ InstallExtControlledPref(ext1, kPref1, |
+ Value::CreateStringValue("chrome://newtab")); |
+ |
+ UninstallExtension(ext1->id()); |
+ registrar.Remove(kPref1, observer.get()); |
+ } |
+ virtual void Verify() { |
+ std::string actual = prefs()->pref_service()->GetString(kPref1); |
+ EXPECT_EQ(kDefaultPref1, actual); |
+ } |
+}; |
+TEST_F(ExtensionPrefsNotifyWhenNeeded, |
+ ExtensionPrefsNotifyWhenNeeded) {} |
+ |
+// Tests disabling an extension |
+class ExtensionPrefsDisableExt |
+ : public ExtensionPrefsPreferencesBase { |
+ virtual void Initialize() { |
+ InstallExtControlledPref(ext1, kPref1, Value::CreateStringValue("val1")); |
+ std::string actual = prefs()->pref_service()->GetString(kPref1); |
+ EXPECT_EQ("val1", actual); |
+ prefs()->SetExtensionState(ext1, Extension::DISABLED); |
+ } |
+ virtual void Verify() { |
+ std::string actual = prefs()->pref_service()->GetString(kPref1); |
+ EXPECT_EQ(kDefaultPref1, actual); |
+ } |
+}; |
+TEST_F(ExtensionPrefsDisableExt, ExtensionPrefsDisableExt) {} |
+ |
+// Tests disabling and reenabling an extension |
+class ExtensionPrefsReenableExt |
+ : public ExtensionPrefsPreferencesBase { |
+ virtual void Initialize() { |
+ InstallExtControlledPref(ext1, kPref1, Value::CreateStringValue("val1")); |
+ prefs()->SetExtensionState(ext1, Extension::DISABLED); |
+ prefs()->SetExtensionState(ext1, Extension::ENABLED); |
+ } |
+ virtual void Verify() { |
+ std::string actual = prefs()->pref_service()->GetString(kPref1); |
+ EXPECT_EQ("val1", actual); |
+ } |
+}; |
+TEST_F(ExtensionPrefsDisableExt, ExtensionPrefsReenableExt) {} |
+ |
Mattias Nissler (ping if slow)
2010/11/19 10:36:12
No trailing newlines please.
battre (please use the other)
2010/11/19 16:03:18
Hopefully done. Eclipse messes this up.
Mattias Nissler (ping if slow)
2010/11/19 16:52:20
I see, not a big deal :)
However, you should get t
|