| 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 796897afa0cc2d8d8b6c92a6f6281d03b3623a32..ec95ad493f875a1e51e317fc740d01c0c1cf14b8 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);
|
| - group->AddPlugin(kPlugin3045, 1);
|
| -
|
| - 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);
|
| + 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);
|
| + EXPECT_FALSE(PluginGroup(*group).IsVulnerable());
|
| +}
|
|
|