Chromium Code Reviews| 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/common/extensions/api/extension_action/action_info.h" | |
| 6 #include "chrome/common/extensions/api/extension_action/script_badge_handler.h" | |
| 5 #include "chrome/common/extensions/extension_builder.h" | 7 #include "chrome/common/extensions/extension_builder.h" |
| 6 #include "chrome/common/extensions/extension_constants.h" | 8 #include "chrome/common/extensions/extension_constants.h" |
| 7 #include "chrome/common/extensions/extension_icon_set.h" | 9 #include "chrome/common/extensions/extension_icon_set.h" |
| 8 #include "chrome/common/extensions/extension_manifest_constants.h" | 10 #include "chrome/common/extensions/extension_manifest_constants.h" |
| 9 #include "chrome/common/extensions/manifest_tests/extension_manifest_test.h" | 11 #include "chrome/common/extensions/manifest_tests/extension_manifest_test.h" |
| 12 #include "chrome/test/base/testing_profile.h" | |
| 10 #include "testing/gmock/include/gmock/gmock.h" | 13 #include "testing/gmock/include/gmock/gmock.h" |
| 11 #include "testing/gtest/include/gtest/gtest.h" | 14 #include "testing/gtest/include/gtest/gtest.h" |
| 12 | 15 |
| 13 namespace errors = extension_manifest_errors; | 16 namespace errors = extension_manifest_errors; |
| 14 using extensions::DictionaryBuilder; | |
| 15 using extensions::Extension; | |
| 16 using extensions::ExtensionBuilder; | |
| 17 | 17 |
| 18 namespace { | 18 namespace extensions { |
| 19 | 19 |
| 20 std::vector<Extension::InstallWarning> StripMissingFlagWarning( | 20 std::vector<Extension::InstallWarning> StripMissingFlagWarning( |
| 21 const std::vector<Extension::InstallWarning>& install_warnings) { | 21 const std::vector<Extension::InstallWarning>& install_warnings) { |
| 22 std::vector<Extension::InstallWarning> result; | 22 std::vector<Extension::InstallWarning> result; |
| 23 for (size_t i = 0; i < install_warnings.size(); ++i) { | 23 for (size_t i = 0; i < install_warnings.size(); ++i) { |
| 24 if (install_warnings[i].message != errors::kScriptBadgeRequiresFlag) | 24 if (install_warnings[i].message != errors::kScriptBadgeRequiresFlag) |
| 25 result.push_back(install_warnings[i]); | 25 result.push_back(install_warnings[i]); |
| 26 } | 26 } |
| 27 return result; | 27 return result; |
| 28 } | 28 } |
| 29 | 29 |
| 30 TEST_F(ExtensionManifestTest, ScriptBadgeBasic) { | 30 TEST_F(ExtensionManifestTest, ScriptBadgeBasic) { |
| 31 // We need to make a profile so that the ProfileKeyedServices (some of which | |
| 32 // are used in manifest-parsing) are initialized. | |
|
Yoyo Zhou
2012/12/18 02:01:41
It would be preferable to just register the manife
Devlin
2012/12/18 20:42:07
File has been moved and ScriptBadgeManifestTest::S
Yoyo Zhou
2012/12/19 01:38:50
I think it's okay to make unit tests explicitly re
| |
| 33 scoped_ptr<TestingProfile> profile(new TestingProfile()); | |
| 34 | |
| 31 scoped_refptr<Extension> extension( | 35 scoped_refptr<Extension> extension( |
| 32 ExtensionBuilder() | 36 ExtensionBuilder() |
| 33 .SetManifest(DictionaryBuilder() | 37 .SetManifest(DictionaryBuilder() |
| 34 .Set("manifest_version", 2) | 38 .Set("manifest_version", 2) |
| 35 .Set("name", "my extension") | 39 .Set("name", "my extension") |
| 36 .Set("version", "1.0.0.0") | 40 .Set("version", "1.0.0.0") |
| 37 .Set("description", | 41 .Set("description", |
| 38 "Check that a simple script_badge section parses") | 42 "Check that a simple script_badge section parses") |
| 39 .Set("icons", DictionaryBuilder() | 43 .Set("icons", DictionaryBuilder() |
| 40 .Set("16", "icon16.png") | 44 .Set("16", "icon16.png") |
| 41 .Set("32", "icon32.png") | 45 .Set("32", "icon32.png") |
| 42 .Set("19", "icon19.png") | 46 .Set("19", "icon19.png") |
| 43 .Set("48", "icon48.png")) | 47 .Set("48", "icon48.png")) |
| 44 .Set("script_badge", DictionaryBuilder() | 48 .Set("script_badge", DictionaryBuilder() |
| 45 .Set("default_popup", "popup.html"))) | 49 .Set("default_popup", "popup.html"))) |
| 46 .Build()); | 50 .Build()); |
| 47 ASSERT_TRUE(extension.get()); | 51 ASSERT_TRUE(extension.get()); |
| 48 ASSERT_TRUE(extension->script_badge_info()); | 52 const ActionInfo* script_badge_info = |
| 53 ScriptBadgeInfo::GetScriptBadge(extension); | |
| 54 ASSERT_TRUE(script_badge_info); | |
| 49 EXPECT_THAT(StripMissingFlagWarning(extension->install_warnings()), | 55 EXPECT_THAT(StripMissingFlagWarning(extension->install_warnings()), |
| 50 testing::ElementsAre(/*empty*/)); | 56 testing::ElementsAre(/*empty*/)); |
| 51 | 57 |
| 52 const ExtensionIconSet& default_icon = | 58 const ExtensionIconSet& default_icon = |
| 53 extension->script_badge_info()->default_icon; | 59 script_badge_info->default_icon; |
| 54 // Should have a default icon set. | 60 // Should have a default icon set. |
| 55 ASSERT_FALSE(default_icon.empty()); | 61 ASSERT_FALSE(default_icon.empty()); |
| 56 | 62 |
| 57 // Verify that correct icon paths are registered in default_icon. | 63 // Verify that correct icon paths are registered in default_icon. |
| 58 EXPECT_EQ(2u, default_icon.map().size()); | 64 EXPECT_EQ(2u, default_icon.map().size()); |
| 59 EXPECT_EQ("icon16.png", | 65 EXPECT_EQ("icon16.png", |
| 60 default_icon.Get(extension_misc::EXTENSION_ICON_BITTY, | 66 default_icon.Get(extension_misc::EXTENSION_ICON_BITTY, |
| 61 ExtensionIconSet::MATCH_EXACTLY)); | 67 ExtensionIconSet::MATCH_EXACTLY)); |
| 62 EXPECT_EQ("icon32.png", | 68 EXPECT_EQ("icon32.png", |
| 63 default_icon.Get(2 * extension_misc::EXTENSION_ICON_BITTY, | 69 default_icon.Get(2 * extension_misc::EXTENSION_ICON_BITTY, |
| 64 ExtensionIconSet::MATCH_EXACTLY)); | 70 ExtensionIconSet::MATCH_EXACTLY)); |
| 65 | 71 |
| 66 EXPECT_EQ("my extension", extension->script_badge_info()->default_title); | 72 EXPECT_EQ("my extension", script_badge_info->default_title); |
| 67 EXPECT_FALSE(extension->script_badge_info()->default_popup_url.is_empty()); | 73 EXPECT_FALSE(script_badge_info->default_popup_url.is_empty()); |
| 68 } | 74 } |
| 69 | 75 |
| 70 TEST_F(ExtensionManifestTest, ScriptBadgeExplicitTitleAndIconsIgnored) { | 76 TEST_F(ExtensionManifestTest, ScriptBadgeExplicitTitleAndIconsIgnored) { |
| 77 // We need to make a profile so that the ProfileKeyedServices (some of which | |
| 78 // are used in manifest-parsing) are initialized. | |
| 79 scoped_ptr<TestingProfile> profile(new TestingProfile()); | |
| 80 | |
| 71 scoped_refptr<Extension> extension( | 81 scoped_refptr<Extension> extension( |
| 72 ExtensionBuilder() | 82 ExtensionBuilder() |
| 73 .SetManifest(DictionaryBuilder() | 83 .SetManifest(DictionaryBuilder() |
| 74 .Set("manifest_version", 2) | 84 .Set("manifest_version", 2) |
| 75 .Set("name", "my extension") | 85 .Set("name", "my extension") |
| 76 .Set("version", "1.0.0.0") | 86 .Set("version", "1.0.0.0") |
| 77 .Set("description", | 87 .Set("description", |
| 78 "Check that a simple script_badge section parses") | 88 "Check that a simple script_badge section parses") |
| 79 .Set("icons", DictionaryBuilder() | 89 .Set("icons", DictionaryBuilder() |
| 80 .Set("16", "icon16.png")) | 90 .Set("16", "icon16.png")) |
| 81 .Set("script_badge", DictionaryBuilder() | 91 .Set("script_badge", DictionaryBuilder() |
| 82 .Set("default_title", "Other Extension") | 92 .Set("default_title", "Other Extension") |
| 83 .Set("default_icon", "malicious.png"))) | 93 .Set("default_icon", "malicious.png"))) |
| 84 .Build()); | 94 .Build()); |
| 85 ASSERT_TRUE(extension.get()); | 95 ASSERT_TRUE(extension.get()); |
| 86 ASSERT_TRUE(extension->script_badge_info()); | 96 const ActionInfo* script_badge_info = |
| 97 ScriptBadgeInfo::GetScriptBadge(extension); | |
| 98 ASSERT_TRUE(script_badge_info); | |
| 87 | 99 |
| 88 EXPECT_THAT(StripMissingFlagWarning(extension->install_warnings()), | 100 EXPECT_THAT(StripMissingFlagWarning(extension->install_warnings()), |
| 89 testing::ElementsAre( | 101 testing::ElementsAre( |
| 90 Extension::InstallWarning( | 102 Extension::InstallWarning( |
| 91 Extension::InstallWarning::FORMAT_TEXT, | 103 Extension::InstallWarning::FORMAT_TEXT, |
| 92 errors::kScriptBadgeTitleIgnored), | 104 errors::kScriptBadgeTitleIgnored), |
| 93 Extension::InstallWarning( | 105 Extension::InstallWarning( |
| 94 Extension::InstallWarning::FORMAT_TEXT, | 106 Extension::InstallWarning::FORMAT_TEXT, |
| 95 errors::kScriptBadgeIconIgnored))); | 107 errors::kScriptBadgeIconIgnored))); |
| 96 | 108 |
| 97 const ExtensionIconSet& default_icon = | 109 const ExtensionIconSet& default_icon = |
| 98 extension->script_badge_info()->default_icon; | 110 script_badge_info->default_icon; |
| 99 ASSERT_FALSE(default_icon.empty()); | 111 ASSERT_FALSE(default_icon.empty()); |
| 100 | 112 |
| 101 EXPECT_EQ(1u, default_icon.map().size()); | 113 EXPECT_EQ(1u, default_icon.map().size()); |
| 102 EXPECT_EQ("icon16.png", | 114 EXPECT_EQ("icon16.png", |
| 103 default_icon.Get(extension_misc::EXTENSION_ICON_BITTY, | 115 default_icon.Get(extension_misc::EXTENSION_ICON_BITTY, |
| 104 ExtensionIconSet::MATCH_EXACTLY)); | 116 ExtensionIconSet::MATCH_EXACTLY)); |
| 105 | 117 |
| 106 EXPECT_EQ("my extension", extension->script_badge_info()->default_title); | 118 EXPECT_EQ("my extension", script_badge_info->default_title); |
| 107 } | 119 } |
| 108 | 120 |
| 109 TEST_F(ExtensionManifestTest, ScriptBadgeIconFallsBackToPuzzlePiece) { | 121 TEST_F(ExtensionManifestTest, ScriptBadgeIconFallsBackToPuzzlePiece) { |
| 122 // We need to make a profile so that the ProfileKeyedServices (some of which | |
| 123 // are used in manifest-parsing) are initialized. | |
| 124 scoped_ptr<TestingProfile> profile(new TestingProfile()); | |
| 125 | |
| 110 scoped_refptr<Extension> extension( | 126 scoped_refptr<Extension> extension( |
| 111 ExtensionBuilder() | 127 ExtensionBuilder() |
| 112 .SetManifest(DictionaryBuilder() | 128 .SetManifest(DictionaryBuilder() |
| 113 .Set("manifest_version", 2) | 129 .Set("manifest_version", 2) |
| 114 .Set("name", "my extension") | 130 .Set("name", "my extension") |
| 115 .Set("version", "1.0.0.0") | 131 .Set("version", "1.0.0.0") |
| 116 .Set("description", | 132 .Set("description", |
| 117 "Check that a simple script_badge section parses") | 133 "Check that a simple script_badge section parses") |
| 118 .Set("icons", DictionaryBuilder() | 134 .Set("icons", DictionaryBuilder() |
| 119 .Set("128", "icon128.png"))) | 135 .Set("128", "icon128.png"))) |
| 120 .Build()); | 136 .Build()); |
| 121 ASSERT_TRUE(extension.get()); | 137 ASSERT_TRUE(extension.get()); |
| 122 ASSERT_TRUE(extension->script_badge_info()); | 138 const ActionInfo* script_badge_info = |
| 139 ScriptBadgeInfo::GetScriptBadge(extension); | |
| 140 ASSERT_TRUE(script_badge_info); | |
| 123 EXPECT_THAT(extension->install_warnings(), | 141 EXPECT_THAT(extension->install_warnings(), |
| 124 testing::ElementsAre(/*empty*/)); | 142 testing::ElementsAre(/*empty*/)); |
| 125 | 143 |
| 126 const ExtensionIconSet& default_icon = | 144 const ExtensionIconSet& default_icon = |
| 127 extension->script_badge_info()->default_icon; | 145 script_badge_info->default_icon; |
| 128 ASSERT_FALSE(default_icon.empty()) << "Should fall back to the 128px icon."; | 146 ASSERT_FALSE(default_icon.empty()) << "Should fall back to the 128px icon."; |
| 129 EXPECT_EQ(2u, default_icon.map().size()); | 147 EXPECT_EQ(2u, default_icon.map().size()); |
| 130 EXPECT_EQ("icon128.png", | 148 EXPECT_EQ("icon128.png", |
| 131 default_icon.Get(extension_misc::EXTENSION_ICON_BITTY, | 149 default_icon.Get(extension_misc::EXTENSION_ICON_BITTY, |
| 132 ExtensionIconSet::MATCH_EXACTLY)); | 150 ExtensionIconSet::MATCH_EXACTLY)); |
| 133 EXPECT_EQ("icon128.png", | 151 EXPECT_EQ("icon128.png", |
| 134 default_icon.Get(2 * extension_misc::EXTENSION_ICON_BITTY, | 152 default_icon.Get(2 * extension_misc::EXTENSION_ICON_BITTY, |
| 135 ExtensionIconSet::MATCH_EXACTLY)); | 153 ExtensionIconSet::MATCH_EXACTLY)); |
| 136 } | 154 } |
| 137 | 155 |
| 138 } // namespace | 156 } // namespace extensions |
| OLD | NEW |