| Index: webkit/plugins/npapi/plugin_group_unittest.cc
|
| diff --git a/webkit/plugins/npapi/plugin_group_unittest.cc b/webkit/plugins/npapi/plugin_group_unittest.cc
|
| index 20332969ac13709dbc1333f3f43f1ab21e514f64..a4f55473d1704171aebf2c9788726c32744a8482 100644
|
| --- a/webkit/plugins/npapi/plugin_group_unittest.cc
|
| +++ b/webkit/plugins/npapi/plugin_group_unittest.cc
|
| @@ -8,128 +8,14 @@
|
| #include <vector>
|
|
|
| #include "base/memory/scoped_ptr.h"
|
| -#include "base/string16.h"
|
| -#include "base/string_util.h"
|
| #include "base/utf_string_conversions.h"
|
| -#include "base/values.h"
|
| #include "base/version.h"
|
| #include "testing/gtest/include/gtest/gtest.h"
|
| -#include "webkit/plugins/webplugininfo.h"
|
|
|
| namespace webkit {
|
| namespace npapi {
|
|
|
| -static const VersionRangeDefinition kPluginVersionRange[] = {
|
| - { "", "", "3.0.44" }
|
| -};
|
| -static const VersionRangeDefinition kPlugin3VersionRange[] = {
|
| - { "0", "4", "3.0.44" }
|
| -};
|
| -static const VersionRangeDefinition kPlugin4VersionRange[] = {
|
| - { "4", "5", "4.0.44" }
|
| -};
|
| -static const VersionRangeDefinition kPlugin34VersionRange[] = {
|
| - { "0", "4", "3.0.44" },
|
| - { "4", "5", "" }
|
| -};
|
| -
|
| -static const PluginGroupDefinition kPluginDef = {
|
| - "myplugin", "MyPlugin", "MyPlugin", kPluginVersionRange,
|
| - arraysize(kPluginVersionRange) };
|
| -static const PluginGroupDefinition kPluginDef3 = {
|
| - "myplugin-3", "MyPlugin 3", "MyPlugin", kPlugin3VersionRange,
|
| - arraysize(kPlugin3VersionRange) };
|
| -static const PluginGroupDefinition kPluginDef4 = {
|
| - "myplugin-4", "MyPlugin 4", "MyPlugin", kPlugin4VersionRange,
|
| - arraysize(kPlugin4VersionRange) };
|
| -static const PluginGroupDefinition kPluginDef34 = {
|
| - "myplugin-34", "MyPlugin 3/4", "MyPlugin", kPlugin34VersionRange,
|
| - arraysize(kPlugin34VersionRange) };
|
| -static const PluginGroupDefinition kPluginDefNotVulnerable = {
|
| - "myplugin-latest", "MyPlugin", "MyPlugin", NULL, 0 };
|
| -
|
| -const PluginGroupDefinition kPluginDefinitions[] = {
|
| - kPluginDef,
|
| - kPluginDef3,
|
| - kPluginDef4,
|
| - kPluginDef34,
|
| - kPluginDefNotVulnerable,
|
| -};
|
| -
|
| -// name, path, version, desc.
|
| -static const WebPluginInfo kPluginNoVersion = WebPluginInfo(
|
| - ASCIIToUTF16("MyPlugin"), FilePath(FILE_PATH_LITERAL("myplugin.so.2.0.43")),
|
| - string16(), ASCIIToUTF16("MyPlugin version 2.0.43"));
|
| -static const WebPluginInfo kPlugin2043 = WebPluginInfo(
|
| - ASCIIToUTF16("MyPlugin"), FilePath(FILE_PATH_LITERAL("myplugin.so.2.0.43")),
|
| - ASCIIToUTF16("2.0.43"), ASCIIToUTF16("MyPlugin version 2.0.43"));
|
| -static const WebPluginInfo kPlugin3043 = WebPluginInfo(
|
| - ASCIIToUTF16("MyPlugin"), FilePath(FILE_PATH_LITERAL("myplugin.so.3.0.43")),
|
| - ASCIIToUTF16("3.0.43"), ASCIIToUTF16("MyPlugin version 3.0.43"));
|
| -static const WebPluginInfo kPlugin3044 = WebPluginInfo(
|
| - ASCIIToUTF16("MyPlugin"), FilePath(FILE_PATH_LITERAL("myplugin.so.3.0.44")),
|
| - ASCIIToUTF16("3.0.44"), ASCIIToUTF16("MyPlugin version 3.0.44"));
|
| -static const WebPluginInfo kPlugin3045 = WebPluginInfo(
|
| - ASCIIToUTF16("MyPlugin"), FilePath(FILE_PATH_LITERAL("myplugin.so.3.0.45")),
|
| - ASCIIToUTF16("3.0.45"), ASCIIToUTF16("MyPlugin version 3.0.45"));
|
| -static const WebPluginInfo kPlugin3045r = WebPluginInfo(
|
| - ASCIIToUTF16("MyPlugin"), FilePath(FILE_PATH_LITERAL("myplugin.so.3.0.45")),
|
| - ASCIIToUTF16("3.0r45"), ASCIIToUTF16("MyPlugin version 3.0r45"));
|
| -static const WebPluginInfo kPlugin4043 = WebPluginInfo(
|
| - ASCIIToUTF16("MyPlugin"), FilePath(FILE_PATH_LITERAL("myplugin.so.4.0.43")),
|
| - ASCIIToUTF16("4.0.43"), ASCIIToUTF16("MyPlugin version 4.0.43"));
|
| -
|
| -class PluginGroupTest : public testing::Test {
|
| - public:
|
| - static PluginGroup* CreatePluginGroup(
|
| - const PluginGroupDefinition& definition) {
|
| - return PluginGroup::FromPluginGroupDefinition(definition);
|
| - }
|
| - static PluginGroup* CreatePluginGroup(const WebPluginInfo& wpi) {
|
| - return PluginGroup::FromWebPluginInfo(wpi);
|
| - }
|
| -};
|
| -
|
| -TEST_F(PluginGroupTest, PluginGroupMatch) {
|
| - scoped_ptr<PluginGroup> group(PluginGroupTest::CreatePluginGroup(
|
| - kPluginDef3));
|
| - EXPECT_TRUE(group->Match(kPlugin3045));
|
| - EXPECT_TRUE(group->Match(kPlugin3045r));
|
| - EXPECT_FALSE(group->Match(kPluginNoVersion));
|
| - group->AddPlugin(kPlugin3045);
|
| - EXPECT_FALSE(group->IsVulnerable(kPlugin3045));
|
| -
|
| - group.reset(PluginGroupTest::CreatePluginGroup(kPluginDef));
|
| - EXPECT_FALSE(group->Match(kPluginNoVersion));
|
| -}
|
| -
|
| -TEST_F(PluginGroupTest, PluginGroupMatchCorrectVersion) {
|
| - scoped_ptr<PluginGroup> group(PluginGroupTest::CreatePluginGroup(
|
| - kPluginDef3));
|
| - EXPECT_TRUE(group->Match(kPlugin2043));
|
| - EXPECT_TRUE(group->Match(kPlugin3043));
|
| - EXPECT_FALSE(group->Match(kPlugin4043));
|
| -
|
| - group.reset(PluginGroupTest::CreatePluginGroup(kPluginDef4));
|
| - EXPECT_FALSE(group->Match(kPlugin2043));
|
| - EXPECT_FALSE(group->Match(kPlugin3043));
|
| - EXPECT_TRUE(group->Match(kPlugin4043));
|
| -
|
| - group.reset(PluginGroupTest::CreatePluginGroup(kPluginDef34));
|
| - EXPECT_TRUE(group->Match(kPlugin2043));
|
| - EXPECT_TRUE(group->Match(kPlugin3043));
|
| - EXPECT_TRUE(group->Match(kPlugin4043));
|
| -}
|
| -
|
| -TEST_F(PluginGroupTest, PluginGroupDefinition) {
|
| - for (size_t i = 0; i < arraysize(kPluginDefinitions); ++i) {
|
| - scoped_ptr<PluginGroup> def_group(
|
| - PluginGroupTest::CreatePluginGroup(kPluginDefinitions[i]));
|
| - ASSERT_TRUE(def_group.get() != NULL);
|
| - }
|
| -}
|
| -
|
| -TEST_F(PluginGroupTest, VersionExtraction) {
|
| +TEST(PluginGroupTest, VersionExtraction) {
|
| // Some real-world plugin versions (spaces, commata, parentheses, 'r', oh my)
|
| const char* versions[][2] = {
|
| { "7.6.6 (1671)", "7.6.6.1671" }, // Quicktime
|
| @@ -146,46 +32,9 @@ TEST_F(PluginGroupTest, VersionExtraction) {
|
| for (size_t i = 0; i < arraysize(versions); i++) {
|
| scoped_ptr<Version> version(PluginGroup::CreateVersionFromString(
|
| ASCIIToUTF16(versions[i][0])));
|
| - EXPECT_STREQ(versions[i][1], version->GetString().c_str());
|
| + EXPECT_EQ(versions[i][1], version->GetString());
|
| }
|
| }
|
|
|
| -TEST_F(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) };
|
| - 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);
|
| - PluginGroup group_copy(*group); // Exercise the copy constructor.
|
| - EXPECT_FALSE(group_copy.IsVulnerable(adobe_reader_plugin));
|
| -
|
| - // 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) };
|
| - 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);
|
| - EXPECT_FALSE(PluginGroup(*group).IsVulnerable(silverlight_plugin));
|
| -}
|
| -
|
| } // namespace npapi
|
| } // namespace webkit
|
|
|