| OLD | NEW |
| 1 // Copyright 2013 The Chromium Authors. All rights reserved. | 1 // Copyright 2013 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/ui/webui/extensions/extension_settings_browsertest.h" | 5 #include "chrome/browser/ui/webui/extensions/extension_settings_browsertest.h" |
| 6 | 6 |
| 7 #include "base/files/file_path.h" | 7 #include "base/files/file_path.h" |
| 8 #include "base/path_service.h" | 8 #include "base/path_service.h" |
| 9 #include "base/strings/string_number_conversions.h" | 9 #include "base/strings/string_number_conversions.h" |
| 10 #include "chrome/browser/chrome_notification_types.h" | 10 #include "chrome/browser/chrome_notification_types.h" |
| (...skipping 16 matching lines...) Expand all Loading... |
| 27 #include "extensions/browser/api/management/management_api.h" | 27 #include "extensions/browser/api/management/management_api.h" |
| 28 #include "extensions/browser/extension_registry.h" | 28 #include "extensions/browser/extension_registry.h" |
| 29 #include "extensions/browser/extension_system.h" | 29 #include "extensions/browser/extension_system.h" |
| 30 #include "extensions/browser/test_extension_registry_observer.h" | 30 #include "extensions/browser/test_extension_registry_observer.h" |
| 31 #include "extensions/common/extension_set.h" | 31 #include "extensions/common/extension_set.h" |
| 32 | 32 |
| 33 using extensions::Extension; | 33 using extensions::Extension; |
| 34 using extensions::TestManagementPolicyProvider; | 34 using extensions::TestManagementPolicyProvider; |
| 35 | 35 |
| 36 ExtensionSettingsUIBrowserTest::ExtensionSettingsUIBrowserTest() | 36 ExtensionSettingsUIBrowserTest::ExtensionSettingsUIBrowserTest() |
| 37 : profile_(NULL), | 37 : profile_(nullptr), |
| 38 policy_provider_(TestManagementPolicyProvider::PROHIBIT_MODIFY_STATUS | | 38 policy_provider_(TestManagementPolicyProvider::PROHIBIT_MODIFY_STATUS | |
| 39 TestManagementPolicyProvider::MUST_REMAIN_ENABLED | | 39 TestManagementPolicyProvider::MUST_REMAIN_ENABLED | |
| 40 TestManagementPolicyProvider::MUST_REMAIN_INSTALLED) { | 40 TestManagementPolicyProvider::MUST_REMAIN_INSTALLED) { |
| 41 CHECK(PathService::Get(chrome::DIR_TEST_DATA, &test_data_dir_)); | 41 CHECK(PathService::Get(chrome::DIR_TEST_DATA, &test_data_dir_)); |
| 42 test_data_dir_ = test_data_dir_.AppendASCII("extensions"); | 42 test_data_dir_ = test_data_dir_.AppendASCII("extensions"); |
| 43 } | 43 } |
| 44 | 44 |
| 45 ExtensionSettingsUIBrowserTest::~ExtensionSettingsUIBrowserTest() {} | 45 ExtensionSettingsUIBrowserTest::~ExtensionSettingsUIBrowserTest() {} |
| 46 | 46 |
| 47 Profile* ExtensionSettingsUIBrowserTest::GetProfile() { | 47 Profile* ExtensionSettingsUIBrowserTest::GetProfile() { |
| (...skipping 35 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 83 | 83 |
| 84 void ExtensionSettingsUIBrowserTest::AddManagedPolicyProvider() { | 84 void ExtensionSettingsUIBrowserTest::AddManagedPolicyProvider() { |
| 85 auto* extension_service = extensions::ExtensionSystem::Get(GetProfile()); | 85 auto* extension_service = extensions::ExtensionSystem::Get(GetProfile()); |
| 86 extension_service->management_policy()->RegisterProvider(&policy_provider_); | 86 extension_service->management_policy()->RegisterProvider(&policy_provider_); |
| 87 } | 87 } |
| 88 | 88 |
| 89 void ExtensionSettingsUIBrowserTest::SetAutoConfirmUninstall() { | 89 void ExtensionSettingsUIBrowserTest::SetAutoConfirmUninstall() { |
| 90 extensions::ManagementUninstallFunctionBase::SetAutoConfirmForTest(true); | 90 extensions::ManagementUninstallFunctionBase::SetAutoConfirmForTest(true); |
| 91 } | 91 } |
| 92 | 92 |
| 93 void ExtensionSettingsUIBrowserTest::EnableErrorConsole() { |
| 94 error_console_override_.reset(new extensions::FeatureSwitch::ScopedOverride( |
| 95 extensions::FeatureSwitch::error_console(), true)); |
| 96 } |
| 97 |
| 93 class MockAutoConfirmExtensionInstallPrompt : public ExtensionInstallPrompt { | 98 class MockAutoConfirmExtensionInstallPrompt : public ExtensionInstallPrompt { |
| 94 public: | 99 public: |
| 95 explicit MockAutoConfirmExtensionInstallPrompt( | 100 explicit MockAutoConfirmExtensionInstallPrompt( |
| 96 content::WebContents* web_contents) | 101 content::WebContents* web_contents) |
| 97 : ExtensionInstallPrompt(web_contents) {} | 102 : ExtensionInstallPrompt(web_contents) {} |
| 98 | 103 |
| 99 // Proceed without confirmation prompt. | 104 // Proceed without confirmation prompt. |
| 100 void ConfirmInstall(Delegate* delegate, | 105 void ConfirmInstall(Delegate* delegate, |
| 101 const Extension* extension, | 106 const Extension* extension, |
| 102 const ShowDialogCallback& show_dialog_callback) override { | 107 const ShowDialogCallback& show_dialog_callback) override { |
| 103 delegate->InstallUIProceed(); | 108 delegate->InstallUIProceed(); |
| 104 } | 109 } |
| 105 }; | 110 }; |
| 106 | 111 |
| 107 const Extension* ExtensionSettingsUIBrowserTest::InstallUnpackedExtension( | 112 const Extension* ExtensionSettingsUIBrowserTest::InstallUnpackedExtension( |
| 108 const base::FilePath& path) { | 113 const base::FilePath& path) { |
| 109 if (path.empty()) | 114 if (path.empty()) |
| 110 return NULL; | 115 return nullptr; |
| 111 | 116 |
| 112 Profile* profile = GetProfile(); | 117 Profile* profile = GetProfile(); |
| 113 ExtensionService* service = | 118 ExtensionService* service = |
| 114 extensions::ExtensionSystem::Get(profile)->extension_service(); | 119 extensions::ExtensionSystem::Get(profile)->extension_service(); |
| 115 service->set_show_extensions_prompts(false); | 120 service->set_show_extensions_prompts(false); |
| 116 extensions::ExtensionRegistry* registry = | 121 extensions::ExtensionRegistry* registry = |
| 117 extensions::ExtensionRegistry::Get(profile); | 122 extensions::ExtensionRegistry::Get(profile); |
| 118 extensions::TestExtensionRegistryObserver observer(registry); | 123 extensions::TestExtensionRegistryObserver observer(registry); |
| 119 extensions::UnpackedInstaller::Create(service)->Load(path); | 124 extensions::UnpackedInstaller::Create(service)->Load(path); |
| 120 base::FilePath extension_path = base::MakeAbsoluteFilePath(path); | 125 base::FilePath extension_path = base::MakeAbsoluteFilePath(path); |
| (...skipping 15 matching lines...) Expand all Loading... |
| 136 service->set_show_extensions_prompts(false); | 141 service->set_show_extensions_prompts(false); |
| 137 size_t num_before = registry->enabled_extensions().size(); | 142 size_t num_before = registry->enabled_extensions().size(); |
| 138 { | 143 { |
| 139 scoped_ptr<ExtensionInstallPrompt> install_ui; | 144 scoped_ptr<ExtensionInstallPrompt> install_ui; |
| 140 install_ui.reset(new MockAutoConfirmExtensionInstallPrompt( | 145 install_ui.reset(new MockAutoConfirmExtensionInstallPrompt( |
| 141 browser()->tab_strip_model()->GetActiveWebContents())); | 146 browser()->tab_strip_model()->GetActiveWebContents())); |
| 142 | 147 |
| 143 base::FilePath crx_path = path; | 148 base::FilePath crx_path = path; |
| 144 DCHECK(crx_path.Extension() == FILE_PATH_LITERAL(".crx")); | 149 DCHECK(crx_path.Extension() == FILE_PATH_LITERAL(".crx")); |
| 145 if (crx_path.empty()) | 150 if (crx_path.empty()) |
| 146 return NULL; | 151 return nullptr; |
| 147 | 152 |
| 148 scoped_refptr<extensions::CrxInstaller> installer( | 153 scoped_refptr<extensions::CrxInstaller> installer( |
| 149 extensions::CrxInstaller::Create(service, install_ui.Pass())); | 154 extensions::CrxInstaller::Create(service, install_ui.Pass())); |
| 150 installer->set_expected_id(std::string()); | 155 installer->set_expected_id(std::string()); |
| 151 installer->set_is_gallery_install(false); | 156 installer->set_is_gallery_install(false); |
| 152 installer->set_install_source(extensions::Manifest::INTERNAL); | 157 installer->set_install_source(extensions::Manifest::INTERNAL); |
| 153 installer->set_install_immediately(true); | 158 installer->set_install_immediately(true); |
| 154 installer->set_off_store_install_allow_reason( | 159 installer->set_off_store_install_allow_reason( |
| 155 extensions::CrxInstaller::OffStoreInstallAllowedInTest); | 160 extensions::CrxInstaller::OffStoreInstallAllowedInTest); |
| 156 | 161 |
| (...skipping 16 matching lines...) Expand all Loading... |
| 173 registry->enabled_extensions()) | 178 registry->enabled_extensions()) |
| 174 VLOG(1) << " " << extension->id(); | 179 VLOG(1) << " " << extension->id(); |
| 175 | 180 |
| 176 VLOG(1) << "Errors follow:"; | 181 VLOG(1) << "Errors follow:"; |
| 177 const std::vector<base::string16>* errors = | 182 const std::vector<base::string16>* errors = |
| 178 ExtensionErrorReporter::GetInstance()->GetErrors(); | 183 ExtensionErrorReporter::GetInstance()->GetErrors(); |
| 179 for (std::vector<base::string16>::const_iterator iter = errors->begin(); | 184 for (std::vector<base::string16>::const_iterator iter = errors->begin(); |
| 180 iter != errors->end(); ++iter) | 185 iter != errors->end(); ++iter) |
| 181 VLOG(1) << *iter; | 186 VLOG(1) << *iter; |
| 182 | 187 |
| 183 return NULL; | 188 return nullptr; |
| 184 } | 189 } |
| 185 | 190 |
| 186 if (!observer_->WaitForExtensionViewsToLoad()) | 191 if (!observer_->WaitForExtensionViewsToLoad()) |
| 187 return NULL; | 192 return nullptr; |
| 188 return service->GetExtensionById(last_loaded_extension_id(), false); | 193 return service->GetExtensionById(last_loaded_extension_id(), false); |
| 189 } | 194 } |
| OLD | NEW |