summaryrefslogtreecommitdiffstats
path: root/chrome/common/extensions/extension_action_unittest.cc
diff options
context:
space:
mode:
authoraa@chromium.org <aa@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2009-10-27 06:17:57 +0000
committeraa@chromium.org <aa@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2009-10-27 06:17:57 +0000
commit5d246db2292523a348d975ca9d65e786389df14f (patch)
tree9d4b515b7bc8516872fc7fb6fdbe9e715843475a /chrome/common/extensions/extension_action_unittest.cc
parent7dc7f0329728dd9d0e11655652a6ec231cb1065d (diff)
downloadchromium_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.cc137
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));
+}