OLD | NEW |
1 // Copyright (c) 2010 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2010 The Chromium Authors. All rights reserved. |
2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
4 | 4 |
5 #include "webkit/glue/plugins/plugin_group.h" | 5 #include "webkit/glue/plugins/plugin_group.h" |
6 | 6 |
7 #include <string> | 7 #include <string> |
8 #include <vector> | 8 #include <vector> |
9 | 9 |
10 #include "base/scoped_ptr.h" | 10 #include "base/scoped_ptr.h" |
11 #include "base/string_util.h" | 11 #include "base/string_util.h" |
12 #include "base/utf_string_conversions.h" | 12 #include "base/utf_string_conversions.h" |
13 #include "base/values.h" | 13 #include "base/values.h" |
14 #include "base/version.h" | 14 #include "base/version.h" |
15 #include "testing/gtest/include/gtest/gtest.h" | 15 #include "testing/gtest/include/gtest/gtest.h" |
16 #include "webkit/glue/plugins/webplugininfo.h" | 16 #include "webkit/glue/plugins/webplugininfo.h" |
17 #include "webkit/glue/plugins/plugin_list.h" | 17 #include "webkit/glue/plugins/plugin_list.h" |
18 | 18 |
19 static const VersionRangeDefinition kPluginVersionRange[] = { | 19 static const VersionRangeDefinition kPluginVersionRange[] = { |
20 { "", "", "3.0.44" } | 20 { "", "", "3.0.44" } |
21 }; | 21 }; |
22 static const VersionRangeDefinition kPlugin3VersionRange[] = { | 22 static const VersionRangeDefinition kPlugin3VersionRange[] = { |
23 { "0", "4", "3.0.44" } | 23 { "0", "4", "3.0.44" } |
24 }; | 24 }; |
25 static const VersionRangeDefinition kPlugin4VersionRange[] = { | 25 static const VersionRangeDefinition kPlugin4VersionRange[] = { |
26 { "4", "5", "4.0.44" } | 26 { "4", "5", "4.0.44" } |
27 }; | 27 }; |
28 static const VersionRangeDefinition kPlugin34VersionRange[] = { | 28 static const VersionRangeDefinition kPlugin34VersionRange[] = { |
29 { "0", "4", "3.0.44" }, | 29 { "0", "4", "3.0.44" }, |
30 { "4", "5", "4.0.44" } | 30 { "4", "5", "" } |
31 }; | 31 }; |
32 | 32 |
33 static const PluginGroupDefinition kPluginDef = { | 33 static const PluginGroupDefinition kPluginDef = { |
34 "myplugin", "MyPlugin", "MyPlugin", kPluginVersionRange, 1, | 34 "myplugin", "MyPlugin", "MyPlugin", kPluginVersionRange, |
35 "http://latest/" }; | 35 arraysize(kPluginVersionRange), "http://latest/" }; |
36 static const PluginGroupDefinition kPluginDef3 = { | 36 static const PluginGroupDefinition kPluginDef3 = { |
37 "myplugin-3", "MyPlugin 3", "MyPlugin", kPlugin3VersionRange, 1, | 37 "myplugin-3", "MyPlugin 3", "MyPlugin", kPlugin3VersionRange, |
38 "http://latest" }; | 38 arraysize(kPlugin3VersionRange), "http://latest" }; |
39 static const PluginGroupDefinition kPluginDef4 = { | 39 static const PluginGroupDefinition kPluginDef4 = { |
40 "myplugin-4", "MyPlugin 4", "MyPlugin", kPlugin4VersionRange, 1, | 40 "myplugin-4", "MyPlugin 4", "MyPlugin", kPlugin4VersionRange, |
41 "http://latest" }; | 41 arraysize(kPlugin4VersionRange), "http://latest" }; |
42 static const PluginGroupDefinition kPluginDef34 = { | 42 static const PluginGroupDefinition kPluginDef34 = { |
43 "myplugin-34", "MyPlugin 3/4", "MyPlugin", kPlugin34VersionRange, 2, | 43 "myplugin-34", "MyPlugin 3/4", "MyPlugin", kPlugin34VersionRange, |
44 "http://latest" }; | 44 arraysize(kPlugin34VersionRange), "http://latest" }; |
45 static const PluginGroupDefinition kPluginDefNotVulnerable = { | 45 static const PluginGroupDefinition kPluginDefNotVulnerable = { |
46 "myplugin-latest", "MyPlugin", "MyPlugin", NULL, 0, "http://latest" }; | 46 "myplugin-latest", "MyPlugin", "MyPlugin", NULL, 0, "http://latest" }; |
47 | 47 |
48 // name, path, version, desc, mime_types, enabled. | 48 // name, path, version, desc, mime_types, enabled. |
49 static WebPluginInfo kPlugin2043 = WebPluginInfo( | 49 static WebPluginInfo kPlugin2043 = WebPluginInfo( |
50 ASCIIToUTF16("MyPlugin"), FilePath(FILE_PATH_LITERAL("myplugin.so.2.0.43")), | 50 ASCIIToUTF16("MyPlugin"), FilePath(FILE_PATH_LITERAL("myplugin.so.2.0.43")), |
51 ASCIIToUTF16("2.0.43"), ASCIIToUTF16("MyPlugin version 2.0.43")); | 51 ASCIIToUTF16("2.0.43"), ASCIIToUTF16("MyPlugin version 2.0.43")); |
52 static WebPluginInfo kPlugin3043 = WebPluginInfo( | 52 static WebPluginInfo kPlugin3043 = WebPluginInfo( |
53 ASCIIToUTF16("MyPlugin"), FilePath(FILE_PATH_LITERAL("myplugin.so.3.0.43")), | 53 ASCIIToUTF16("MyPlugin"), FilePath(FILE_PATH_LITERAL("myplugin.so.3.0.43")), |
54 ASCIIToUTF16("3.0.43"), ASCIIToUTF16("MyPlugin version 3.0.43")); | 54 ASCIIToUTF16("3.0.43"), ASCIIToUTF16("MyPlugin version 3.0.43")); |
(...skipping 45 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
100 group.reset(PluginGroupTest::CreatePluginGroup(kPluginDef34)); | 100 group.reset(PluginGroupTest::CreatePluginGroup(kPluginDef34)); |
101 EXPECT_TRUE(group->Match(kPlugin2043)); | 101 EXPECT_TRUE(group->Match(kPlugin2043)); |
102 EXPECT_TRUE(group->Match(kPlugin3043)); | 102 EXPECT_TRUE(group->Match(kPlugin3043)); |
103 EXPECT_TRUE(group->Match(kPlugin4043)); | 103 EXPECT_TRUE(group->Match(kPlugin4043)); |
104 } | 104 } |
105 | 105 |
106 TEST(PluginGroupTest, PluginGroupDescription) { | 106 TEST(PluginGroupTest, PluginGroupDescription) { |
107 string16 desc3043(ASCIIToUTF16("MyPlugin version 3.0.43")); | 107 string16 desc3043(ASCIIToUTF16("MyPlugin version 3.0.43")); |
108 string16 desc3045(ASCIIToUTF16("MyPlugin version 3.0.45")); | 108 string16 desc3045(ASCIIToUTF16("MyPlugin version 3.0.45")); |
109 | 109 |
110 PluginGroupDefinition plugindefs[] = { kPluginDef3, kPluginDef34 }; | 110 PluginGroupDefinition plugindefs[] = |
111 for (size_t i = 0; i < 2; ++i) { | 111 { kPluginDef, kPluginDef3, kPluginDef34 }; |
| 112 for (size_t i = 0; i < arraysize(plugindefs); ++i) { |
112 WebPluginInfo plugin3043(kPlugin3043); | 113 WebPluginInfo plugin3043(kPlugin3043); |
113 WebPluginInfo plugin3045(kPlugin3045); | 114 WebPluginInfo plugin3045(kPlugin3045); |
114 { | 115 { |
115 scoped_ptr<PluginGroup> group(PluginGroupTest::CreatePluginGroup( | 116 scoped_ptr<PluginGroup> group(PluginGroupTest::CreatePluginGroup( |
116 plugindefs[i])); | 117 plugindefs[i])); |
117 EXPECT_TRUE(group->Match(plugin3043)); | 118 EXPECT_TRUE(group->Match(plugin3043)); |
118 group->AddPlugin(plugin3043, 0, NULL); | 119 group->AddPlugin(plugin3043, 0, NULL); |
119 EXPECT_EQ(desc3043, group->description()); | 120 EXPECT_EQ(desc3043, group->description()); |
120 EXPECT_TRUE(group->IsVulnerable()); | 121 EXPECT_TRUE(group->IsVulnerable()); |
121 EXPECT_TRUE(group->Match(plugin3045)); | 122 EXPECT_TRUE(group->Match(plugin3045)); |
(...skipping 41 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
163 for (size_t i = 0; | 164 for (size_t i = 0; |
164 i < NPAPI::PluginList::GetPluginGroupDefinitionsSize(); | 165 i < NPAPI::PluginList::GetPluginGroupDefinitionsSize(); |
165 ++i) { | 166 ++i) { |
166 scoped_ptr<PluginGroup> def_group( | 167 scoped_ptr<PluginGroup> def_group( |
167 PluginGroupTest::CreatePluginGroup(definitions[i])); | 168 PluginGroupTest::CreatePluginGroup(definitions[i])); |
168 ASSERT_TRUE(def_group.get() != NULL); | 169 ASSERT_TRUE(def_group.get() != NULL); |
169 EXPECT_FALSE(def_group->Match(kPlugin2043)); | 170 EXPECT_FALSE(def_group->Match(kPlugin2043)); |
170 } | 171 } |
171 } | 172 } |
172 | 173 |
173 TEST(PluginGroupTest, DisableOutdated) { | |
174 PluginGroupDefinition plugindefs[] = { kPluginDef3, kPluginDef34 }; | |
175 for (size_t i = 0; i < 2; ++i) { | |
176 scoped_ptr<PluginGroup> group(PluginGroupTest::CreatePluginGroup( | |
177 plugindefs[i])); | |
178 group->AddPlugin(kPlugin3043, 0, NULL); | |
179 group->AddPlugin(kPlugin3045, 1, NULL); | |
180 | |
181 EXPECT_EQ(ASCIIToUTF16("MyPlugin version 3.0.43"), group->description()); | |
182 EXPECT_TRUE(group->IsVulnerable()); | |
183 | |
184 group->DisableOutdatedPlugins(); | |
185 EXPECT_EQ(ASCIIToUTF16("MyPlugin version 3.0.45"), group->description()); | |
186 EXPECT_FALSE(group->IsVulnerable()); | |
187 } | |
188 } | |
189 | |
190 TEST(PluginGroupTest, VersionExtraction) { | 174 TEST(PluginGroupTest, VersionExtraction) { |
191 // Some real-world plugin versions (spaces, commata, parentheses, 'r', oh my) | 175 // Some real-world plugin versions (spaces, commata, parentheses, 'r', oh my) |
192 const char* versions[][2] = { | 176 const char* versions[][2] = { |
193 { "7.6.6 (1671)", "7.6.6.1671" }, // Quicktime | 177 { "7.6.6 (1671)", "7.6.6.1671" }, // Quicktime |
194 { "2, 0, 0, 254", "2.0.0.254" }, // DivX | 178 { "2, 0, 0, 254", "2.0.0.254" }, // DivX |
195 { "3, 0, 0, 0", "3.0.0.0" }, // Picasa | 179 { "3, 0, 0, 0", "3.0.0.0" }, // Picasa |
196 { "1, 0, 0, 1", "1.0.0.1" }, // Earth | 180 { "1, 0, 0, 1", "1.0.0.1" }, // Earth |
197 { "10,0,45,2", "10.0.45.2" }, // Flash | 181 { "10,0,45,2", "10.0.45.2" }, // Flash |
198 { "11.5.7r609", "11.5.7.609"} // Shockwave | 182 { "11.5.7r609", "11.5.7.609"} // Shockwave |
199 }; | 183 }; |
(...skipping 17 matching lines...) Expand all Loading... |
217 disabled_plugins.insert(ASCIIToUTF16("Disable this!")); | 201 disabled_plugins.insert(ASCIIToUTF16("Disable this!")); |
218 disabled_plugins.insert(ASCIIToUTF16("*Google*")); | 202 disabled_plugins.insert(ASCIIToUTF16("*Google*")); |
219 PluginGroup::SetPolicyDisabledPluginPatterns(disabled_plugins); | 203 PluginGroup::SetPolicyDisabledPluginPatterns(disabled_plugins); |
220 | 204 |
221 EXPECT_FALSE(PluginGroup::IsPluginNameDisabledByPolicy(ASCIIToUTF16("42"))); | 205 EXPECT_FALSE(PluginGroup::IsPluginNameDisabledByPolicy(ASCIIToUTF16("42"))); |
222 EXPECT_TRUE(PluginGroup::IsPluginNameDisabledByPolicy( | 206 EXPECT_TRUE(PluginGroup::IsPluginNameDisabledByPolicy( |
223 ASCIIToUTF16("Disable this!"))); | 207 ASCIIToUTF16("Disable this!"))); |
224 EXPECT_TRUE(PluginGroup::IsPluginNameDisabledByPolicy( | 208 EXPECT_TRUE(PluginGroup::IsPluginNameDisabledByPolicy( |
225 ASCIIToUTF16("Google Earth"))); | 209 ASCIIToUTF16("Google Earth"))); |
226 } | 210 } |
| 211 |
| 212 TEST(PluginGroupTest, IsVulnerable) { |
| 213 // Adobe Reader 10 |
| 214 VersionRangeDefinition adobe_reader_version_range[] = { |
| 215 { "10", "11", "" }, |
| 216 { "9", "10", "9.4.1" }, |
| 217 { "0", "9", "8.2.5" } |
| 218 }; |
| 219 PluginGroupDefinition adobe_reader_plugin_def = { |
| 220 "adobe-reader", "Adobe Reader", "Adobe Acrobat", |
| 221 adobe_reader_version_range, arraysize(adobe_reader_version_range), |
| 222 "http://get.adobe.com/reader/" }; |
| 223 WebPluginInfo adobe_reader_plugin(ASCIIToUTF16("Adobe Reader"), |
| 224 FilePath(FILE_PATH_LITERAL("/reader.so")), |
| 225 ASCIIToUTF16("10.0.0.396"), |
| 226 ASCIIToUTF16("adobe reader 10")); |
| 227 scoped_ptr<PluginGroup> group(PluginGroupTest::CreatePluginGroup( |
| 228 adobe_reader_plugin_def)); |
| 229 group->AddPlugin(adobe_reader_plugin, 0, NULL); |
| 230 PluginGroup group_copy(*group); // Exercise the copy constructor. |
| 231 EXPECT_FALSE(group_copy.IsVulnerable()); |
| 232 |
| 233 // Silverlight 4 |
| 234 VersionRangeDefinition silverlight_version_range[] = { |
| 235 { "0", "4", "3.0.50106.0" }, |
| 236 { "4", "5", "" } |
| 237 }; |
| 238 PluginGroupDefinition silverlight_plugin_def = { |
| 239 "silverlight", "Silverlight", "Silverlight", silverlight_version_range, |
| 240 arraysize(silverlight_version_range), |
| 241 "http://www.microsoft.com/getsilverlight/" }; |
| 242 WebPluginInfo silverlight_plugin(ASCIIToUTF16("Silverlight"), |
| 243 FilePath(FILE_PATH_LITERAL("/silver.so")), |
| 244 ASCIIToUTF16("4.0.50917.0"), |
| 245 ASCIIToUTF16("silverlight 4")); |
| 246 group.reset(PluginGroupTest::CreatePluginGroup(silverlight_plugin_def)); |
| 247 group->AddPlugin(silverlight_plugin, 0, NULL); |
| 248 EXPECT_FALSE(PluginGroup(*group).IsVulnerable()); |
| 249 } |
OLD | NEW |