Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(221)

Unified Diff: webkit/glue/plugins/plugin_group_unittest.cc

Issue 5783005: PluginList: Unit tests and bugfixes (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: address comments; rebase Created 10 years ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
Index: webkit/glue/plugins/plugin_group_unittest.cc
diff --git a/webkit/glue/plugins/plugin_group_unittest.cc b/webkit/glue/plugins/plugin_group_unittest.cc
index 044c7c781a73b369f9fdf30d106c3d14a6b81f59..946bf18d8a288d65ba972a4c6410c371ebec7716 100644
--- a/webkit/glue/plugins/plugin_group_unittest.cc
+++ b/webkit/glue/plugins/plugin_group_unittest.cc
@@ -27,21 +27,21 @@ static const VersionRangeDefinition kPlugin4VersionRange[] = {
};
static const VersionRangeDefinition kPlugin34VersionRange[] = {
{ "0", "4", "3.0.44" },
- { "4", "5", "4.0.44" }
+ { "4", "5", "" }
};
static const PluginGroupDefinition kPluginDef = {
- "myplugin", "MyPlugin", "MyPlugin", kPluginVersionRange, 1,
- "http://latest/" };
+ "myplugin", "MyPlugin", "MyPlugin", kPluginVersionRange,
+ arraysize(kPluginVersionRange), "http://latest/" };
static const PluginGroupDefinition kPluginDef3 = {
- "myplugin-3", "MyPlugin 3", "MyPlugin", kPlugin3VersionRange, 1,
- "http://latest" };
+ "myplugin-3", "MyPlugin 3", "MyPlugin", kPlugin3VersionRange,
+ arraysize(kPlugin3VersionRange), "http://latest" };
static const PluginGroupDefinition kPluginDef4 = {
- "myplugin-4", "MyPlugin 4", "MyPlugin", kPlugin4VersionRange, 1,
- "http://latest" };
+ "myplugin-4", "MyPlugin 4", "MyPlugin", kPlugin4VersionRange,
+ arraysize(kPlugin4VersionRange), "http://latest" };
static const PluginGroupDefinition kPluginDef34 = {
- "myplugin-34", "MyPlugin 3/4", "MyPlugin", kPlugin34VersionRange, 2,
- "http://latest" };
+ "myplugin-34", "MyPlugin 3/4", "MyPlugin", kPlugin34VersionRange,
+ arraysize(kPlugin34VersionRange), "http://latest" };
static const PluginGroupDefinition kPluginDefNotVulnerable = {
"myplugin-latest", "MyPlugin", "MyPlugin", NULL, 0, "http://latest" };
@@ -107,8 +107,9 @@ TEST(PluginGroupTest, PluginGroupDescription) {
string16 desc3043(ASCIIToUTF16("MyPlugin version 3.0.43"));
string16 desc3045(ASCIIToUTF16("MyPlugin version 3.0.45"));
- PluginGroupDefinition plugindefs[] = { kPluginDef3, kPluginDef34 };
- for (size_t i = 0; i < 2; ++i) {
+ PluginGroupDefinition plugindefs[] =
+ { kPluginDef, kPluginDef3, kPluginDef34 };
+ for (size_t i = 0; i < arraysize(plugindefs); ++i) {
WebPluginInfo plugin3043(kPlugin3043);
WebPluginInfo plugin3045(kPlugin3045);
{
@@ -170,23 +171,6 @@ TEST(PluginGroupTest, PluginGroupDefinition) {
}
}
-TEST(PluginGroupTest, DisableOutdated) {
- PluginGroupDefinition plugindefs[] = { kPluginDef3, kPluginDef34 };
- for (size_t i = 0; i < 2; ++i) {
- scoped_ptr<PluginGroup> group(PluginGroupTest::CreatePluginGroup(
- plugindefs[i]));
- group->AddPlugin(kPlugin3043, 0, NULL);
- group->AddPlugin(kPlugin3045, 1, NULL);
-
- EXPECT_EQ(ASCIIToUTF16("MyPlugin version 3.0.43"), group->description());
- EXPECT_TRUE(group->IsVulnerable());
-
- group->DisableOutdatedPlugins();
- EXPECT_EQ(ASCIIToUTF16("MyPlugin version 3.0.45"), group->description());
- EXPECT_FALSE(group->IsVulnerable());
- }
-}
-
TEST(PluginGroupTest, VersionExtraction) {
// Some real-world plugin versions (spaces, commata, parentheses, 'r', oh my)
const char* versions[][2] = {
@@ -224,3 +208,42 @@ TEST(PluginGroupTest, DisabledByPolicy) {
EXPECT_TRUE(PluginGroup::IsPluginNameDisabledByPolicy(
ASCIIToUTF16("Google Earth")));
}
+
+TEST(PluginGroupTest, IsVulnerable) {
+ // Adobe Reader 10
+ VersionRangeDefinition adobe_reader_version_range[] = {
+ { "10", "11", "" },
+ { "9", "10", "9.4.1" },
+ { "0", "9", "8.2.5" }
+ };
+ PluginGroupDefinition adobe_reader_plugin_def = {
+ "adobe-reader", "Adobe Reader", "Adobe Acrobat",
+ adobe_reader_version_range, arraysize(adobe_reader_version_range),
+ "http://get.adobe.com/reader/" };
+ WebPluginInfo adobe_reader_plugin(ASCIIToUTF16("Adobe Reader"),
+ FilePath(FILE_PATH_LITERAL("/reader.so")),
+ ASCIIToUTF16("10.0.0.396"),
+ ASCIIToUTF16("adobe reader 10"));
+ scoped_ptr<PluginGroup> group(PluginGroupTest::CreatePluginGroup(
+ adobe_reader_plugin_def));
+ group->AddPlugin(adobe_reader_plugin, 0, NULL);
+ PluginGroup group_copy(*group); // Exercise the copy constructor.
+ EXPECT_FALSE(group_copy.IsVulnerable());
+
+ // Silverlight 4
+ VersionRangeDefinition silverlight_version_range[] = {
+ { "0", "4", "3.0.50106.0" },
+ { "4", "5", "" }
+ };
+ PluginGroupDefinition silverlight_plugin_def = {
+ "silverlight", "Silverlight", "Silverlight", silverlight_version_range,
+ arraysize(silverlight_version_range),
+ "http://www.microsoft.com/getsilverlight/" };
+ WebPluginInfo silverlight_plugin(ASCIIToUTF16("Silverlight"),
+ FilePath(FILE_PATH_LITERAL("/silver.so")),
+ ASCIIToUTF16("4.0.50917.0"),
+ ASCIIToUTF16("silverlight 4"));
+ group.reset(PluginGroupTest::CreatePluginGroup(silverlight_plugin_def));
+ group->AddPlugin(silverlight_plugin, 0, NULL);
+ EXPECT_FALSE(PluginGroup(*group).IsVulnerable());
+}

Powered by Google App Engine
This is Rietveld 408576698