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

Side by Side Diff: webkit/plugins/npapi/plugin_group_unittest.cc

Issue 9536013: Move |requires_authorization| flag for plug-ins out of webkit/ (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: copyright Created 8 years, 9 months 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 unified diff | Download patch | Annotate | Revision Log
« no previous file with comments | « webkit/plugins/npapi/plugin_group.cc ('k') | webkit/plugins/npapi/plugin_list.h » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 // Copyright (c) 2011 The Chromium Authors. All rights reserved. 1 // Copyright (c) 2012 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/plugins/npapi/plugin_group.h" 5 #include "webkit/plugins/npapi/plugin_group.h"
6 6
7 #include <string> 7 #include <string>
8 #include <vector> 8 #include <vector>
9 9
10 #include "base/memory/scoped_ptr.h" 10 #include "base/memory/scoped_ptr.h"
11 #include "base/string16.h" 11 #include "base/string16.h"
12 #include "base/string_util.h" 12 #include "base/string_util.h"
13 #include "base/utf_string_conversions.h" 13 #include "base/utf_string_conversions.h"
14 #include "base/values.h" 14 #include "base/values.h"
15 #include "base/version.h" 15 #include "base/version.h"
16 #include "testing/gtest/include/gtest/gtest.h" 16 #include "testing/gtest/include/gtest/gtest.h"
17 #include "webkit/plugins/webplugininfo.h" 17 #include "webkit/plugins/webplugininfo.h"
18 18
19 namespace webkit { 19 namespace webkit {
20 namespace npapi { 20 namespace npapi {
21 21
22 static const VersionRangeDefinition kPluginVersionRange[] = { 22 static const VersionRangeDefinition kPluginVersionRange[] = {
23 { "", "", "3.0.44", false } 23 { "", "", "3.0.44" }
24 }; 24 };
25 static const VersionRangeDefinition kPlugin3VersionRange[] = { 25 static const VersionRangeDefinition kPlugin3VersionRange[] = {
26 { "0", "4", "3.0.44", false } 26 { "0", "4", "3.0.44" }
27 }; 27 };
28 static const VersionRangeDefinition kPlugin4VersionRange[] = { 28 static const VersionRangeDefinition kPlugin4VersionRange[] = {
29 { "4", "5", "4.0.44", false } 29 { "4", "5", "4.0.44" }
30 }; 30 };
31 static const VersionRangeDefinition kPlugin34VersionRange[] = { 31 static const VersionRangeDefinition kPlugin34VersionRange[] = {
32 { "0", "4", "3.0.44", false }, 32 { "0", "4", "3.0.44" },
33 { "4", "5", "", false } 33 { "4", "5", "" }
34 }; 34 };
35 35
36 static const PluginGroupDefinition kPluginDef = { 36 static const PluginGroupDefinition kPluginDef = {
37 "myplugin", "MyPlugin", "MyPlugin", kPluginVersionRange, 37 "myplugin", "MyPlugin", "MyPlugin", kPluginVersionRange,
38 arraysize(kPluginVersionRange), "http://latest/" }; 38 arraysize(kPluginVersionRange) };
39 static const PluginGroupDefinition kPluginDef3 = { 39 static const PluginGroupDefinition kPluginDef3 = {
40 "myplugin-3", "MyPlugin 3", "MyPlugin", kPlugin3VersionRange, 40 "myplugin-3", "MyPlugin 3", "MyPlugin", kPlugin3VersionRange,
41 arraysize(kPlugin3VersionRange), "http://latest" }; 41 arraysize(kPlugin3VersionRange) };
42 static const PluginGroupDefinition kPluginDef4 = { 42 static const PluginGroupDefinition kPluginDef4 = {
43 "myplugin-4", "MyPlugin 4", "MyPlugin", kPlugin4VersionRange, 43 "myplugin-4", "MyPlugin 4", "MyPlugin", kPlugin4VersionRange,
44 arraysize(kPlugin4VersionRange), "http://latest" }; 44 arraysize(kPlugin4VersionRange) };
45 static const PluginGroupDefinition kPluginDef34 = { 45 static const PluginGroupDefinition kPluginDef34 = {
46 "myplugin-34", "MyPlugin 3/4", "MyPlugin", kPlugin34VersionRange, 46 "myplugin-34", "MyPlugin 3/4", "MyPlugin", kPlugin34VersionRange,
47 arraysize(kPlugin34VersionRange), "http://latest" }; 47 arraysize(kPlugin34VersionRange) };
48 static const PluginGroupDefinition kPluginDefNotVulnerable = { 48 static const PluginGroupDefinition kPluginDefNotVulnerable = {
49 "myplugin-latest", "MyPlugin", "MyPlugin", NULL, 0, "http://latest" }; 49 "myplugin-latest", "MyPlugin", "MyPlugin", NULL, 0 };
50 50
51 const PluginGroupDefinition kPluginDefinitions[] = { 51 const PluginGroupDefinition kPluginDefinitions[] = {
52 kPluginDef, 52 kPluginDef,
53 kPluginDef3, 53 kPluginDef3,
54 kPluginDef4, 54 kPluginDef4,
55 kPluginDef34, 55 kPluginDef34,
56 kPluginDefNotVulnerable, 56 kPluginDefNotVulnerable,
57 }; 57 };
58 58
59 // name, path, version, desc. 59 // name, path, version, desc.
(...skipping 86 matching lines...) Expand 10 before | Expand all | Expand 10 after
146 for (size_t i = 0; i < arraysize(versions); i++) { 146 for (size_t i = 0; i < arraysize(versions); i++) {
147 scoped_ptr<Version> version(PluginGroup::CreateVersionFromString( 147 scoped_ptr<Version> version(PluginGroup::CreateVersionFromString(
148 ASCIIToUTF16(versions[i][0]))); 148 ASCIIToUTF16(versions[i][0])));
149 EXPECT_STREQ(versions[i][1], version->GetString().c_str()); 149 EXPECT_STREQ(versions[i][1], version->GetString().c_str());
150 } 150 }
151 } 151 }
152 152
153 TEST_F(PluginGroupTest, IsVulnerable) { 153 TEST_F(PluginGroupTest, IsVulnerable) {
154 // Adobe Reader 10 154 // Adobe Reader 10
155 VersionRangeDefinition adobe_reader_version_range[] = { 155 VersionRangeDefinition adobe_reader_version_range[] = {
156 { "10", "11", "", false }, 156 { "10", "11", "" },
157 { "9", "10", "9.4.1", false }, 157 { "9", "10", "9.4.1" },
158 { "0", "9", "8.2.5", false } 158 { "0", "9", "8.2.5" }
159 }; 159 };
160 PluginGroupDefinition adobe_reader_plugin_def = { 160 PluginGroupDefinition adobe_reader_plugin_def = {
161 "adobe-reader", "Adobe Reader", "Adobe Acrobat", 161 "adobe-reader", "Adobe Reader", "Adobe Acrobat",
162 adobe_reader_version_range, arraysize(adobe_reader_version_range), 162 adobe_reader_version_range, arraysize(adobe_reader_version_range) };
163 "http://get.adobe.com/reader/" };
164 WebPluginInfo adobe_reader_plugin(ASCIIToUTF16("Adobe Reader"), 163 WebPluginInfo adobe_reader_plugin(ASCIIToUTF16("Adobe Reader"),
165 FilePath(FILE_PATH_LITERAL("/reader.so")), 164 FilePath(FILE_PATH_LITERAL("/reader.so")),
166 ASCIIToUTF16("10.0.0.396"), 165 ASCIIToUTF16("10.0.0.396"),
167 ASCIIToUTF16("adobe reader 10")); 166 ASCIIToUTF16("adobe reader 10"));
168 scoped_ptr<PluginGroup> group(PluginGroupTest::CreatePluginGroup( 167 scoped_ptr<PluginGroup> group(PluginGroupTest::CreatePluginGroup(
169 adobe_reader_plugin_def)); 168 adobe_reader_plugin_def));
170 group->AddPlugin(adobe_reader_plugin); 169 group->AddPlugin(adobe_reader_plugin);
171 PluginGroup group_copy(*group); // Exercise the copy constructor. 170 PluginGroup group_copy(*group); // Exercise the copy constructor.
172 EXPECT_FALSE(group_copy.IsVulnerable(adobe_reader_plugin)); 171 EXPECT_FALSE(group_copy.IsVulnerable(adobe_reader_plugin));
173 EXPECT_FALSE(group_copy.RequiresAuthorization(adobe_reader_plugin));
174 172
175 // Silverlight 4 173 // Silverlight 4
176 VersionRangeDefinition silverlight_version_range[] = { 174 VersionRangeDefinition silverlight_version_range[] = {
177 { "0", "4", "3.0.50106.0", false }, 175 { "0", "4", "3.0.50106.0" },
178 { "4", "5", "", true } 176 { "4", "5", "" }
179 }; 177 };
180 PluginGroupDefinition silverlight_plugin_def = { 178 PluginGroupDefinition silverlight_plugin_def = {
181 "silverlight", "Silverlight", "Silverlight", silverlight_version_range, 179 "silverlight", "Silverlight", "Silverlight", silverlight_version_range,
182 arraysize(silverlight_version_range), 180 arraysize(silverlight_version_range) };
183 "http://www.microsoft.com/getsilverlight/" };
184 WebPluginInfo silverlight_plugin(ASCIIToUTF16("Silverlight"), 181 WebPluginInfo silverlight_plugin(ASCIIToUTF16("Silverlight"),
185 FilePath(FILE_PATH_LITERAL("/silver.so")), 182 FilePath(FILE_PATH_LITERAL("/silver.so")),
186 ASCIIToUTF16("4.0.50917.0"), 183 ASCIIToUTF16("4.0.50917.0"),
187 ASCIIToUTF16("silverlight 4")); 184 ASCIIToUTF16("silverlight 4"));
188 group.reset(PluginGroupTest::CreatePluginGroup(silverlight_plugin_def)); 185 group.reset(PluginGroupTest::CreatePluginGroup(silverlight_plugin_def));
189 group->AddPlugin(silverlight_plugin); 186 group->AddPlugin(silverlight_plugin);
190 EXPECT_FALSE(PluginGroup(*group).IsVulnerable(silverlight_plugin)); 187 EXPECT_FALSE(PluginGroup(*group).IsVulnerable(silverlight_plugin));
191 EXPECT_TRUE(PluginGroup(*group).RequiresAuthorization(silverlight_plugin));
192 } 188 }
193 189
194 } // namespace npapi 190 } // namespace npapi
195 } // namespace webkit 191 } // namespace webkit
OLDNEW
« no previous file with comments | « webkit/plugins/npapi/plugin_group.cc ('k') | webkit/plugins/npapi/plugin_list.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698