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

Side by Side Diff: chrome/browser/extensions/api/declarative_content/content_action_unittest.cc

Issue 493633003: Browser changes for wiring up RequestContentScript API to shared memory (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Fix nit: Inline methods in unit tests Created 6 years, 3 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
OLDNEW
1 // Copyright (c) 2012 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 "chrome/browser/extensions/api/declarative_content/content_action.h" 5 #include "chrome/browser/extensions/api/declarative_content/content_action.h"
6 6
7 #include "base/run_loop.h"
7 #include "base/test/values_test_util.h" 8 #include "base/test/values_test_util.h"
8 #include "chrome/browser/extensions/extension_action.h" 9 #include "chrome/browser/extensions/extension_action.h"
9 #include "chrome/browser/extensions/extension_action_manager.h" 10 #include "chrome/browser/extensions/extension_action_manager.h"
11 #include "chrome/browser/extensions/extension_service_test_base.h"
10 #include "chrome/browser/extensions/extension_tab_util.h" 12 #include "chrome/browser/extensions/extension_tab_util.h"
11 #include "chrome/browser/extensions/test_extension_environment.h" 13 #include "chrome/browser/extensions/test_extension_environment.h"
14 #include "chrome/browser/extensions/test_extension_system.h"
15 #include "chrome/test/base/testing_profile.h"
12 #include "chrome/test/base/testing_profile.h" 16 #include "chrome/test/base/testing_profile.h"
13 #include "content/public/browser/web_contents.h" 17 #include "content/public/browser/web_contents.h"
18 #include "extensions/browser/extension_system.h"
19 #include "extensions/common/extension.h"
14 #include "extensions/common/extension_builder.h" 20 #include "extensions/common/extension_builder.h"
15 #include "testing/gmock/include/gmock/gmock.h" 21 #include "testing/gmock/include/gmock/gmock.h"
16 #include "testing/gtest/include/gtest/gtest.h" 22 #include "testing/gtest/include/gtest/gtest.h"
17 23
18 namespace extensions { 24 namespace extensions {
19 namespace { 25 namespace {
20 26
21 using base::test::ParseJson; 27 using base::test::ParseJson;
22 using testing::HasSubstr; 28 using testing::HasSubstr;
23 29
30
31 scoped_ptr<base::DictionaryValue> SimpleManifest() {
32 return DictionaryBuilder()
33 .Set("name", "extension")
34 .Set("manifest_version", 2)
35 .Set("version", "1.0")
36 .Build();
37 }
38
39 class RequestContentScriptTest : public ExtensionServiceTestBase {
40 public:
41 RequestContentScriptTest()
42 : extension_(ExtensionBuilder().SetManifest(SimpleManifest()).Build()) {};
43
44 // TODO(rdevlin.cronin): This should be SetUp(), but an issues with invoking
45 // InitializeEmptyExtensionService() within SetUp() means that we have to
46 // call this manually within every test. This can be cleaned up once said
47 // issue is fixed.
48 virtual void Init() {
49 InitializeEmptyExtensionService();
50 static_cast<TestExtensionSystem*>(ExtensionSystem::Get(profile()))->
51 SetReady();
52 base::RunLoop().RunUntilIdle();
53 }
54
55 Profile* profile() { return profile_.get(); }
56 Extension* extension() { return extension_.get(); }
57
58 private:
59 scoped_refptr<Extension> extension_;
60 };
61
24 TEST(DeclarativeContentActionTest, InvalidCreation) { 62 TEST(DeclarativeContentActionTest, InvalidCreation) {
25 TestExtensionEnvironment env; 63 TestExtensionEnvironment env;
26 std::string error; 64 std::string error;
27 bool bad_message = false; 65 bool bad_message = false;
28 scoped_refptr<const ContentAction> result; 66 scoped_refptr<const ContentAction> result;
29 67
30 // Test wrong data type passed. 68 // Test wrong data type passed.
31 error.clear(); 69 error.clear();
32 result = ContentAction::Create(NULL, *ParseJson("[]"), &error, &bad_message); 70 result = ContentAction::Create(
71 NULL, NULL, *ParseJson("[]"), &error, &bad_message);
33 EXPECT_TRUE(bad_message); 72 EXPECT_TRUE(bad_message);
34 EXPECT_EQ("", error); 73 EXPECT_EQ("", error);
35 EXPECT_FALSE(result.get()); 74 EXPECT_FALSE(result.get());
36 75
37 // Test missing instanceType element. 76 // Test missing instanceType element.
38 error.clear(); 77 error.clear();
39 result = ContentAction::Create(NULL, *ParseJson("{}"), &error, &bad_message); 78 result = ContentAction::Create(
79 NULL, NULL, *ParseJson("{}"), &error, &bad_message);
40 EXPECT_TRUE(bad_message); 80 EXPECT_TRUE(bad_message);
41 EXPECT_EQ("", error); 81 EXPECT_EQ("", error);
42 EXPECT_FALSE(result.get()); 82 EXPECT_FALSE(result.get());
43 83
44 // Test wrong instanceType element. 84 // Test wrong instanceType element.
45 error.clear(); 85 error.clear();
46 result = ContentAction::Create(NULL, *ParseJson( 86 result = ContentAction::Create(NULL, NULL, *ParseJson(
47 "{\n" 87 "{\n"
48 " \"instanceType\": \"declarativeContent.UnknownType\",\n" 88 " \"instanceType\": \"declarativeContent.UnknownType\",\n"
49 "}"), 89 "}"),
50 &error, &bad_message); 90 &error, &bad_message);
51 EXPECT_THAT(error, HasSubstr("invalid instanceType")); 91 EXPECT_THAT(error, HasSubstr("invalid instanceType"));
52 EXPECT_FALSE(result.get()); 92 EXPECT_FALSE(result.get());
53 } 93 }
54 94
55 TEST(DeclarativeContentActionTest, ShowPageActionWithoutPageAction) { 95 TEST(DeclarativeContentActionTest, ShowPageActionWithoutPageAction) {
56 TestExtensionEnvironment env; 96 TestExtensionEnvironment env;
57 97
58 const Extension* extension = env.MakeExtension(base::DictionaryValue()); 98 const Extension* extension = env.MakeExtension(base::DictionaryValue());
59 std::string error; 99 std::string error;
60 bool bad_message = false; 100 bool bad_message = false;
61 scoped_refptr<const ContentAction> result = ContentAction::Create( 101 scoped_refptr<const ContentAction> result = ContentAction::Create(
102 NULL,
62 extension, 103 extension,
63 *ParseJson( 104 *ParseJson(
64 "{\n" 105 "{\n"
65 " \"instanceType\": \"declarativeContent.ShowPageAction\",\n" 106 " \"instanceType\": \"declarativeContent.ShowPageAction\",\n"
66 "}"), 107 "}"),
67 &error, 108 &error,
68 &bad_message); 109 &bad_message);
69 EXPECT_THAT(error, testing::HasSubstr("without a page action")); 110 EXPECT_THAT(error, testing::HasSubstr("without a page action"));
70 EXPECT_FALSE(bad_message); 111 EXPECT_FALSE(bad_message);
71 ASSERT_FALSE(result.get()); 112 ASSERT_FALSE(result.get());
72 } 113 }
73 114
74 TEST(DeclarativeContentActionTest, ShowPageAction) { 115 TEST(DeclarativeContentActionTest, ShowPageAction) {
75 TestExtensionEnvironment env; 116 TestExtensionEnvironment env;
76 117
77 const Extension* extension = env.MakeExtension( 118 const Extension* extension = env.MakeExtension(
78 *ParseJson("{\"page_action\": { \"default_title\": \"Extension\" } }")); 119 *ParseJson("{\"page_action\": { \"default_title\": \"Extension\" } }"));
79 std::string error; 120 std::string error;
80 bool bad_message = false; 121 bool bad_message = false;
81 scoped_refptr<const ContentAction> result = ContentAction::Create( 122 scoped_refptr<const ContentAction> result = ContentAction::Create(
123 NULL,
82 extension, 124 extension,
83 *ParseJson( 125 *ParseJson(
84 "{\n" 126 "{\n"
85 " \"instanceType\": \"declarativeContent.ShowPageAction\",\n" 127 " \"instanceType\": \"declarativeContent.ShowPageAction\",\n"
86 "}"), 128 "}"),
87 &error, 129 &error,
88 &bad_message); 130 &bad_message);
89 EXPECT_EQ("", error); 131 EXPECT_EQ("", error);
90 EXPECT_FALSE(bad_message); 132 EXPECT_FALSE(bad_message);
91 ASSERT_TRUE(result.get()); 133 ASSERT_TRUE(result.get());
(...skipping 10 matching lines...) Expand all
102 result->Apply(extension->id(), base::Time(), &apply_info); 144 result->Apply(extension->id(), base::Time(), &apply_info);
103 EXPECT_TRUE(page_action->GetIsVisible(tab_id)); 145 EXPECT_TRUE(page_action->GetIsVisible(tab_id));
104 result->Apply(extension->id(), base::Time(), &apply_info); 146 result->Apply(extension->id(), base::Time(), &apply_info);
105 EXPECT_TRUE(page_action->GetIsVisible(tab_id)); 147 EXPECT_TRUE(page_action->GetIsVisible(tab_id));
106 result->Revert(extension->id(), base::Time(), &apply_info); 148 result->Revert(extension->id(), base::Time(), &apply_info);
107 EXPECT_TRUE(page_action->GetIsVisible(tab_id)); 149 EXPECT_TRUE(page_action->GetIsVisible(tab_id));
108 result->Revert(extension->id(), base::Time(), &apply_info); 150 result->Revert(extension->id(), base::Time(), &apply_info);
109 EXPECT_FALSE(page_action->GetIsVisible(tab_id)); 151 EXPECT_FALSE(page_action->GetIsVisible(tab_id));
110 } 152 }
111 153
112 TEST(DeclarativeContentActionTest, RequestContentScriptMissingScripts) { 154 TEST_F(RequestContentScriptTest, MissingScripts) {
113 TestExtensionEnvironment env; 155 Init();
114
115 std::string error; 156 std::string error;
116 bool bad_message = false; 157 bool bad_message = false;
117 scoped_refptr<const ContentAction> result = ContentAction::Create( 158 scoped_refptr<const ContentAction> result = ContentAction::Create(
118 NULL, 159 profile(),
160 extension(),
119 *ParseJson( 161 *ParseJson(
120 "{\n" 162 "{\n"
121 " \"instanceType\": \"declarativeContent.RequestContentScript\",\n" 163 " \"instanceType\": \"declarativeContent.RequestContentScript\",\n"
122 " \"allFrames\": true,\n" 164 " \"allFrames\": true,\n"
123 " \"matchAboutBlank\": true\n" 165 " \"matchAboutBlank\": true\n"
124 "}"), 166 "}"),
125 &error, 167 &error,
126 &bad_message); 168 &bad_message);
127 EXPECT_THAT(error, testing::HasSubstr("Missing parameter is required")); 169 EXPECT_THAT(error, testing::HasSubstr("Missing parameter is required"));
128 EXPECT_FALSE(bad_message); 170 EXPECT_FALSE(bad_message);
129 ASSERT_FALSE(result.get()); 171 ASSERT_FALSE(result.get());
130 } 172 }
131 173
132 TEST(DeclarativeContentActionTest, RequestContentScriptCSS) { 174 TEST_F(RequestContentScriptTest, CSS) {
133 TestExtensionEnvironment env; 175 Init();
134
135 std::string error; 176 std::string error;
136 bool bad_message = false; 177 bool bad_message = false;
137 scoped_refptr<const ContentAction> result = ContentAction::Create( 178 scoped_refptr<const ContentAction> result = ContentAction::Create(
138 NULL, 179 profile(),
180 extension(),
139 *ParseJson( 181 *ParseJson(
140 "{\n" 182 "{\n"
141 " \"instanceType\": \"declarativeContent.RequestContentScript\",\n" 183 " \"instanceType\": \"declarativeContent.RequestContentScript\",\n"
142 " \"css\": [\"style.css\"]\n" 184 " \"css\": [\"style.css\"]\n"
143 "}"), 185 "}"),
144 &error, 186 &error,
145 &bad_message); 187 &bad_message);
146 EXPECT_EQ("", error); 188 EXPECT_EQ("", error);
147 EXPECT_FALSE(bad_message); 189 EXPECT_FALSE(bad_message);
148 ASSERT_TRUE(result.get()); 190 ASSERT_TRUE(result.get());
149 EXPECT_EQ(ContentAction::ACTION_REQUEST_CONTENT_SCRIPT, result->GetType()); 191 EXPECT_EQ(ContentAction::ACTION_REQUEST_CONTENT_SCRIPT, result->GetType());
150 } 192 }
151 193
152 TEST(DeclarativeContentActionTest, RequestContentScriptJS) { 194 TEST_F(RequestContentScriptTest, JS) {
153 TestExtensionEnvironment env; 195 Init();
154
155 std::string error; 196 std::string error;
156 bool bad_message = false; 197 bool bad_message = false;
157 scoped_refptr<const ContentAction> result = ContentAction::Create( 198 scoped_refptr<const ContentAction> result = ContentAction::Create(
158 NULL, 199 profile(),
200 extension(),
159 *ParseJson( 201 *ParseJson(
160 "{\n" 202 "{\n"
161 " \"instanceType\": \"declarativeContent.RequestContentScript\",\n" 203 " \"instanceType\": \"declarativeContent.RequestContentScript\",\n"
162 " \"js\": [\"script.js\"]\n" 204 " \"js\": [\"script.js\"]\n"
163 "}"), 205 "}"),
164 &error, 206 &error,
165 &bad_message); 207 &bad_message);
166 EXPECT_EQ("", error); 208 EXPECT_EQ("", error);
167 EXPECT_FALSE(bad_message); 209 EXPECT_FALSE(bad_message);
168 ASSERT_TRUE(result.get()); 210 ASSERT_TRUE(result.get());
169 EXPECT_EQ(ContentAction::ACTION_REQUEST_CONTENT_SCRIPT, result->GetType()); 211 EXPECT_EQ(ContentAction::ACTION_REQUEST_CONTENT_SCRIPT, result->GetType());
170 } 212 }
171 213
172 TEST(DeclarativeContentActionTest, RequestContentScriptCSSBadType) { 214 TEST_F(RequestContentScriptTest, CSSBadType) {
173 TestExtensionEnvironment env; 215 Init();
174
175 std::string error; 216 std::string error;
176 bool bad_message = false; 217 bool bad_message = false;
177 scoped_refptr<const ContentAction> result = ContentAction::Create( 218 scoped_refptr<const ContentAction> result = ContentAction::Create(
178 NULL, 219 profile(),
220 extension(),
179 *ParseJson( 221 *ParseJson(
180 "{\n" 222 "{\n"
181 " \"instanceType\": \"declarativeContent.RequestContentScript\",\n" 223 " \"instanceType\": \"declarativeContent.RequestContentScript\",\n"
182 " \"css\": \"style.css\"\n" 224 " \"css\": \"style.css\"\n"
183 "}"), 225 "}"),
184 &error, 226 &error,
185 &bad_message); 227 &bad_message);
186 EXPECT_TRUE(bad_message); 228 EXPECT_TRUE(bad_message);
187 ASSERT_FALSE(result.get()); 229 ASSERT_FALSE(result.get());
188 } 230 }
189 231
190 TEST(DeclarativeContentActionTest, RequestContentScriptJSBadType) { 232 TEST_F(RequestContentScriptTest, JSBadType) {
191 TestExtensionEnvironment env; 233 Init();
192
193 std::string error; 234 std::string error;
194 bool bad_message = false; 235 bool bad_message = false;
195 scoped_refptr<const ContentAction> result = ContentAction::Create( 236 scoped_refptr<const ContentAction> result = ContentAction::Create(
196 NULL, 237 profile(),
238 extension(),
197 *ParseJson( 239 *ParseJson(
198 "{\n" 240 "{\n"
199 " \"instanceType\": \"declarativeContent.RequestContentScript\",\n" 241 " \"instanceType\": \"declarativeContent.RequestContentScript\",\n"
200 " \"js\": \"script.js\"\n" 242 " \"js\": \"script.js\"\n"
201 "}"), 243 "}"),
202 &error, 244 &error,
203 &bad_message); 245 &bad_message);
204 EXPECT_TRUE(bad_message); 246 EXPECT_TRUE(bad_message);
205 ASSERT_FALSE(result.get()); 247 ASSERT_FALSE(result.get());
206 } 248 }
207 249
208 TEST(DeclarativeContentActionTest, RequestContentScriptAllFrames) { 250 TEST_F(RequestContentScriptTest, AllFrames) {
209 TestExtensionEnvironment env; 251 Init();
210
211 std::string error; 252 std::string error;
212 bool bad_message = false; 253 bool bad_message = false;
213 scoped_refptr<const ContentAction> result = ContentAction::Create( 254 scoped_refptr<const ContentAction> result = ContentAction::Create(
214 NULL, 255 profile(),
256 extension(),
215 *ParseJson( 257 *ParseJson(
216 "{\n" 258 "{\n"
217 " \"instanceType\": \"declarativeContent.RequestContentScript\",\n" 259 " \"instanceType\": \"declarativeContent.RequestContentScript\",\n"
218 " \"js\": [\"script.js\"],\n" 260 " \"js\": [\"script.js\"],\n"
219 " \"allFrames\": true\n" 261 " \"allFrames\": true\n"
220 "}"), 262 "}"),
221 &error, 263 &error,
222 &bad_message); 264 &bad_message);
223 EXPECT_EQ("", error); 265 EXPECT_EQ("", error);
224 EXPECT_FALSE(bad_message); 266 EXPECT_FALSE(bad_message);
225 ASSERT_TRUE(result.get()); 267 ASSERT_TRUE(result.get());
226 EXPECT_EQ(ContentAction::ACTION_REQUEST_CONTENT_SCRIPT, result->GetType()); 268 EXPECT_EQ(ContentAction::ACTION_REQUEST_CONTENT_SCRIPT, result->GetType());
227 } 269 }
228 270
229 TEST(DeclarativeContentActionTest, RequestContentScriptMatchAboutBlank) { 271 TEST_F(RequestContentScriptTest, MatchAboutBlank) {
230 TestExtensionEnvironment env; 272 Init();
231
232 std::string error; 273 std::string error;
233 bool bad_message = false; 274 bool bad_message = false;
234 scoped_refptr<const ContentAction> result = ContentAction::Create( 275 scoped_refptr<const ContentAction> result = ContentAction::Create(
235 NULL, 276 profile(),
277 extension(),
236 *ParseJson( 278 *ParseJson(
237 "{\n" 279 "{\n"
238 " \"instanceType\": \"declarativeContent.RequestContentScript\",\n" 280 " \"instanceType\": \"declarativeContent.RequestContentScript\",\n"
239 " \"js\": [\"script.js\"],\n" 281 " \"js\": [\"script.js\"],\n"
240 " \"matchAboutBlank\": true\n" 282 " \"matchAboutBlank\": true\n"
241 "}"), 283 "}"),
242 &error, 284 &error,
243 &bad_message); 285 &bad_message);
244 EXPECT_EQ("", error); 286 EXPECT_EQ("", error);
245 EXPECT_FALSE(bad_message); 287 EXPECT_FALSE(bad_message);
246 ASSERT_TRUE(result.get()); 288 ASSERT_TRUE(result.get());
247 EXPECT_EQ(ContentAction::ACTION_REQUEST_CONTENT_SCRIPT, result->GetType()); 289 EXPECT_EQ(ContentAction::ACTION_REQUEST_CONTENT_SCRIPT, result->GetType());
248 } 290 }
249 291
250 TEST(DeclarativeContentActionTest, RequestContentScriptAllFramesBadType) { 292 TEST_F(RequestContentScriptTest, AllFramesBadType) {
251 TestExtensionEnvironment env; 293 Init();
252
253 std::string error; 294 std::string error;
254 bool bad_message = false; 295 bool bad_message = false;
255 scoped_refptr<const ContentAction> result = ContentAction::Create( 296 scoped_refptr<const ContentAction> result = ContentAction::Create(
256 NULL, 297 profile(),
298 extension(),
257 *ParseJson( 299 *ParseJson(
258 "{\n" 300 "{\n"
259 " \"instanceType\": \"declarativeContent.RequestContentScript\",\n" 301 " \"instanceType\": \"declarativeContent.RequestContentScript\",\n"
260 " \"js\": [\"script.js\"],\n" 302 " \"js\": [\"script.js\"],\n"
261 " \"allFrames\": null\n" 303 " \"allFrames\": null\n"
262 "}"), 304 "}"),
263 &error, 305 &error,
264 &bad_message); 306 &bad_message);
265 EXPECT_TRUE(bad_message); 307 EXPECT_TRUE(bad_message);
266 ASSERT_FALSE(result.get()); 308 ASSERT_FALSE(result.get());
267 } 309 }
268 310
269 TEST(DeclarativeContentActionTest, RequestContentScriptMatchAboutBlankBadType) { 311 TEST_F(RequestContentScriptTest, MatchAboutBlankBadType) {
270 TestExtensionEnvironment env; 312 Init();
271
272 std::string error; 313 std::string error;
273 bool bad_message = false; 314 bool bad_message = false;
274 scoped_refptr<const ContentAction> result = ContentAction::Create( 315 scoped_refptr<const ContentAction> result = ContentAction::Create(
275 NULL, 316 profile(),
317 extension(),
276 *ParseJson( 318 *ParseJson(
277 "{\n" 319 "{\n"
278 " \"instanceType\": \"declarativeContent.RequestContentScript\",\n" 320 " \"instanceType\": \"declarativeContent.RequestContentScript\",\n"
279 " \"js\": [\"script.js\"],\n" 321 " \"js\": [\"script.js\"],\n"
280 " \"matchAboutBlank\": null\n" 322 " \"matchAboutBlank\": null\n"
281 "}"), 323 "}"),
282 &error, 324 &error,
283 &bad_message); 325 &bad_message);
284 EXPECT_TRUE(bad_message); 326 EXPECT_TRUE(bad_message);
285 ASSERT_FALSE(result.get()); 327 ASSERT_FALSE(result.get());
286 } 328 }
287 329
288 } // namespace 330 } // namespace
289 } // namespace extensions 331 } // namespace extensions
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698