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

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

Issue 5621006: Merge PluginGroups for Adobe Reader (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: address comments Created 10 years 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/glue/plugins/plugin_group.cc ('k') | webkit/glue/plugins/plugin_list.cc » ('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) 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[] = {
20 { "", "", "3.0.44" }
21 };
22 static const VersionRangeDefinition kPlugin3VersionRange[] = {
23 { "0", "4", "3.0.44" }
24 };
25 static const VersionRangeDefinition kPlugin4VersionRange[] = {
26 { "4", "5", "4.0.44" }
27 };
28 static const VersionRangeDefinition kPlugin34VersionRange[] = {
29 { "0", "4", "3.0.44" },
30 { "4", "5", "4.0.44" }
31 };
32
19 static const PluginGroupDefinition kPluginDef = { 33 static const PluginGroupDefinition kPluginDef = {
20 "myplugin", "MyPlugin", "MyPlugin", "", "", "3.0.44", "http://latest/" }; 34 "myplugin", "MyPlugin", "MyPlugin", kPluginVersionRange, 1,
35 "http://latest/" };
21 static const PluginGroupDefinition kPluginDef3 = { 36 static const PluginGroupDefinition kPluginDef3 = {
22 "myplugin-3", "MyPlugin 3", "MyPlugin", "0", "4", "3.0.44", 37 "myplugin-3", "MyPlugin 3", "MyPlugin", kPlugin3VersionRange, 1,
23 "http://latest" }; 38 "http://latest" };
24 static const PluginGroupDefinition kPluginDef4 = { 39 static const PluginGroupDefinition kPluginDef4 = {
25 "myplugin-4", "MyPlugin 4", "MyPlugin", "4", "5", "4.0.44", 40 "myplugin-4", "MyPlugin 4", "MyPlugin", kPlugin4VersionRange, 1,
41 "http://latest" };
42 static const PluginGroupDefinition kPluginDef34 = {
43 "myplugin-34", "MyPlugin 3/4", "MyPlugin", kPlugin34VersionRange, 2,
26 "http://latest" }; 44 "http://latest" };
27 static const PluginGroupDefinition kPluginDefNotVulnerable = { 45 static const PluginGroupDefinition kPluginDefNotVulnerable = {
28 "myplugin-latest", "MyPlugin", "MyPlugin", "", "", "", "http://latest" }; 46 "myplugin-latest", "MyPlugin", "MyPlugin", NULL, 0, "http://latest" };
29 47
30 // name, path, version, desc, mime_types, enabled. 48 // name, path, version, desc, mime_types, enabled.
31 static WebPluginInfo kPlugin2043 = WebPluginInfo( 49 static WebPluginInfo kPlugin2043 = WebPluginInfo(
32 ASCIIToUTF16("MyPlugin"), ASCIIToUTF16("2.0.43"), 50 ASCIIToUTF16("MyPlugin"), ASCIIToUTF16("2.0.43"),
33 ASCIIToUTF16("MyPlugin version 2.0.43")); 51 ASCIIToUTF16("MyPlugin version 2.0.43"));
34 static WebPluginInfo kPlugin3043 = WebPluginInfo( 52 static WebPluginInfo kPlugin3043 = WebPluginInfo(
35 ASCIIToUTF16("MyPlugin"), ASCIIToUTF16("3.0.43"), 53 ASCIIToUTF16("MyPlugin"), ASCIIToUTF16("3.0.43"),
36 ASCIIToUTF16("MyPlugin version 3.0.43")); 54 ASCIIToUTF16("MyPlugin version 3.0.43"));
37 static WebPluginInfo kPlugin3044 = WebPluginInfo( 55 static WebPluginInfo kPlugin3044 = WebPluginInfo(
38 ASCIIToUTF16("MyPlugin"), ASCIIToUTF16("3.0.44"), 56 ASCIIToUTF16("MyPlugin"), ASCIIToUTF16("3.0.44"),
(...skipping 32 matching lines...) Expand 10 before | Expand all | Expand 10 after
71 scoped_ptr<PluginGroup> group(PluginGroupTest::CreatePluginGroup( 89 scoped_ptr<PluginGroup> group(PluginGroupTest::CreatePluginGroup(
72 kPluginDef3)); 90 kPluginDef3));
73 EXPECT_TRUE(group->Match(kPlugin2043)); 91 EXPECT_TRUE(group->Match(kPlugin2043));
74 EXPECT_TRUE(group->Match(kPlugin3043)); 92 EXPECT_TRUE(group->Match(kPlugin3043));
75 EXPECT_FALSE(group->Match(kPlugin4043)); 93 EXPECT_FALSE(group->Match(kPlugin4043));
76 94
77 group.reset(PluginGroupTest::CreatePluginGroup(kPluginDef4)); 95 group.reset(PluginGroupTest::CreatePluginGroup(kPluginDef4));
78 EXPECT_FALSE(group->Match(kPlugin2043)); 96 EXPECT_FALSE(group->Match(kPlugin2043));
79 EXPECT_FALSE(group->Match(kPlugin3043)); 97 EXPECT_FALSE(group->Match(kPlugin3043));
80 EXPECT_TRUE(group->Match(kPlugin4043)); 98 EXPECT_TRUE(group->Match(kPlugin4043));
99
100 group.reset(PluginGroupTest::CreatePluginGroup(kPluginDef34));
101 EXPECT_TRUE(group->Match(kPlugin2043));
102 EXPECT_TRUE(group->Match(kPlugin3043));
103 EXPECT_TRUE(group->Match(kPlugin4043));
81 } 104 }
82 105
83 TEST(PluginGroupTest, PluginGroupDescription) { 106 TEST(PluginGroupTest, PluginGroupDescription) {
84 string16 desc3043(ASCIIToUTF16("MyPlugin version 3.0.43")); 107 string16 desc3043(ASCIIToUTF16("MyPlugin version 3.0.43"));
85 string16 desc3045(ASCIIToUTF16("MyPlugin version 3.0.45")); 108 string16 desc3045(ASCIIToUTF16("MyPlugin version 3.0.45"));
86 WebPluginInfo plugin3043(kPlugin3043);
87 WebPluginInfo plugin3045(kPlugin3045);
88 109
89 { 110 PluginGroupDefinition plugindefs[] = { kPluginDef3, kPluginDef34 };
90 scoped_ptr<PluginGroup> group(PluginGroupTest::CreatePluginGroup( 111 for (size_t i = 0; i < 2; ++i) {
91 kPluginDef3)); 112 WebPluginInfo plugin3043(kPlugin3043);
92 EXPECT_TRUE(group->Match(plugin3043)); 113 WebPluginInfo plugin3045(kPlugin3045);
93 group->AddPlugin(plugin3043, 0); 114 {
94 EXPECT_EQ(desc3043, group->description()); 115 scoped_ptr<PluginGroup> group(PluginGroupTest::CreatePluginGroup(
95 EXPECT_TRUE(group->IsVulnerable()); 116 plugindefs[i]));
96 EXPECT_TRUE(group->Match(plugin3045)); 117 EXPECT_TRUE(group->Match(plugin3043));
97 group->AddPlugin(plugin3045, 1); 118 group->AddPlugin(plugin3043, 0);
98 EXPECT_EQ(desc3043, group->description()); 119 EXPECT_EQ(desc3043, group->description());
99 EXPECT_TRUE(group->IsVulnerable()); 120 EXPECT_TRUE(group->IsVulnerable());
100 } 121 EXPECT_TRUE(group->Match(plugin3045));
122 group->AddPlugin(plugin3045, 1);
123 EXPECT_EQ(desc3043, group->description());
124 EXPECT_TRUE(group->IsVulnerable());
125 }
101 126
102 { 127 {
103 // Disable the first plugin. 128 // Disable the first plugin.
104 plugin3043.enabled = false; 129 plugin3043.enabled = false;
105 scoped_ptr<PluginGroup> group(PluginGroupTest::CreatePluginGroup( 130 scoped_ptr<PluginGroup> group(PluginGroupTest::CreatePluginGroup(
106 kPluginDef3)); 131 plugindefs[i]));
107 EXPECT_TRUE(group->Match(plugin3043)); 132 EXPECT_TRUE(group->Match(plugin3043));
108 group->AddPlugin(plugin3043, 0); 133 group->AddPlugin(plugin3043, 0);
109 EXPECT_EQ(desc3043, group->description()); 134 EXPECT_EQ(desc3043, group->description());
110 EXPECT_TRUE(group->IsVulnerable()); 135 EXPECT_TRUE(group->IsVulnerable());
111 EXPECT_TRUE(group->Match(plugin3045)); 136 EXPECT_FALSE(group->Enabled());
112 group->AddPlugin(plugin3045, 1); 137 EXPECT_TRUE(group->Match(plugin3045));
113 EXPECT_EQ(desc3045, group->description()); 138 group->AddPlugin(plugin3045, 1);
114 EXPECT_FALSE(group->IsVulnerable()); 139 EXPECT_EQ(desc3045, group->description());
115 } 140 EXPECT_FALSE(group->IsVulnerable());
141 }
116 142
117 { 143 {
118 // Disable the second plugin. 144 // Disable the second plugin.
119 plugin3045.enabled = false; 145 plugin3045.enabled = false;
120 scoped_ptr<PluginGroup> group(PluginGroupTest::CreatePluginGroup( 146 scoped_ptr<PluginGroup> group(PluginGroupTest::CreatePluginGroup(
121 kPluginDef3)); 147 plugindefs[i]));
122 EXPECT_TRUE(group->Match(plugin3043)); 148 EXPECT_TRUE(group->Match(plugin3043));
123 group->AddPlugin(plugin3043, 1); 149 group->AddPlugin(plugin3043, 1);
124 EXPECT_EQ(desc3043, group->description()); 150 EXPECT_EQ(desc3043, group->description());
125 EXPECT_TRUE(group->IsVulnerable()); 151 EXPECT_TRUE(group->IsVulnerable());
126 EXPECT_TRUE(group->Match(plugin3045)); 152 EXPECT_TRUE(group->Match(plugin3045));
127 group->AddPlugin(plugin3045, 0); 153 group->AddPlugin(plugin3045, 0);
128 EXPECT_EQ(desc3043, group->description()); 154 EXPECT_EQ(desc3043, group->description());
129 EXPECT_TRUE(group->IsVulnerable()); 155 EXPECT_TRUE(group->IsVulnerable());
156 }
130 } 157 }
131 } 158 }
132 159
133 TEST(PluginGroupTest, PluginGroupDefinition) { 160 TEST(PluginGroupTest, PluginGroupDefinition) {
134 const PluginGroupDefinition* definitions = 161 const PluginGroupDefinition* definitions =
135 NPAPI::PluginList::GetPluginGroupDefinitions(); 162 NPAPI::PluginList::GetPluginGroupDefinitions();
136 for (size_t i = 0; 163 for (size_t i = 0;
137 i < NPAPI::PluginList::GetPluginGroupDefinitionsSize(); 164 i < NPAPI::PluginList::GetPluginGroupDefinitionsSize();
138 ++i) { 165 ++i) {
139 scoped_ptr<PluginGroup> def_group( 166 scoped_ptr<PluginGroup> def_group(
140 PluginGroupTest::CreatePluginGroup(definitions[i])); 167 PluginGroupTest::CreatePluginGroup(definitions[i]));
141 ASSERT_TRUE(def_group.get() != NULL); 168 ASSERT_TRUE(def_group.get() != NULL);
142 EXPECT_FALSE(def_group->Match(kPlugin2043)); 169 EXPECT_FALSE(def_group->Match(kPlugin2043));
143 } 170 }
144 } 171 }
145 172
146 TEST(PluginGroupTest, DisableOutdated) { 173 TEST(PluginGroupTest, DisableOutdated) {
147 scoped_ptr<PluginGroup> group(PluginGroupTest::CreatePluginGroup( 174 PluginGroupDefinition plugindefs[] = { kPluginDef3, kPluginDef34 };
148 kPluginDef3)); 175 for (size_t i = 0; i < 2; ++i) {
149 group->AddPlugin(kPlugin3043, 0); 176 scoped_ptr<PluginGroup> group(PluginGroupTest::CreatePluginGroup(
150 group->AddPlugin(kPlugin3045, 1); 177 plugindefs[i]));
151 EXPECT_EQ(ASCIIToUTF16("MyPlugin version 3.0.43"), group->description()); 178 group->AddPlugin(kPlugin3043, 0);
152 EXPECT_TRUE(group->IsVulnerable()); 179 group->AddPlugin(kPlugin3045, 1);
180 EXPECT_EQ(ASCIIToUTF16("MyPlugin version 3.0.43"), group->description());
181 EXPECT_TRUE(group->IsVulnerable());
153 182
154 group->DisableOutdatedPlugins(); 183 group->DisableOutdatedPlugins();
155 EXPECT_EQ(ASCIIToUTF16("MyPlugin version 3.0.45"), group->description()); 184 EXPECT_EQ(ASCIIToUTF16("MyPlugin version 3.0.45"), group->description());
156 EXPECT_FALSE(group->IsVulnerable()); 185 EXPECT_FALSE(group->IsVulnerable());
186 }
157 } 187 }
158 188
159 TEST(PluginGroupTest, VersionExtraction) { 189 TEST(PluginGroupTest, VersionExtraction) {
160 // Some real-world plugin versions (spaces, commata, parentheses, 'r', oh my) 190 // Some real-world plugin versions (spaces, commata, parentheses, 'r', oh my)
161 const char* versions[][2] = { 191 const char* versions[][2] = {
162 { "7.6.6 (1671)", "7.6.6.1671" }, // Quicktime 192 { "7.6.6 (1671)", "7.6.6.1671" }, // Quicktime
163 { "2, 0, 0, 254", "2.0.0.254" }, // DivX 193 { "2, 0, 0, 254", "2.0.0.254" }, // DivX
164 { "3, 0, 0, 0", "3.0.0.0" }, // Picasa 194 { "3, 0, 0, 0", "3.0.0.0" }, // Picasa
165 { "1, 0, 0, 1", "1.0.0.1" }, // Earth 195 { "1, 0, 0, 1", "1.0.0.1" }, // Earth
166 { "10,0,45,2", "10.0.45.2" }, // Flash 196 { "10,0,45,2", "10.0.45.2" }, // Flash
(...skipping 18 matching lines...) Expand all
185 disabled_plugins.insert(ASCIIToUTF16("Disable this!")); 215 disabled_plugins.insert(ASCIIToUTF16("Disable this!"));
186 disabled_plugins.insert(ASCIIToUTF16("*Google*")); 216 disabled_plugins.insert(ASCIIToUTF16("*Google*"));
187 PluginGroup::SetPolicyDisabledPluginPatterns(disabled_plugins); 217 PluginGroup::SetPolicyDisabledPluginPatterns(disabled_plugins);
188 218
189 EXPECT_FALSE(PluginGroup::IsPluginNameDisabledByPolicy(ASCIIToUTF16("42"))); 219 EXPECT_FALSE(PluginGroup::IsPluginNameDisabledByPolicy(ASCIIToUTF16("42")));
190 EXPECT_TRUE(PluginGroup::IsPluginNameDisabledByPolicy( 220 EXPECT_TRUE(PluginGroup::IsPluginNameDisabledByPolicy(
191 ASCIIToUTF16("Disable this!"))); 221 ASCIIToUTF16("Disable this!")));
192 EXPECT_TRUE(PluginGroup::IsPluginNameDisabledByPolicy( 222 EXPECT_TRUE(PluginGroup::IsPluginNameDisabledByPolicy(
193 ASCIIToUTF16("Google Earth"))); 223 ASCIIToUTF16("Google Earth")));
194 } 224 }
OLDNEW
« no previous file with comments | « webkit/glue/plugins/plugin_group.cc ('k') | webkit/glue/plugins/plugin_list.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698