diff options
author | aa@chromium.org <aa@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2009-10-27 06:17:57 +0000 |
---|---|---|
committer | aa@chromium.org <aa@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2009-10-27 06:17:57 +0000 |
commit | 5d246db2292523a348d975ca9d65e786389df14f (patch) | |
tree | 9d4b515b7bc8516872fc7fb6fdbe9e715843475a /chrome/common/extensions/extension_action_unittest.cc | |
parent | 7dc7f0329728dd9d0e11655652a6ec231cb1065d (diff) | |
download | chromium_src-5d246db2292523a348d975ca9d65e786389df14f.zip chromium_src-5d246db2292523a348d975ca9d65e786389df14f.tar.gz chromium_src-5d246db2292523a348d975ca9d65e786389df14f.tar.bz2 |
Replace ExtensionAction with ExtensionAction2.
BUG=24472
Review URL: http://codereview.chromium.org/337035
git-svn-id: svn://svn.chromium.org/chrome/trunk/src@30172 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'chrome/common/extensions/extension_action_unittest.cc')
-rw-r--r-- | chrome/common/extensions/extension_action_unittest.cc | 137 |
1 files changed, 137 insertions, 0 deletions
diff --git a/chrome/common/extensions/extension_action_unittest.cc b/chrome/common/extensions/extension_action_unittest.cc new file mode 100644 index 0000000..d700c33 --- /dev/null +++ b/chrome/common/extensions/extension_action_unittest.cc @@ -0,0 +1,137 @@ +#include "base/file_path.h" +#include "base/file_util.h" +#include "base/path_service.h" +#include "chrome/common/chrome_paths.h" +#include "chrome/common/extensions/extension_action.h" +#include "testing/gtest/include/gtest/gtest.h" +#include "third_party/skia/include/core/SkBitmap.h" +#include "webkit/glue/image_decoder.h" + +static SkBitmap LoadIcon(const std::string& filename) { + FilePath path; + PathService::Get(chrome::DIR_TEST_DATA, &path); + path = path.AppendASCII("extensions").AppendASCII(filename); + + std::string file_contents; + file_util::ReadFileToString(path, &file_contents); + const unsigned char* data = + reinterpret_cast<const unsigned char*>(file_contents.data()); + + SkBitmap bitmap; + webkit_glue::ImageDecoder decoder; + bitmap = decoder.Decode(data, file_contents.length()); + + return bitmap; +} + +static bool BitmapsAreEqual(const SkBitmap& bitmap1, const SkBitmap& bitmap2) { + void* addr1 = NULL; + void* addr2 = NULL; + + bitmap1.lockPixels(); + addr1 = bitmap1.getAddr32(0, 0); + bitmap1.unlockPixels(); + + bitmap2.lockPixels(); + addr2 = bitmap2.getAddr32(0, 0); + bitmap2.unlockPixels(); + + return 0 == memcmp(addr1, addr2, bitmap1.getSize()); +} + +TEST(ExtensionActionTest, TabSpecificState) { + ExtensionAction action; + + // title + ASSERT_EQ("", action.GetTitle(1)); + action.SetTitle(ExtensionAction::kDefaultTabId, "foo"); + ASSERT_EQ("foo", action.GetTitle(1)); + ASSERT_EQ("foo", action.GetTitle(100)); + action.SetTitle(100, "bar"); + ASSERT_EQ("foo", action.GetTitle(1)); + ASSERT_EQ("bar", action.GetTitle(100)); + action.SetTitle(ExtensionAction::kDefaultTabId, "baz"); + ASSERT_EQ("baz", action.GetTitle(1)); + action.ClearAllValuesForTab(100); + ASSERT_EQ("baz", action.GetTitle(100)); + + // icon + SkBitmap icon1 = LoadIcon("icon1.png"); + SkBitmap icon2 = LoadIcon("icon2.png"); + ASSERT_TRUE(action.GetIcon(1).isNull()); + action.SetIcon(ExtensionAction::kDefaultTabId, icon1); + ASSERT_TRUE(BitmapsAreEqual(icon1, action.GetIcon(100))); + action.SetIcon(100, icon2); + ASSERT_TRUE(BitmapsAreEqual(icon1, action.GetIcon(1))); + ASSERT_TRUE(BitmapsAreEqual(icon2, action.GetIcon(100))); + + // icon index + ASSERT_EQ(-1, action.GetIconIndex(1)); + action.icon_paths()->push_back("foo.png"); + action.icon_paths()->push_back("bar.png"); + action.SetIconIndex(ExtensionAction::kDefaultTabId, 1); + ASSERT_EQ(1, action.GetIconIndex(1)); + ASSERT_EQ(1, action.GetIconIndex(100)); + action.SetIconIndex(100, 0); + ASSERT_EQ(0, action.GetIconIndex(100)); + ASSERT_EQ(1, action.GetIconIndex(1)); + action.ClearAllValuesForTab(100); + ASSERT_EQ(1, action.GetIconIndex(100)); + ASSERT_EQ(1, action.GetIconIndex(1)); + + // visibility + ASSERT_EQ(false, action.GetIsVisible(1)); + action.SetIsVisible(ExtensionAction::kDefaultTabId, true); + ASSERT_EQ(true, action.GetIsVisible(1)); + ASSERT_EQ(true, action.GetIsVisible(100)); + action.SetIsVisible(ExtensionAction::kDefaultTabId, false); + ASSERT_EQ(false, action.GetIsVisible(1)); + ASSERT_EQ(false, action.GetIsVisible(100)); + action.SetIsVisible(100, true); + ASSERT_EQ(false, action.GetIsVisible(1)); + ASSERT_EQ(true, action.GetIsVisible(100)); + action.ClearAllValuesForTab(100); + ASSERT_EQ(false, action.GetIsVisible(1)); + ASSERT_EQ(false, action.GetIsVisible(100)); + + // badge text + ASSERT_EQ("", action.GetBadgeText(1)); + action.SetBadgeText(ExtensionAction::kDefaultTabId, "foo"); + ASSERT_EQ("foo", action.GetBadgeText(1)); + ASSERT_EQ("foo", action.GetBadgeText(100)); + action.SetBadgeText(100, "bar"); + ASSERT_EQ("foo", action.GetBadgeText(1)); + ASSERT_EQ("bar", action.GetBadgeText(100)); + action.SetBadgeText(ExtensionAction::kDefaultTabId, "baz"); + ASSERT_EQ("baz", action.GetBadgeText(1)); + action.ClearAllValuesForTab(100); + ASSERT_EQ("baz", action.GetBadgeText(100)); + + // badge text color + ASSERT_EQ(0x00000000u, action.GetBadgeTextColor(1)); + action.SetBadgeTextColor(ExtensionAction::kDefaultTabId, 0xFFFF0000u); + ASSERT_EQ(0xFFFF0000u, action.GetBadgeTextColor(1)); + ASSERT_EQ(0xFFFF0000u, action.GetBadgeTextColor(100)); + action.SetBadgeTextColor(100, 0xFF00FF00); + ASSERT_EQ(0xFFFF0000u, action.GetBadgeTextColor(1)); + ASSERT_EQ(0xFF00FF00u, action.GetBadgeTextColor(100)); + action.SetBadgeTextColor(ExtensionAction::kDefaultTabId, 0xFF0000FFu); + ASSERT_EQ(0xFF0000FFu, action.GetBadgeTextColor(1)); + action.ClearAllValuesForTab(100); + ASSERT_EQ(0xFF0000FFu, action.GetBadgeTextColor(100)); + + // badge background color + ASSERT_EQ(0x00000000u, action.GetBadgeBackgroundColor(1)); + action.SetBadgeBackgroundColor(ExtensionAction::kDefaultTabId, + 0xFFFF0000u); + ASSERT_EQ(0xFFFF0000u, action.GetBadgeBackgroundColor(1)); + ASSERT_EQ(0xFFFF0000u, action.GetBadgeBackgroundColor(100)); + action.SetBadgeBackgroundColor(100, 0xFF00FF00); + ASSERT_EQ(0xFFFF0000u, action.GetBadgeBackgroundColor(1)); + ASSERT_EQ(0xFF00FF00u, action.GetBadgeBackgroundColor(100)); + action.SetBadgeBackgroundColor(ExtensionAction::kDefaultTabId, + 0xFF0000FFu); + ASSERT_EQ(0xFF0000FFu, action.GetBadgeBackgroundColor(1)); + action.ClearAllValuesForTab(100); + ASSERT_EQ(0xFF0000FFu, action.GetBadgeBackgroundColor(100)); +} |