| 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());
 | 
| +}
 | 
| 
 |