summaryrefslogtreecommitdiffstats
path: root/content/common/plugin_list_unittest.cc
diff options
context:
space:
mode:
Diffstat (limited to 'content/common/plugin_list_unittest.cc')
-rw-r--r--content/common/plugin_list_unittest.cc204
1 files changed, 204 insertions, 0 deletions
diff --git a/content/common/plugin_list_unittest.cc b/content/common/plugin_list_unittest.cc
new file mode 100644
index 0000000..e38a687
--- /dev/null
+++ b/content/common/plugin_list_unittest.cc
@@ -0,0 +1,204 @@
+// Copyright (c) 2012 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 "content/common/plugin_list.h"
+
+#include "base/strings/string16.h"
+#include "base/strings/utf_string_conversions.h"
+#include "testing/gtest/include/gtest/gtest.h"
+
+using webkit::WebPluginInfo;
+using webkit::WebPluginMimeType;
+
+namespace content {
+
+namespace {
+
+bool Equals(const WebPluginInfo& a, const WebPluginInfo& b) {
+ return (a.name == b.name &&
+ a.path == b.path &&
+ a.version == b.version &&
+ a.desc == b.desc);
+}
+
+bool Contains(const std::vector<WebPluginInfo>& list,
+ const WebPluginInfo& plugin) {
+ for (std::vector<WebPluginInfo>::const_iterator it = list.begin();
+ it != list.end(); ++it) {
+ if (Equals(*it, plugin))
+ return true;
+ }
+ return false;
+}
+
+} // namespace
+
+// Linux Aura and Android don't support NPAPI.
+#if defined(OS_WIN) || defined(OS_MACOSX) || (defined(OS_LINUX) && !defined(USE_AURA))
+
+base::FilePath::CharType kFooPath[] = FILE_PATH_LITERAL("/plugins/foo.plugin");
+base::FilePath::CharType kBarPath[] = FILE_PATH_LITERAL("/plugins/bar.plugin");
+const char* kFooName = "Foo Plugin";
+
+class PluginListTest : public testing::Test {
+ public:
+ PluginListTest()
+ : foo_plugin_(ASCIIToUTF16(kFooName),
+ base::FilePath(kFooPath),
+ ASCIIToUTF16("1.2.3"),
+ ASCIIToUTF16("foo")),
+ bar_plugin_(ASCIIToUTF16("Bar Plugin"),
+ base::FilePath(kBarPath),
+ ASCIIToUTF16("2.3.4"),
+ ASCIIToUTF16("bar")) {
+ }
+
+ virtual void SetUp() {
+ plugin_list_.DisablePluginsDiscovery();
+ plugin_list_.RegisterInternalPlugin(bar_plugin_, false);
+ plugin_list_.RegisterInternalPlugin(foo_plugin_, false);
+ }
+
+ protected:
+ PluginList plugin_list_;
+ WebPluginInfo foo_plugin_;
+ WebPluginInfo bar_plugin_;
+};
+
+TEST_F(PluginListTest, GetPlugins) {
+ std::vector<WebPluginInfo> plugins;
+ plugin_list_.GetPlugins(&plugins);
+ EXPECT_EQ(2u, plugins.size());
+ EXPECT_TRUE(Contains(plugins, foo_plugin_));
+ EXPECT_TRUE(Contains(plugins, bar_plugin_));
+}
+
+TEST_F(PluginListTest, BadPluginDescription) {
+ WebPluginInfo plugin_3043(
+ base::string16(), base::FilePath(FILE_PATH_LITERAL("/myplugin.3.0.43")),
+ base::string16(), base::string16());
+ // Simulate loading of the plugins.
+ plugin_list_.RegisterInternalPlugin(plugin_3043, false);
+ // Now we should have them in the state we specified above.
+ plugin_list_.RefreshPlugins();
+ std::vector<WebPluginInfo> plugins;
+ plugin_list_.GetPlugins(&plugins);
+ ASSERT_TRUE(Contains(plugins, plugin_3043));
+}
+
+#endif
+
+#if defined(OS_POSIX) && !defined(OS_MACOSX)
+
+// Test parsing a simple description: Real Audio.
+TEST(MIMEDescriptionParse, Simple) {
+ std::vector<WebPluginMimeType> types;
+ PluginList::ParseMIMEDescription(
+ "audio/x-pn-realaudio-plugin:rpm:RealAudio document;",
+ &types);
+ ASSERT_EQ(1U, types.size());
+ const WebPluginMimeType& type = types[0];
+ EXPECT_EQ("audio/x-pn-realaudio-plugin", type.mime_type);
+ ASSERT_EQ(1U, type.file_extensions.size());
+ EXPECT_EQ("rpm", type.file_extensions[0]);
+ EXPECT_EQ(ASCIIToUTF16("RealAudio document"), type.description);
+}
+
+// Test parsing a multi-entry description: QuickTime as provided by Totem.
+TEST(MIMEDescriptionParse, Multi) {
+ std::vector<WebPluginMimeType> types;
+ PluginList::ParseMIMEDescription(
+ "video/quicktime:mov:QuickTime video;video/mp4:mp4:MPEG-4 "
+ "video;image/x-macpaint:pntg:MacPaint Bitmap image;image/x"
+ "-quicktime:pict, pict1, pict2:QuickTime image;video/x-m4v"
+ ":m4v:MPEG-4 video;",
+ &types);
+
+ ASSERT_EQ(5U, types.size());
+
+ // Check the x-quicktime one, since it looks tricky with spaces in the
+ // extension list.
+ const WebPluginMimeType& type = types[3];
+ EXPECT_EQ("image/x-quicktime", type.mime_type);
+ ASSERT_EQ(3U, type.file_extensions.size());
+ EXPECT_EQ("pict2", type.file_extensions[2]);
+ EXPECT_EQ(ASCIIToUTF16("QuickTime image"), type.description);
+}
+
+// Test parsing a Japanese description, since we got this wrong in the past.
+// This comes from loading Totem with LANG=ja_JP.UTF-8.
+TEST(MIMEDescriptionParse, JapaneseUTF8) {
+ std::vector<WebPluginMimeType> types;
+ PluginList::ParseMIMEDescription(
+ "audio/x-ogg:ogg:Ogg \xe3\x82\xaa\xe3\x83\xbc\xe3\x83\x87"
+ "\xe3\x82\xa3\xe3\x83\xaa",
+ &types);
+
+ ASSERT_EQ(1U, types.size());
+ // Check we got the right number of Unicode characters out of the parse.
+ EXPECT_EQ(9U, types[0].description.size());
+}
+
+// Test that we handle corner cases gracefully.
+TEST(MIMEDescriptionParse, CornerCases) {
+ std::vector<WebPluginMimeType> types;
+ PluginList::ParseMIMEDescription("mime/type:", &types);
+ EXPECT_TRUE(types.empty());
+
+ types.clear();
+ PluginList::ParseMIMEDescription("mime/type:ext1:", &types);
+ ASSERT_EQ(1U, types.size());
+ EXPECT_EQ("mime/type", types[0].mime_type);
+ EXPECT_EQ(1U, types[0].file_extensions.size());
+ EXPECT_EQ("ext1", types[0].file_extensions[0]);
+ EXPECT_EQ(base::string16(), types[0].description);
+}
+
+// This Java plugin has embedded semicolons in the mime type.
+TEST(MIMEDescriptionParse, ComplicatedJava) {
+ std::vector<WebPluginMimeType> types;
+ PluginList::ParseMIMEDescription(
+ "application/x-java-vm:class,jar:IcedTea;application/x-java"
+ "-applet:class,jar:IcedTea;application/x-java-applet;versio"
+ "n=1.1:class,jar:IcedTea;application/x-java-applet;version="
+ "1.1.1:class,jar:IcedTea;application/x-java-applet;version="
+ "1.1.2:class,jar:IcedTea;application/x-java-applet;version="
+ "1.1.3:class,jar:IcedTea;application/x-java-applet;version="
+ "1.2:class,jar:IcedTea;application/x-java-applet;version=1."
+ "2.1:class,jar:IcedTea;application/x-java-applet;version=1."
+ "2.2:class,jar:IcedTea;application/x-java-applet;version=1."
+ "3:class,jar:IcedTea;application/x-java-applet;version=1.3."
+ "1:class,jar:IcedTea;application/x-java-applet;version=1.4:"
+ "class,jar:IcedTea",
+ &types);
+
+ ASSERT_EQ(12U, types.size());
+ for (size_t i = 0; i < types.size(); ++i)
+ EXPECT_EQ(ASCIIToUTF16("IcedTea"), types[i].description);
+
+ // Verify that the mime types with semis are coming through ok.
+ EXPECT_TRUE(types[4].mime_type.find(';') != std::string::npos);
+}
+
+// Make sure we understand how to get the version numbers for common Linux
+// plug-ins.
+TEST(PluginDescriptionParse, ExtractVersion) {
+ WebPluginInfo info;
+ PluginList::ExtractVersionString("Shockwave Flash 10.1 r102", &info);
+ EXPECT_EQ(ASCIIToUTF16("10.1 r102"), info.version);
+ PluginList::ExtractVersionString("Java(TM) Plug-in 1.6.0_22", &info);
+ EXPECT_EQ(ASCIIToUTF16("1.6.0_22"), info.version);
+ // It's actually much more likely for a modern Linux distribution to have
+ // IcedTea.
+ PluginList::ExtractVersionString(
+ "IcedTea-Web Plugin "
+ "(using IcedTea-Web 1.2 (1.2-2ubuntu0.10.04.2))",
+ &info);
+ EXPECT_EQ(ASCIIToUTF16("1.2"), info.version);
+}
+
+#endif // defined(OS_POSIX) && !defined(OS_MACOSX)
+
+
+} // namespace content