| OLD | NEW |
| 1 // Copyright (c) 2011 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2011 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/extension_browsertest.h" | 5 #include "chrome/browser/extensions/extension_browsertest.h" |
| 6 | 6 |
| 7 #include <vector> | 7 #include <vector> |
| 8 | 8 |
| 9 #include "base/command_line.h" | 9 #include "base/command_line.h" |
| 10 #include "base/file_path.h" | 10 #include "base/file_path.h" |
| (...skipping 211 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 222 public: | 222 public: |
| 223 explicit MockAutoConfirmExtensionInstallUI(Profile* profile) : | 223 explicit MockAutoConfirmExtensionInstallUI(Profile* profile) : |
| 224 ExtensionInstallUI(profile) {} | 224 ExtensionInstallUI(profile) {} |
| 225 | 225 |
| 226 // Proceed without confirmation prompt. | 226 // Proceed without confirmation prompt. |
| 227 virtual void ConfirmInstall(Delegate* delegate, const Extension* extension) { | 227 virtual void ConfirmInstall(Delegate* delegate, const Extension* extension) { |
| 228 delegate->InstallUIProceed(); | 228 delegate->InstallUIProceed(); |
| 229 } | 229 } |
| 230 }; | 230 }; |
| 231 | 231 |
| 232 bool ExtensionBrowserTest::InstallExtensionFromWebstore(const FilePath& path, | 232 const Extension* ExtensionBrowserTest::InstallExtensionFromWebstore( |
| 233 int expected_change) { | 233 const FilePath& path, |
| 234 int expected_change) { |
| 234 return InstallOrUpdateExtension("", path, INSTALL_UI_TYPE_NONE, | 235 return InstallOrUpdateExtension("", path, INSTALL_UI_TYPE_NONE, |
| 235 expected_change, browser()->profile(), | 236 expected_change, browser()->profile(), |
| 236 true); | 237 true); |
| 237 } | 238 } |
| 238 | 239 |
| 239 bool ExtensionBrowserTest::InstallOrUpdateExtension(const std::string& id, | 240 const Extension* ExtensionBrowserTest::InstallOrUpdateExtension( |
| 240 const FilePath& path, | 241 const std::string& id, |
| 241 InstallUIType ui_type, | 242 const FilePath& path, |
| 242 int expected_change) { | 243 InstallUIType ui_type, |
| 244 int expected_change) { |
| 243 return InstallOrUpdateExtension(id, path, ui_type, expected_change, | 245 return InstallOrUpdateExtension(id, path, ui_type, expected_change, |
| 244 browser()->profile(), false); | 246 browser()->profile(), false); |
| 245 } | 247 } |
| 246 | 248 |
| 247 bool ExtensionBrowserTest::InstallOrUpdateExtension(const std::string& id, | 249 const Extension* ExtensionBrowserTest::InstallOrUpdateExtension( |
| 248 const FilePath& path, | 250 const std::string& id, |
| 249 InstallUIType ui_type, | 251 const FilePath& path, |
| 250 int expected_change, | 252 InstallUIType ui_type, |
| 251 Profile* profile, | 253 int expected_change, |
| 252 bool from_webstore) { | 254 Profile* profile, |
| 255 bool from_webstore) { |
| 253 ExtensionService* service = profile->GetExtensionService(); | 256 ExtensionService* service = profile->GetExtensionService(); |
| 254 service->set_show_extensions_prompts(false); | 257 service->set_show_extensions_prompts(false); |
| 255 size_t num_before = service->extensions()->size(); | 258 size_t num_before = service->extensions()->size(); |
| 256 | 259 |
| 257 { | 260 { |
| 258 content::NotificationRegistrar registrar; | |
| 259 registrar.Add(this, chrome::NOTIFICATION_EXTENSION_LOADED, | |
| 260 content::NotificationService::AllSources()); | |
| 261 registrar.Add(this, chrome::NOTIFICATION_EXTENSION_UPDATE_DISABLED, | |
| 262 content::NotificationService::AllSources()); | |
| 263 registrar.Add(this, chrome::NOTIFICATION_EXTENSION_INSTALL_ERROR, | |
| 264 content::NotificationService::AllSources()); | |
| 265 registrar.Add(this, chrome::NOTIFICATION_EXTENSION_LOAD_ERROR, | |
| 266 content::NotificationService::AllSources()); | |
| 267 | |
| 268 ExtensionInstallUI* install_ui = NULL; | 261 ExtensionInstallUI* install_ui = NULL; |
| 269 if (ui_type == INSTALL_UI_TYPE_CANCEL) | 262 if (ui_type == INSTALL_UI_TYPE_CANCEL) |
| 270 install_ui = new MockAbortExtensionInstallUI(); | 263 install_ui = new MockAbortExtensionInstallUI(); |
| 271 else if (ui_type == INSTALL_UI_TYPE_NORMAL) | 264 else if (ui_type == INSTALL_UI_TYPE_NORMAL) |
| 272 install_ui = new ExtensionInstallUI(profile); | 265 install_ui = new ExtensionInstallUI(profile); |
| 273 else if (ui_type == INSTALL_UI_TYPE_AUTO_CONFIRM) | 266 else if (ui_type == INSTALL_UI_TYPE_AUTO_CONFIRM) |
| 274 install_ui = new MockAutoConfirmExtensionInstallUI(profile); | 267 install_ui = new MockAutoConfirmExtensionInstallUI(profile); |
| 275 | 268 |
| 276 // TODO(tessamac): Update callers to always pass an unpacked extension | 269 // TODO(tessamac): Update callers to always pass an unpacked extension |
| 277 // and then always pack the extension here. | 270 // and then always pack the extension here. |
| 278 FilePath crx_path = path; | 271 FilePath crx_path = path; |
| 279 if (crx_path.Extension() != FILE_PATH_LITERAL(".crx")) { | 272 if (crx_path.Extension() != FILE_PATH_LITERAL(".crx")) { |
| 280 crx_path = PackExtension(path); | 273 crx_path = PackExtension(path); |
| 281 } | 274 } |
| 282 if (crx_path.empty()) | 275 if (crx_path.empty()) |
| 283 return false; | 276 return NULL; |
| 284 | 277 |
| 285 scoped_refptr<CrxInstaller> installer( | 278 scoped_refptr<CrxInstaller> installer( |
| 286 CrxInstaller::Create(service, install_ui)); | 279 CrxInstaller::Create(service, install_ui)); |
| 287 installer->set_expected_id(id); | 280 installer->set_expected_id(id); |
| 288 installer->set_is_gallery_install(from_webstore); | 281 installer->set_is_gallery_install(from_webstore); |
| 282 |
| 283 content::NotificationRegistrar registrar; |
| 284 registrar.Add(this, chrome::NOTIFICATION_CRX_INSTALLER_DONE, |
| 285 content::Source<CrxInstaller>(installer.get())); |
| 286 |
| 289 installer->InstallCrx(crx_path); | 287 installer->InstallCrx(crx_path); |
| 290 | 288 |
| 291 ui_test_utils::RunMessageLoop(); | 289 ui_test_utils::RunMessageLoop(); |
| 292 } | 290 } |
| 293 | 291 |
| 294 size_t num_after = service->extensions()->size(); | 292 size_t num_after = service->extensions()->size(); |
| 295 if (num_after != (num_before + expected_change)) { | 293 EXPECT_EQ(num_before + expected_change, num_after); |
| 294 if (num_before + expected_change != num_after) { |
| 296 VLOG(1) << "Num extensions before: " << base::IntToString(num_before) | 295 VLOG(1) << "Num extensions before: " << base::IntToString(num_before) |
| 297 << " num after: " << base::IntToString(num_after) | 296 << " num after: " << base::IntToString(num_after) |
| 298 << " Installed extensions follow:"; | 297 << " Installed extensions follow:"; |
| 299 | 298 |
| 300 for (size_t i = 0; i < service->extensions()->size(); ++i) | 299 for (size_t i = 0; i < service->extensions()->size(); ++i) |
| 301 VLOG(1) << " " << (*service->extensions())[i]->id(); | 300 VLOG(1) << " " << (*service->extensions())[i]->id(); |
| 302 | 301 |
| 303 VLOG(1) << "Errors follow:"; | 302 VLOG(1) << "Errors follow:"; |
| 304 const std::vector<std::string>* errors = | 303 const std::vector<std::string>* errors = |
| 305 ExtensionErrorReporter::GetInstance()->GetErrors(); | 304 ExtensionErrorReporter::GetInstance()->GetErrors(); |
| 306 for (std::vector<std::string>::const_iterator iter = errors->begin(); | 305 for (std::vector<std::string>::const_iterator iter = errors->begin(); |
| 307 iter != errors->end(); ++iter) | 306 iter != errors->end(); ++iter) |
| 308 VLOG(1) << *iter; | 307 VLOG(1) << *iter; |
| 309 | 308 |
| 310 return false; | 309 return NULL; |
| 311 } | 310 } |
| 312 | 311 |
| 313 return WaitForExtensionHostsToLoad(); | 312 if (!WaitForExtensionHostsToLoad()) |
| 313 return NULL; |
| 314 return service->GetExtensionById(last_loaded_extension_id_, false); |
| 314 } | 315 } |
| 315 | 316 |
| 316 void ExtensionBrowserTest::ReloadExtension(const std::string& extension_id) { | 317 void ExtensionBrowserTest::ReloadExtension(const std::string& extension_id) { |
| 317 ExtensionService* service = browser()->profile()->GetExtensionService(); | 318 ExtensionService* service = browser()->profile()->GetExtensionService(); |
| 318 service->ReloadExtension(extension_id); | 319 service->ReloadExtension(extension_id); |
| 319 ui_test_utils::RegisterAndWait(this, | 320 ui_test_utils::RegisterAndWait(this, |
| 320 chrome::NOTIFICATION_EXTENSION_LOADED, | 321 chrome::NOTIFICATION_EXTENSION_LOADED, |
| 321 content::NotificationService::AllSources()); | 322 content::NotificationService::AllSources()); |
| 322 } | 323 } |
| 323 | 324 |
| (...skipping 106 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 430 const content::NotificationSource& source, | 431 const content::NotificationSource& source, |
| 431 const content::NotificationDetails& details) { | 432 const content::NotificationDetails& details) { |
| 432 switch (type) { | 433 switch (type) { |
| 433 case chrome::NOTIFICATION_EXTENSION_LOADED: | 434 case chrome::NOTIFICATION_EXTENSION_LOADED: |
| 434 last_loaded_extension_id_ = | 435 last_loaded_extension_id_ = |
| 435 content::Details<const Extension>(details).ptr()->id(); | 436 content::Details<const Extension>(details).ptr()->id(); |
| 436 VLOG(1) << "Got EXTENSION_LOADED notification."; | 437 VLOG(1) << "Got EXTENSION_LOADED notification."; |
| 437 MessageLoopForUI::current()->Quit(); | 438 MessageLoopForUI::current()->Quit(); |
| 438 break; | 439 break; |
| 439 | 440 |
| 440 case chrome::NOTIFICATION_EXTENSION_UPDATE_DISABLED: | 441 case chrome::NOTIFICATION_CRX_INSTALLER_DONE: |
| 441 VLOG(1) << "Got EXTENSION_UPDATE_DISABLED notification."; | 442 VLOG(1) << "Got CRX_INSTALLER_DONE notification."; |
| 443 { |
| 444 const Extension* extension = |
| 445 content::Details<const Extension>(details).ptr(); |
| 446 if (extension) |
| 447 last_loaded_extension_id_ = extension->id(); |
| 448 else |
| 449 last_loaded_extension_id_ = ""; |
| 450 } |
| 442 MessageLoopForUI::current()->Quit(); | 451 MessageLoopForUI::current()->Quit(); |
| 443 break; | 452 break; |
| 444 | 453 |
| 445 case chrome::NOTIFICATION_EXTENSION_HOST_DID_STOP_LOADING: | 454 case chrome::NOTIFICATION_EXTENSION_HOST_DID_STOP_LOADING: |
| 446 VLOG(1) << "Got EXTENSION_HOST_DID_STOP_LOADING notification."; | 455 VLOG(1) << "Got EXTENSION_HOST_DID_STOP_LOADING notification."; |
| 447 MessageLoopForUI::current()->Quit(); | 456 MessageLoopForUI::current()->Quit(); |
| 448 break; | 457 break; |
| 449 | 458 |
| 450 case chrome::NOTIFICATION_EXTENSION_INSTALLED: | 459 case chrome::NOTIFICATION_EXTENSION_INSTALLED: |
| 451 VLOG(1) << "Got EXTENSION_INSTALLED notification."; | 460 VLOG(1) << "Got EXTENSION_INSTALLED notification."; |
| 452 ++extension_installs_observed_; | 461 ++extension_installs_observed_; |
| 453 MessageLoopForUI::current()->Quit(); | 462 MessageLoopForUI::current()->Quit(); |
| 454 break; | 463 break; |
| 455 | 464 |
| 456 case chrome::NOTIFICATION_EXTENSION_LOAD_ERROR: | |
| 457 VLOG(1) << "Got EXTENSION_LOAD_ERROR notification."; | |
| 458 MessageLoopForUI::current()->Quit(); | |
| 459 break; | |
| 460 | |
| 461 case chrome::NOTIFICATION_EXTENSION_INSTALL_ERROR: | 465 case chrome::NOTIFICATION_EXTENSION_INSTALL_ERROR: |
| 462 VLOG(1) << "Got EXTENSION_INSTALL_ERROR notification."; | 466 VLOG(1) << "Got EXTENSION_INSTALL_ERROR notification."; |
| 463 MessageLoopForUI::current()->Quit(); | 467 MessageLoopForUI::current()->Quit(); |
| 464 break; | 468 break; |
| 465 | 469 |
| 466 case chrome::NOTIFICATION_EXTENSION_PROCESS_TERMINATED: | 470 case chrome::NOTIFICATION_EXTENSION_PROCESS_TERMINATED: |
| 467 VLOG(1) << "Got EXTENSION_PROCESS_TERMINATED notification."; | 471 VLOG(1) << "Got EXTENSION_PROCESS_TERMINATED notification."; |
| 468 MessageLoopForUI::current()->Quit(); | 472 MessageLoopForUI::current()->Quit(); |
| 469 break; | 473 break; |
| 470 | 474 |
| (...skipping 22 matching lines...) Expand all Loading... |
| 493 MessageLoopForUI::current()->Quit(); | 497 MessageLoopForUI::current()->Quit(); |
| 494 } | 498 } |
| 495 break; | 499 break; |
| 496 } | 500 } |
| 497 | 501 |
| 498 default: | 502 default: |
| 499 NOTREACHED(); | 503 NOTREACHED(); |
| 500 break; | 504 break; |
| 501 } | 505 } |
| 502 } | 506 } |
| OLD | NEW |