1 // Copyright (c) 2013 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
9 #include "base/at_exit.h"
10 #include "base/basictypes.h"
11 #include "base/bind.h"
12 #include "base/command_line.h"
13 #include "base/files/file_enumerator.h"
14 #include "base/files/file_util.h"
15 #include "base/files/scoped_temp_dir.h"
16 #include "base/json/json_file_value_serializer.h"
17 #include "base/json/json_reader.h"
18 #include "base/json/json_string_value_serializer.h"
19 #include "base/location.h"
20 #include "base/memory/scoped_ptr.h"
21 #include "base/memory/weak_ptr.h"
22 #include "base/metrics/field_trial.h"
23 #include "base/prefs/scoped_user_pref_update.h"
24 #include "base/single_thread_task_runner.h"
25 #include "base/stl_util.h"
26 #include "base/strings/pattern.h"
27 #include "base/strings/string16.h"
28 #include "base/strings/string_number_conversions.h"
29 #include "base/strings/string_util.h"
30 #include "base/strings/utf_string_conversions.h"
31 #include "base/test/mock_entropy_provider.h"
32 #include "base/thread_task_runner_handle.h"
33 #include "base/version.h"
34 #include "chrome/browser/browser_process.h"
35 #include "chrome/browser/chrome_notification_types.h"
36 #include "chrome/browser/extensions/blacklist.h"
37 #include "chrome/browser/extensions/chrome_app_sorting.h"
38 #include "chrome/browser/extensions/component_loader.h"
39 #include "chrome/browser/extensions/crx_installer.h"
40 #include "chrome/browser/extensions/default_apps.h"
41 #include "chrome/browser/extensions/extension_creator.h"
42 #include "chrome/browser/extensions/extension_error_reporter.h"
43 #include "chrome/browser/extensions/extension_error_ui.h"
44 #include "chrome/browser/extensions/extension_management_test_util.h"
45 #include "chrome/browser/extensions/extension_notification_observer.h"
46 #include "chrome/browser/extensions/extension_service.h"
47 #include "chrome/browser/extensions/extension_service_test_base.h"
48 #include "chrome/browser/extensions/extension_special_storage_policy.h"
49 #include "chrome/browser/extensions/extension_sync_data.h"
50 #include "chrome/browser/extensions/extension_sync_service.h"
51 #include "chrome/browser/extensions/extension_util.h"
52 #include "chrome/browser/extensions/external_install_error.h"
53 #include "chrome/browser/extensions/external_install_manager.h"
54 #include "chrome/browser/extensions/external_policy_loader.h"
55 #include "chrome/browser/extensions/external_pref_loader.h"
56 #include "chrome/browser/extensions/external_provider_impl.h"
57 #include "chrome/browser/extensions/fake_safe_browsing_database_manager.h"
58 #include "chrome/browser/extensions/installed_loader.h"
59 #include "chrome/browser/extensions/pack_extension_job.h"
60 #include "chrome/browser/extensions/pending_extension_info.h"
61 #include "chrome/browser/extensions/pending_extension_manager.h"
62 #include "chrome/browser/extensions/permissions_updater.h"
63 #include "chrome/browser/extensions/test_blacklist.h"
64 #include "chrome/browser/extensions/test_extension_system.h"
65 #include "chrome/browser/extensions/unpacked_installer.h"
66 #include "chrome/browser/extensions/updater/extension_updater.h"
67 #include "chrome/browser/policy/profile_policy_connector.h"
68 #include "chrome/browser/policy/profile_policy_connector_factory.h"
69 #include "chrome/browser/prefs/pref_service_syncable.h"
70 #include "chrome/browser/sync/profile_sync_service.h"
71 #include "chrome/browser/sync/profile_sync_service_factory.h"
72 #include "chrome/common/chrome_constants.h"
73 #include "chrome/common/chrome_switches.h"
74 #include "chrome/common/extensions/api/plugins/plugins_handler.h"
75 #include "chrome/common/extensions/manifest_handlers/app_launch_info.h"
76 #include "chrome/common/extensions/manifest_handlers/content_scripts_handler.h"
77 #include "chrome/common/extensions/sync_helper.h"
78 #include "chrome/common/pref_names.h"
79 #include "chrome/common/url_constants.h"
80 #include "chrome/test/base/scoped_browser_locale.h"
81 #include "chrome/test/base/testing_pref_service_syncable.h"
82 #include "chrome/test/base/testing_profile.h"
83 #include "components/crx_file/id_util.h"
84 #include "components/pref_registry/pref_registry_syncable.h"
85 #include "content/public/browser/dom_storage_context.h"
86 #include "content/public/browser/gpu_data_manager.h"
87 #include "content/public/browser/indexed_db_context.h"
88 #include "content/public/browser/notification_registrar.h"
89 #include "content/public/browser/notification_service.h"
90 #include "content/public/browser/plugin_service.h"
91 #include "content/public/browser/render_process_host.h"
92 #include "content/public/browser/storage_partition.h"
93 #include "content/public/common/content_constants.h"
94 #include "content/public/test/test_browser_thread_bundle.h"
95 #include "content/public/test/test_utils.h"
96 #include "extensions/browser/extension_dialog_auto_confirm.h"
97 #include "extensions/browser/extension_prefs.h"
98 #include "extensions/browser/extension_registry.h"
99 #include "extensions/browser/extension_system.h"
100 #include "extensions/browser/external_provider_interface.h"
101 #include "extensions/browser/install_flag.h"
102 #include "extensions/browser/management_policy.h"
103 #include "extensions/browser/test_management_policy.h"
104 #include "extensions/browser/uninstall_reason.h"
105 #include "extensions/common/constants.h"
106 #include "extensions/common/extension.h"
107 #include "extensions/common/extension_builder.h"
108 #include "extensions/common/extension_l10n_util.h"
109 #include "extensions/common/extension_resource.h"
110 #include "extensions/common/feature_switch.h"
111 #include "extensions/common/manifest_constants.h"
112 #include "extensions/common/manifest_handlers/background_info.h"
113 #include "extensions/common/manifest_handlers/permissions_parser.h"
114 #include "extensions/common/manifest_url_handlers.h"
115 #include "extensions/common/permissions/permission_set.h"
116 #include "extensions/common/permissions/permissions_data.h"
117 #include "extensions/common/switches.h"
118 #include "extensions/common/url_pattern.h"
119 #include "extensions/common/value_builder.h"
120 #include "gpu/config/gpu_info.h"
121 #include "grit/browser_resources.h"
122 #include "grit/generated_resources.h"
123 #include "net/cookies/canonical_cookie.h"
124 #include "net/cookies/cookie_monster.h"
125 #include "net/cookies/cookie_options.h"
126 #include "net/url_request/url_request_context.h"
127 #include "net/url_request/url_request_context_getter.h"
128 #include "storage/browser/database/database_tracker.h"
129 #include "storage/browser/quota/quota_manager.h"
130 #include "storage/common/database/database_identifier.h"
131 #include "sync/api/fake_sync_change_processor.h"
132 #include "sync/api/string_ordinal.h"
133 #include "sync/api/sync_data.h"
134 #include "sync/api/sync_error_factory.h"
135 #include "sync/api/sync_error_factory_mock.h"
136 #include "sync/api/syncable_service.h"
137 #include "sync/protocol/app_specifics.pb.h"
138 #include "sync/protocol/extension_specifics.pb.h"
139 #include "sync/protocol/sync.pb.h"
140 #include "testing/gtest/include/gtest/gtest.h"
141 #include "testing/platform_test.h"
142 #include "ui/base/l10n/l10n_util.h"
143 #include "url/gurl.h"
145 #if defined(ENABLE_SUPERVISED_USERS)
146 #include "chrome/browser/supervised_user/permission_request_creator.h"
147 #include "chrome/browser/supervised_user/supervised_user_constants.h"
148 #include "chrome/browser/supervised_user/supervised_user_service.h"
149 #include "chrome/browser/supervised_user/supervised_user_service_factory.h"
152 #if defined(OS_CHROMEOS)
153 #include "chrome/browser/chromeos/login/users/scoped_test_user_manager.h"
154 #include "chrome/browser/chromeos/settings/cros_settings.h"
155 #include "chrome/browser/chromeos/settings/device_settings_service.h"
158 // The blacklist tests rely on the safe-browsing database.
159 #if defined(SAFE_BROWSING_DB_LOCAL)
160 #define ENABLE_BLACKLIST_TESTS
163 using base::DictionaryValue
;
164 using base::ListValue
;
166 using content::BrowserContext
;
167 using content::BrowserThread
;
168 using content::DOMStorageContext
;
169 using content::IndexedDBContext
;
170 using content::PluginService
;
171 using extensions::APIPermission
;
172 using extensions::APIPermissionSet
;
173 using extensions::AppSorting
;
174 using extensions::Blacklist
;
175 using extensions::CrxInstaller
;
176 using extensions::Extension
;
177 using extensions::ExtensionCreator
;
178 using extensions::ExtensionPrefs
;
179 using extensions::ExtensionRegistry
;
180 using extensions::ExtensionResource
;
181 using extensions::ExtensionSyncData
;
182 using extensions::ExtensionSystem
;
183 using extensions::FakeSafeBrowsingDatabaseManager
;
184 using extensions::FeatureSwitch
;
185 using extensions::Manifest
;
186 using extensions::PermissionSet
;
187 using extensions::TestExtensionSystem
;
188 using extensions::UnloadedExtensionInfo
;
189 using extensions::URLPatternSet
;
191 namespace keys
= extensions::manifest_keys
;
195 // Extension ids used during testing.
196 const char good0
[] = "behllobkkfkfnphdnhnkndlbkcpglgmj";
197 const char good1
[] = "hpiknbiabeeppbpihjehijgoemciehgk";
198 const char good2
[] = "bjafgdebaacbbbecmhlhpofkepfkgcpa";
199 const char all_zero
[] = "aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa";
200 const char good2048
[] = "nmgjhmhbleinmjpbdhgajfjkbijcmgbh";
201 const char good_crx
[] = "ldnnhddmnhbkjipkidpdiheffobcpfmf";
202 const char hosted_app
[] = "kbmnembihfiondgfjekmnmcbddelicoi";
203 const char page_action
[] = "obcimlgaoabeegjmmpldobjndiealpln";
204 const char theme_crx
[] = "iamefpfkojoapidjnbafmgkgncegbkad";
205 const char theme2_crx
[] = "pjpgmfcmabopnnfonnhmdjglfpjjfkbf";
206 const char permissions_crx
[] = "eagpmdpfmaekmmcejjbmjoecnejeiiin";
207 const char updates_from_webstore
[] = "akjooamlhcgeopfifcmlggaebeocgokj";
208 const char permissions_blocklist
[] = "noffkehfcaggllbcojjbopcmlhcnhcdn";
210 struct ExtensionsOrder
{
211 bool operator()(const scoped_refptr
<const Extension
>& a
,
212 const scoped_refptr
<const Extension
>& b
) {
213 return a
->name() < b
->name();
217 static std::vector
<base::string16
> GetErrors() {
218 const std::vector
<base::string16
>* errors
=
219 ExtensionErrorReporter::GetInstance()->GetErrors();
220 std::vector
<base::string16
> ret_val
;
222 for (std::vector
<base::string16
>::const_iterator iter
= errors
->begin();
223 iter
!= errors
->end(); ++iter
) {
224 std::string utf8_error
= base::UTF16ToUTF8(*iter
);
225 if (utf8_error
.find(".svn") == std::string::npos
) {
226 ret_val
.push_back(*iter
);
230 // The tests rely on the errors being in a certain order, which can vary
231 // depending on how filesystem iteration works.
232 std::stable_sort(ret_val
.begin(), ret_val
.end());
237 static void AddPattern(URLPatternSet
* extent
, const std::string
& pattern
) {
238 int schemes
= URLPattern::SCHEME_ALL
;
239 extent
->AddPattern(URLPattern(schemes
, pattern
));
242 base::FilePath
GetTemporaryFile() {
243 base::FilePath temp_file
;
244 CHECK(base::CreateTemporaryFile(&temp_file
));
248 bool WaitForCountNotificationsCallback(int *count
) {
249 return --(*count
) == 0;
254 class MockExtensionProvider
: public extensions::ExternalProviderInterface
{
256 MockExtensionProvider(
257 VisitorInterface
* visitor
,
258 Manifest::Location location
)
259 : location_(location
), visitor_(visitor
), visit_count_(0) {
262 ~MockExtensionProvider() override
{}
264 void UpdateOrAddExtension(const std::string
& id
,
265 const std::string
& version
,
266 const base::FilePath
& path
) {
267 extension_map_
[id
] = std::make_pair(version
, path
);
270 void RemoveExtension(const std::string
& id
) {
271 extension_map_
.erase(id
);
274 // ExternalProvider implementation:
275 void VisitRegisteredExtension() override
{
277 for (DataMap::const_iterator i
= extension_map_
.begin();
278 i
!= extension_map_
.end(); ++i
) {
279 Version
version(i
->second
.first
);
281 visitor_
->OnExternalExtensionFileFound(
282 i
->first
, &version
, i
->second
.second
, location_
,
283 Extension::NO_FLAGS
, false, false);
285 visitor_
->OnExternalProviderReady(this);
288 bool HasExtension(const std::string
& id
) const override
{
289 return extension_map_
.find(id
) != extension_map_
.end();
292 bool GetExtensionDetails(const std::string
& id
,
293 Manifest::Location
* location
,
294 scoped_ptr
<Version
>* version
) const override
{
295 DataMap::const_iterator it
= extension_map_
.find(id
);
296 if (it
== extension_map_
.end())
300 version
->reset(new Version(it
->second
.first
));
303 *location
= location_
;
308 bool IsReady() const override
{ return true; }
310 void ServiceShutdown() override
{}
312 int visit_count() const { return visit_count_
; }
313 void set_visit_count(int visit_count
) {
314 visit_count_
= visit_count
;
318 typedef std::map
< std::string
, std::pair
<std::string
, base::FilePath
> >
320 DataMap extension_map_
;
321 Manifest::Location location_
;
322 VisitorInterface
* visitor_
;
324 // visit_count_ tracks the number of calls to VisitRegisteredExtension().
325 // Mutable because it must be incremented on each call to
326 // VisitRegisteredExtension(), which must be a const method to inherit
327 // from the class being mocked.
328 mutable int visit_count_
;
330 DISALLOW_COPY_AND_ASSIGN(MockExtensionProvider
);
333 class MockProviderVisitor
334 : public extensions::ExternalProviderInterface::VisitorInterface
{
336 // The provider will return |fake_base_path| from
337 // GetBaseCrxFilePath(). User can test the behavior with
338 // and without an empty path using this parameter.
339 explicit MockProviderVisitor(base::FilePath fake_base_path
)
341 fake_base_path_(fake_base_path
),
342 expected_creation_flags_(Extension::NO_FLAGS
) {
343 profile_
.reset(new TestingProfile
);
346 MockProviderVisitor(base::FilePath fake_base_path
,
347 int expected_creation_flags
)
349 fake_base_path_(fake_base_path
),
350 expected_creation_flags_(expected_creation_flags
) {
351 profile_
.reset(new TestingProfile
);
354 int Visit(const std::string
& json_data
) {
355 // Give the test json file to the provider for parsing.
356 provider_
.reset(new extensions::ExternalProviderImpl(
358 new extensions::ExternalTestingLoader(json_data
, fake_base_path_
),
360 Manifest::EXTERNAL_PREF
,
361 Manifest::EXTERNAL_PREF_DOWNLOAD
,
362 Extension::NO_FLAGS
));
364 // We also parse the file into a dictionary to compare what we get back
365 // from the provider.
366 JSONStringValueDeserializer
deserializer(json_data
);
367 base::Value
* json_value
= deserializer
.Deserialize(NULL
, NULL
);
369 if (!json_value
|| !json_value
->IsType(base::Value::TYPE_DICTIONARY
)) {
370 NOTREACHED() << "Unable to deserialize json data";
373 base::DictionaryValue
* external_extensions
=
374 static_cast<base::DictionaryValue
*>(json_value
);
375 prefs_
.reset(external_extensions
);
378 // Reset our counter.
380 // Ask the provider to look up all extensions and return them.
381 provider_
->VisitRegisteredExtension();
386 bool OnExternalExtensionFileFound(const std::string
& id
,
387 const Version
* version
,
388 const base::FilePath
& path
,
389 Manifest::Location unused
,
391 bool mark_acknowledged
,
392 bool install_immediately
) override
{
393 EXPECT_EQ(expected_creation_flags_
, creation_flags
);
396 base::DictionaryValue
* pref
;
397 // This tests is to make sure that the provider only notifies us of the
398 // values we gave it. So if the id we doesn't exist in our internal
399 // dictionary then something is wrong.
400 EXPECT_TRUE(prefs_
->GetDictionary(id
, &pref
))
401 << "Got back ID (" << id
.c_str() << ") we weren't expecting";
403 EXPECT_TRUE(path
.IsAbsolute());
404 if (!fake_base_path_
.empty())
405 EXPECT_TRUE(fake_base_path_
.IsParent(path
));
408 EXPECT_TRUE(provider_
->HasExtension(id
));
410 // Ask provider if the extension we got back is registered.
411 Manifest::Location location
= Manifest::INVALID_LOCATION
;
412 scoped_ptr
<Version
> v1
;
413 base::FilePath crx_path
;
415 EXPECT_TRUE(provider_
->GetExtensionDetails(id
, NULL
, &v1
));
416 EXPECT_STREQ(version
->GetString().c_str(), v1
->GetString().c_str());
418 scoped_ptr
<Version
> v2
;
419 EXPECT_TRUE(provider_
->GetExtensionDetails(id
, &location
, &v2
));
420 EXPECT_STREQ(version
->GetString().c_str(), v1
->GetString().c_str());
421 EXPECT_STREQ(version
->GetString().c_str(), v2
->GetString().c_str());
422 EXPECT_EQ(Manifest::EXTERNAL_PREF
, location
);
424 // Remove it so we won't count it ever again.
425 prefs_
->Remove(id
, NULL
);
430 bool OnExternalExtensionUpdateUrlFound(const std::string
& id
,
431 const std::string
& install_parameter
,
432 const GURL
& update_url
,
433 Manifest::Location location
,
435 bool mark_acknowledged
) override
{
437 base::DictionaryValue
* pref
;
438 // This tests is to make sure that the provider only notifies us of the
439 // values we gave it. So if the id we doesn't exist in our internal
440 // dictionary then something is wrong.
441 EXPECT_TRUE(prefs_
->GetDictionary(id
, &pref
))
442 << L
"Got back ID (" << id
.c_str() << ") we weren't expecting";
443 EXPECT_EQ(Manifest::EXTERNAL_PREF_DOWNLOAD
, location
);
446 EXPECT_TRUE(provider_
->HasExtension(id
));
448 // External extensions with update URLs do not have versions.
449 scoped_ptr
<Version
> v1
;
450 Manifest::Location location1
= Manifest::INVALID_LOCATION
;
451 EXPECT_TRUE(provider_
->GetExtensionDetails(id
, &location1
, &v1
));
452 EXPECT_FALSE(v1
.get());
453 EXPECT_EQ(Manifest::EXTERNAL_PREF_DOWNLOAD
, location1
);
455 std::string parsed_install_parameter
;
456 pref
->GetString("install_parameter", &parsed_install_parameter
);
457 EXPECT_EQ(parsed_install_parameter
, install_parameter
);
459 // Remove it so we won't count it again.
460 prefs_
->Remove(id
, NULL
);
465 void OnExternalProviderReady(
466 const extensions::ExternalProviderInterface
* provider
) override
{
467 EXPECT_EQ(provider
, provider_
.get());
468 EXPECT_TRUE(provider
->IsReady());
471 Profile
* profile() { return profile_
.get(); }
475 base::FilePath fake_base_path_
;
476 int expected_creation_flags_
;
477 scoped_ptr
<extensions::ExternalProviderImpl
> provider_
;
478 scoped_ptr
<base::DictionaryValue
> prefs_
;
479 scoped_ptr
<TestingProfile
> profile_
;
481 DISALLOW_COPY_AND_ASSIGN(MockProviderVisitor
);
484 class ExtensionServiceTest
: public extensions::ExtensionServiceTestBase
,
485 public content::NotificationObserver
{
487 ExtensionServiceTest()
488 : unloaded_reason_(UnloadedExtensionInfo::REASON_UNDEFINED
),
491 override_external_install_prompt_(
492 FeatureSwitch::prompt_for_external_extensions(),
494 expected_extensions_count_(0) {
496 extensions::NOTIFICATION_EXTENSION_LOADED_DEPRECATED
,
497 content::NotificationService::AllSources());
499 extensions::NOTIFICATION_EXTENSION_UNLOADED_DEPRECATED
,
500 content::NotificationService::AllSources());
503 extensions::NOTIFICATION_EXTENSION_WILL_BE_INSTALLED_DEPRECATED
,
504 content::NotificationService::AllSources());
507 void Observe(int type
,
508 const content::NotificationSource
& source
,
509 const content::NotificationDetails
& details
) override
{
511 case extensions::NOTIFICATION_EXTENSION_LOADED_DEPRECATED
: {
512 const Extension
* extension
=
513 content::Details
<const Extension
>(details
).ptr();
514 loaded_
.push_back(make_scoped_refptr(extension
));
515 // The tests rely on the errors being in a certain order, which can vary
516 // depending on how filesystem iteration works.
517 std::stable_sort(loaded_
.begin(), loaded_
.end(), ExtensionsOrder());
521 case extensions::NOTIFICATION_EXTENSION_UNLOADED_DEPRECATED
: {
522 UnloadedExtensionInfo
* unloaded_info
=
523 content::Details
<UnloadedExtensionInfo
>(details
).ptr();
524 const Extension
* e
= unloaded_info
->extension
;
525 unloaded_id_
= e
->id();
526 unloaded_reason_
= unloaded_info
->reason
;
527 extensions::ExtensionList::iterator i
=
528 std::find(loaded_
.begin(), loaded_
.end(), e
);
529 // TODO(erikkay) fix so this can be an assert. Right now the tests
530 // are manually calling clear() on loaded_, so this isn't doable.
531 if (i
== loaded_
.end())
536 case extensions::NOTIFICATION_EXTENSION_WILL_BE_INSTALLED_DEPRECATED
: {
537 const extensions::InstalledExtensionInfo
* installed_info
=
538 content::Details
<const extensions::InstalledExtensionInfo
>(details
)
540 installed_
= installed_info
->extension
;
541 was_update_
= installed_info
->is_update
;
542 old_name_
= installed_info
->old_name
;
551 void AddMockExternalProvider(
552 extensions::ExternalProviderInterface
* provider
) {
553 service()->AddProviderForTesting(provider
);
556 void MockSyncStartFlare(bool* was_called
,
557 syncer::ModelType
* model_type_passed_in
,
558 syncer::ModelType model_type
) {
560 *model_type_passed_in
= model_type
;
564 // Paths to some of the fake extensions.
565 base::FilePath
good0_path() {
568 .AppendASCII("Extensions")
570 .AppendASCII("1.0.0.0");
573 base::FilePath
good1_path() {
576 .AppendASCII("Extensions")
581 base::FilePath
good2_path() {
584 .AppendASCII("Extensions")
589 void TestExternalProvider(MockExtensionProvider
* provider
,
590 Manifest::Location location
);
592 void PackCRX(const base::FilePath
& dir_path
,
593 const base::FilePath
& pem_path
,
594 const base::FilePath
& crx_path
) {
595 // Use the existing pem key, if provided.
596 base::FilePath pem_output_path
;
597 if (pem_path
.value().empty()) {
598 pem_output_path
= crx_path
.DirName().AppendASCII("temp.pem");
600 ASSERT_TRUE(base::PathExists(pem_path
));
603 ASSERT_TRUE(base::DeleteFile(crx_path
, false));
605 scoped_ptr
<ExtensionCreator
> creator(new ExtensionCreator());
606 ASSERT_TRUE(creator
->Run(dir_path
,
610 ExtensionCreator::kOverwriteCRX
));
612 ASSERT_TRUE(base::PathExists(crx_path
));
619 INSTALL_WITHOUT_LOAD
,
622 const Extension
* PackAndInstallCRX(const base::FilePath
& dir_path
,
623 const base::FilePath
& pem_path
,
624 InstallState install_state
,
625 int creation_flags
) {
626 base::FilePath crx_path
;
627 base::ScopedTempDir temp_dir
;
628 EXPECT_TRUE(temp_dir
.CreateUniqueTempDir());
629 crx_path
= temp_dir
.path().AppendASCII("temp.crx");
631 PackCRX(dir_path
, pem_path
, crx_path
);
632 return InstallCRX(crx_path
, install_state
, creation_flags
);
635 const Extension
* PackAndInstallCRX(const base::FilePath
& dir_path
,
636 const base::FilePath
& pem_path
,
637 InstallState install_state
) {
638 return PackAndInstallCRX(dir_path
, pem_path
, install_state
,
639 Extension::NO_FLAGS
);
642 const Extension
* PackAndInstallCRX(const base::FilePath
& dir_path
,
643 InstallState install_state
) {
644 return PackAndInstallCRX(dir_path
, base::FilePath(), install_state
,
645 Extension::NO_FLAGS
);
648 // Attempts to install an extension. Use INSTALL_FAILED if the installation
649 // is expected to fail.
650 // If |install_state| is INSTALL_UPDATED, and |expected_old_name| is
651 // non-empty, expects that the existing extension's title was
652 // |expected_old_name|.
653 const Extension
* InstallCRX(const base::FilePath
& path
,
654 InstallState install_state
,
656 const std::string
& expected_old_name
) {
657 InstallCRXInternal(path
, creation_flags
);
658 return VerifyCrxInstall(path
, install_state
, expected_old_name
);
661 // Attempts to install an extension. Use INSTALL_FAILED if the installation
662 // is expected to fail.
663 const Extension
* InstallCRX(const base::FilePath
& path
,
664 InstallState install_state
,
665 int creation_flags
) {
666 return InstallCRX(path
, install_state
, creation_flags
, std::string());
669 // Attempts to install an extension. Use INSTALL_FAILED if the installation
670 // is expected to fail.
671 const Extension
* InstallCRX(const base::FilePath
& path
,
672 InstallState install_state
) {
673 return InstallCRX(path
, install_state
, Extension::NO_FLAGS
);
676 const Extension
* InstallCRXFromWebStore(const base::FilePath
& path
,
677 InstallState install_state
) {
678 InstallCRXInternal(path
, Extension::FROM_WEBSTORE
);
679 return VerifyCrxInstall(path
, install_state
);
682 const Extension
* InstallCRXWithLocation(const base::FilePath
& crx_path
,
683 Manifest::Location install_location
,
684 InstallState install_state
) {
685 EXPECT_TRUE(base::PathExists(crx_path
))
686 << "Path does not exist: "<< crx_path
.value().c_str();
687 // no client (silent install)
688 scoped_refptr
<CrxInstaller
> installer(
689 CrxInstaller::CreateSilent(service()));
690 installer
->set_install_source(install_location
);
692 content::WindowedNotificationObserver
observer(
693 extensions::NOTIFICATION_CRX_INSTALLER_DONE
,
694 content::NotificationService::AllSources());
695 installer
->InstallCrx(crx_path
);
698 return VerifyCrxInstall(crx_path
, install_state
);
701 // Verifies the result of a CRX installation. Used by InstallCRX. Set the
702 // |install_state| to INSTALL_FAILED if the installation is expected to fail.
703 // Returns an Extension pointer if the install succeeded, NULL otherwise.
704 const Extension
* VerifyCrxInstall(const base::FilePath
& path
,
705 InstallState install_state
) {
706 return VerifyCrxInstall(path
, install_state
, std::string());
709 // Verifies the result of a CRX installation. Used by InstallCRX. Set the
710 // |install_state| to INSTALL_FAILED if the installation is expected to fail.
711 // If |install_state| is INSTALL_UPDATED, and |expected_old_name| is
712 // non-empty, expects that the existing extension's title was
713 // |expected_old_name|.
714 // Returns an Extension pointer if the install succeeded, NULL otherwise.
715 const Extension
* VerifyCrxInstall(const base::FilePath
& path
,
716 InstallState install_state
,
717 const std::string
& expected_old_name
) {
718 std::vector
<base::string16
> errors
= GetErrors();
719 const Extension
* extension
= NULL
;
720 if (install_state
!= INSTALL_FAILED
) {
721 if (install_state
== INSTALL_NEW
)
722 ++expected_extensions_count_
;
724 EXPECT_TRUE(installed_
) << path
.value();
725 // If and only if INSTALL_UPDATED, it should have the is_update flag.
726 EXPECT_EQ(install_state
== INSTALL_UPDATED
, was_update_
)
728 // If INSTALL_UPDATED, old_name_ should match the given string.
729 if (install_state
== INSTALL_UPDATED
&& !expected_old_name
.empty())
730 EXPECT_EQ(expected_old_name
, old_name_
);
731 EXPECT_EQ(0u, errors
.size()) << path
.value();
733 if (install_state
== INSTALL_WITHOUT_LOAD
) {
734 EXPECT_EQ(0u, loaded_
.size()) << path
.value();
736 EXPECT_EQ(1u, loaded_
.size()) << path
.value();
737 size_t actual_extension_count
=
738 registry()->enabled_extensions().size() +
739 registry()->disabled_extensions().size();
740 EXPECT_EQ(expected_extensions_count_
, actual_extension_count
) <<
742 extension
= loaded_
[0].get();
743 EXPECT_TRUE(service()->GetExtensionById(extension
->id(), false))
747 for (std::vector
<base::string16
>::iterator err
= errors
.begin();
748 err
!= errors
.end(); ++err
) {
752 EXPECT_FALSE(installed_
) << path
.value();
753 EXPECT_EQ(0u, loaded_
.size()) << path
.value();
754 EXPECT_EQ(1u, errors
.size()) << path
.value();
761 ExtensionErrorReporter::GetInstance()->ClearErrors();
774 void BlackListWebGL() {
775 static const std::string json_blacklist
=
777 " \"name\": \"gpu blacklist\",\n"
778 " \"version\": \"1.0\",\n"
782 " \"features\": [\"webgl\"]\n"
786 gpu::GPUInfo gpu_info
;
787 content::GpuDataManager::GetInstance()->InitializeForTesting(
788 json_blacklist
, gpu_info
);
791 // Grants all optional permissions stated in manifest to active permission
792 // set for extension |id|.
793 void GrantAllOptionalPermissions(const std::string
& id
) {
794 const Extension
* extension
= service()->GetInstalledExtension(id
);
795 scoped_refptr
<const PermissionSet
> all_optional_permissions
=
796 extensions::PermissionsParser::GetOptionalPermissions(extension
);
797 extensions::PermissionsUpdater
perms_updater(profile());
798 perms_updater
.AddPermissions(extension
, all_optional_permissions
.get());
801 // Helper method to set up a WindowedNotificationObserver to wait for a
802 // specific CrxInstaller to finish if we don't know the value of the
804 static bool IsCrxInstallerDone(extensions::CrxInstaller
** installer
,
805 const content::NotificationSource
& source
,
806 const content::NotificationDetails
& details
) {
807 return content::Source
<extensions::CrxInstaller
>(source
).ptr() ==
811 void PackCRXAndUpdateExtension(const std::string
& id
,
812 const base::FilePath
& dir_path
,
813 const base::FilePath
& pem_path
,
814 UpdateState expected_state
) {
815 base::ScopedTempDir temp_dir
;
816 EXPECT_TRUE(temp_dir
.CreateUniqueTempDir());
817 base::FilePath crx_path
= temp_dir
.path().AppendASCII("temp.crx");
819 PackCRX(dir_path
, pem_path
, crx_path
);
820 UpdateExtension(id
, crx_path
, expected_state
);
823 void UpdateExtension(const std::string
& id
,
824 const base::FilePath
& in_path
,
825 UpdateState expected_state
) {
826 ASSERT_TRUE(base::PathExists(in_path
));
828 // We need to copy this to a temporary location because Update() will delete
830 base::FilePath path
= temp_dir().path();
831 path
= path
.Append(in_path
.BaseName());
832 ASSERT_TRUE(base::CopyFile(in_path
, path
));
834 int previous_enabled_extension_count
=
835 registry()->enabled_extensions().size();
836 int previous_installed_extension_count
=
837 previous_enabled_extension_count
+
838 registry()->disabled_extensions().size();
840 extensions::CrxInstaller
* installer
= NULL
;
841 content::WindowedNotificationObserver
observer(
842 extensions::NOTIFICATION_CRX_INSTALLER_DONE
,
843 base::Bind(&IsCrxInstallerDone
, &installer
));
844 service()->UpdateExtension(extensions::CRXFileInfo(id
, path
), true,
850 base::RunLoop().RunUntilIdle();
852 std::vector
<base::string16
> errors
= GetErrors();
853 int error_count
= errors
.size();
854 int enabled_extension_count
= registry()->enabled_extensions().size();
855 int installed_extension_count
=
856 enabled_extension_count
+ registry()->disabled_extensions().size();
858 int expected_error_count
= (expected_state
== FAILED
) ? 1 : 0;
859 EXPECT_EQ(expected_error_count
, error_count
) << path
.value();
861 if (expected_state
<= FAILED
) {
862 EXPECT_EQ(previous_enabled_extension_count
,
863 enabled_extension_count
);
864 EXPECT_EQ(previous_installed_extension_count
,
865 installed_extension_count
);
867 int expected_installed_extension_count
=
868 (expected_state
>= INSTALLED
) ? 1 : 0;
869 int expected_enabled_extension_count
=
870 (expected_state
>= ENABLED
) ? 1 : 0;
871 EXPECT_EQ(expected_installed_extension_count
,
872 installed_extension_count
);
873 EXPECT_EQ(expected_enabled_extension_count
,
874 enabled_extension_count
);
877 // Update() should the temporary input file.
878 EXPECT_FALSE(base::PathExists(path
));
881 void TerminateExtension(const std::string
& id
) {
882 const Extension
* extension
= service()->GetInstalledExtension(id
);
887 service()->TrackTerminatedExtensionForTest(extension
);
890 testing::AssertionResult
IsBlocked(const std::string
& id
) {
891 scoped_ptr
<extensions::ExtensionSet
> all_unblocked_extensions
=
892 registry()->GenerateInstalledExtensionsSet(
893 ExtensionRegistry::EVERYTHING
& ~ExtensionRegistry::BLOCKED
);
894 if (all_unblocked_extensions
.get()->Contains(id
))
895 return testing::AssertionFailure() << id
<< " is still unblocked!";
896 if (!registry()->blocked_extensions().Contains(id
))
897 return testing::AssertionFailure() << id
<< " is not blocked!";
898 return testing::AssertionSuccess();
901 // Helper method to test that an extension moves through being blocked and
902 // unblocked as appropriate for its type.
903 void AssertExtensionBlocksAndUnblocks(
904 bool should_block
, const std::string extension_id
) {
905 // Assume we start in an unblocked state.
906 EXPECT_FALSE(IsBlocked(extension_id
));
908 // Block the extensions.
909 service()->BlockAllExtensions();
910 base::RunLoop().RunUntilIdle();
913 ASSERT_TRUE(IsBlocked(extension_id
));
915 ASSERT_FALSE(IsBlocked(extension_id
));
917 service()->UnblockAllExtensions();
918 base::RunLoop().RunUntilIdle();
920 ASSERT_FALSE(IsBlocked(extension_id
));
923 size_t GetPrefKeyCount() {
924 const base::DictionaryValue
* dict
=
925 profile()->GetPrefs()->GetDictionary("extensions.settings");
933 void UninstallExtension(const std::string
& id
, bool use_helper
) {
934 UninstallExtension(id
, use_helper
, Extension::ENABLED
);
937 void UninstallExtension(const std::string
& id
, bool use_helper
,
938 Extension::State expected_state
) {
939 // Verify that the extension is installed.
940 base::FilePath extension_path
= extensions_install_dir().AppendASCII(id
);
941 EXPECT_TRUE(base::PathExists(extension_path
));
942 size_t pref_key_count
= GetPrefKeyCount();
943 EXPECT_GT(pref_key_count
, 0u);
944 ValidateIntegerPref(id
, "state", expected_state
);
948 EXPECT_TRUE(ExtensionService::UninstallExtensionHelper(
949 service(), id
, extensions::UNINSTALL_REASON_FOR_TESTING
));
951 EXPECT_TRUE(service()->UninstallExtension(
953 extensions::UNINSTALL_REASON_FOR_TESTING
,
954 base::Bind(&base::DoNothing
),
957 --expected_extensions_count_
;
959 // We should get an unload notification.
960 EXPECT_FALSE(unloaded_id_
.empty());
961 EXPECT_EQ(id
, unloaded_id_
);
963 // Verify uninstalled state.
964 size_t new_pref_key_count
= GetPrefKeyCount();
965 if (new_pref_key_count
== pref_key_count
) {
966 ValidateIntegerPref(id
, "state",
967 Extension::EXTERNAL_EXTENSION_UNINSTALLED
);
969 EXPECT_EQ(new_pref_key_count
, pref_key_count
- 1);
972 // The extension should not be in the service anymore.
973 EXPECT_FALSE(service()->GetInstalledExtension(id
));
974 base::RunLoop().RunUntilIdle();
976 // The directory should be gone.
977 EXPECT_FALSE(base::PathExists(extension_path
));
980 void ValidatePrefKeyCount(size_t count
) {
981 EXPECT_EQ(count
, GetPrefKeyCount());
984 testing::AssertionResult
ValidateBooleanPref(
985 const std::string
& extension_id
,
986 const std::string
& pref_path
,
988 std::string msg
= "while checking: ";
993 msg
+= expected_val
? "true" : "false";
995 PrefService
* prefs
= profile()->GetPrefs();
996 const base::DictionaryValue
* dict
=
997 prefs
->GetDictionary("extensions.settings");
999 return testing::AssertionFailure()
1000 << "extension.settings does not exist " << msg
;
1003 const base::DictionaryValue
* pref
= NULL
;
1004 if (!dict
->GetDictionary(extension_id
, &pref
)) {
1005 return testing::AssertionFailure()
1006 << "extension pref does not exist " << msg
;
1010 if (!pref
->GetBoolean(pref_path
, &val
)) {
1011 return testing::AssertionFailure()
1012 << pref_path
<< " pref not found " << msg
;
1015 return expected_val
== val
1016 ? testing::AssertionSuccess()
1017 : testing::AssertionFailure() << "base::Value is incorrect " << msg
;
1020 bool IsPrefExist(const std::string
& extension_id
,
1021 const std::string
& pref_path
) {
1022 const base::DictionaryValue
* dict
=
1023 profile()->GetPrefs()->GetDictionary("extensions.settings");
1024 if (dict
== NULL
) return false;
1025 const base::DictionaryValue
* pref
= NULL
;
1026 if (!dict
->GetDictionary(extension_id
, &pref
)) {
1033 if (!pref
->GetBoolean(pref_path
, &val
)) {
1039 void ValidateIntegerPref(const std::string
& extension_id
,
1040 const std::string
& pref_path
,
1042 std::string msg
= " while checking: ";
1043 msg
+= extension_id
;
1047 msg
+= base::IntToString(expected_val
);
1049 PrefService
* prefs
= profile()->GetPrefs();
1050 const base::DictionaryValue
* dict
=
1051 prefs
->GetDictionary("extensions.settings");
1052 ASSERT_TRUE(dict
!= NULL
) << msg
;
1053 const base::DictionaryValue
* pref
= NULL
;
1054 ASSERT_TRUE(dict
->GetDictionary(extension_id
, &pref
)) << msg
;
1055 EXPECT_TRUE(pref
!= NULL
) << msg
;
1057 ASSERT_TRUE(pref
->GetInteger(pref_path
, &val
)) << msg
;
1058 EXPECT_EQ(expected_val
, val
) << msg
;
1061 void ValidateStringPref(const std::string
& extension_id
,
1062 const std::string
& pref_path
,
1063 const std::string
& expected_val
) {
1064 std::string msg
= " while checking: ";
1065 msg
+= extension_id
;
1066 msg
+= ".manifest.";
1069 msg
+= expected_val
;
1071 const base::DictionaryValue
* dict
=
1072 profile()->GetPrefs()->GetDictionary("extensions.settings");
1073 ASSERT_TRUE(dict
!= NULL
) << msg
;
1074 const base::DictionaryValue
* pref
= NULL
;
1075 std::string manifest_path
= extension_id
+ ".manifest";
1076 ASSERT_TRUE(dict
->GetDictionary(manifest_path
, &pref
)) << msg
;
1077 EXPECT_TRUE(pref
!= NULL
) << msg
;
1079 ASSERT_TRUE(pref
->GetString(pref_path
, &val
)) << msg
;
1080 EXPECT_EQ(expected_val
, val
) << msg
;
1083 void SetPref(const std::string
& extension_id
,
1084 const std::string
& pref_path
,
1086 const std::string
& msg
) {
1087 DictionaryPrefUpdate
update(profile()->GetPrefs(), "extensions.settings");
1088 base::DictionaryValue
* dict
= update
.Get();
1089 ASSERT_TRUE(dict
!= NULL
) << msg
;
1090 base::DictionaryValue
* pref
= NULL
;
1091 ASSERT_TRUE(dict
->GetDictionary(extension_id
, &pref
)) << msg
;
1092 EXPECT_TRUE(pref
!= NULL
) << msg
;
1093 pref
->Set(pref_path
, value
);
1096 void SetPrefInteg(const std::string
& extension_id
,
1097 const std::string
& pref_path
,
1099 std::string msg
= " while setting: ";
1100 msg
+= extension_id
;
1104 msg
+= base::IntToString(value
);
1106 SetPref(extension_id
, pref_path
, new base::FundamentalValue(value
), msg
);
1109 void SetPrefBool(const std::string
& extension_id
,
1110 const std::string
& pref_path
,
1112 std::string msg
= " while setting: ";
1113 msg
+= extension_id
+ " " + pref_path
;
1115 msg
+= (value
? "true" : "false");
1117 SetPref(extension_id
, pref_path
, new base::FundamentalValue(value
), msg
);
1120 void ClearPref(const std::string
& extension_id
,
1121 const std::string
& pref_path
) {
1122 std::string msg
= " while clearing: ";
1123 msg
+= extension_id
+ " " + pref_path
;
1125 DictionaryPrefUpdate
update(profile()->GetPrefs(), "extensions.settings");
1126 base::DictionaryValue
* dict
= update
.Get();
1127 ASSERT_TRUE(dict
!= NULL
) << msg
;
1128 base::DictionaryValue
* pref
= NULL
;
1129 ASSERT_TRUE(dict
->GetDictionary(extension_id
, &pref
)) << msg
;
1130 EXPECT_TRUE(pref
!= NULL
) << msg
;
1131 pref
->Remove(pref_path
, NULL
);
1134 void SetPrefStringSet(const std::string
& extension_id
,
1135 const std::string
& pref_path
,
1136 const std::set
<std::string
>& value
) {
1137 std::string msg
= " while setting: ";
1138 msg
+= extension_id
+ " " + pref_path
;
1140 base::ListValue
* list_value
= new base::ListValue();
1141 for (std::set
<std::string
>::const_iterator iter
= value
.begin();
1142 iter
!= value
.end(); ++iter
)
1143 list_value
->Append(new base::StringValue(*iter
));
1145 SetPref(extension_id
, pref_path
, list_value
, msg
);
1148 void InitPluginService() {
1149 #if defined(ENABLE_PLUGINS)
1150 PluginService::GetInstance()->Init();
1154 void InitializeEmptyExtensionServiceWithTestingPrefs() {
1155 ExtensionServiceTestBase::ExtensionServiceInitParams params
=
1156 CreateDefaultInitParams();
1157 params
.pref_file
= base::FilePath();
1158 InitializeExtensionService(params
);
1161 extensions::ManagementPolicy
* GetManagementPolicy() {
1162 return ExtensionSystem::Get(browser_context())->management_policy();
1165 ExtensionSyncService
* extension_sync_service() {
1166 return ExtensionSyncService::Get(profile());
1170 typedef extensions::ExtensionManagementPrefUpdater
<TestingPrefServiceSyncable
>
1171 ManagementPrefUpdater
;
1172 extensions::ExtensionList loaded_
;
1173 std::string unloaded_id_
;
1174 UnloadedExtensionInfo::Reason unloaded_reason_
;
1175 const Extension
* installed_
;
1177 std::string old_name_
;
1178 FeatureSwitch::ScopedOverride override_external_install_prompt_
;
1181 // Create a CrxInstaller and install the CRX file.
1182 // Instead of calling this method yourself, use InstallCRX(), which does extra
1184 void InstallCRXInternal(const base::FilePath
& crx_path
) {
1185 InstallCRXInternal(crx_path
, Extension::NO_FLAGS
);
1188 void InstallCRXInternal(const base::FilePath
& crx_path
, int creation_flags
) {
1189 ASSERT_TRUE(base::PathExists(crx_path
))
1190 << "Path does not exist: "<< crx_path
.value().c_str();
1191 scoped_refptr
<CrxInstaller
> installer(
1192 CrxInstaller::CreateSilent(service()));
1193 installer
->set_creation_flags(creation_flags
);
1194 if (!(creation_flags
& Extension::WAS_INSTALLED_BY_DEFAULT
))
1195 installer
->set_allow_silent_install(true);
1197 content::WindowedNotificationObserver
observer(
1198 extensions::NOTIFICATION_CRX_INSTALLER_DONE
,
1199 content::Source
<extensions::CrxInstaller
>(installer
.get()));
1201 installer
->InstallCrx(crx_path
);
1206 size_t expected_extensions_count_
;
1207 content::NotificationRegistrar registrar_
;
1210 // Receives notifications from a PackExtensionJob, indicating either that
1211 // packing succeeded or that there was some error.
1212 class PackExtensionTestClient
: public extensions::PackExtensionJob::Client
{
1214 PackExtensionTestClient(const base::FilePath
& expected_crx_path
,
1215 const base::FilePath
& expected_private_key_path
);
1216 void OnPackSuccess(const base::FilePath
& crx_path
,
1217 const base::FilePath
& private_key_path
) override
;
1218 void OnPackFailure(const std::string
& error_message
,
1219 ExtensionCreator::ErrorType type
) override
;
1222 const base::FilePath expected_crx_path_
;
1223 const base::FilePath expected_private_key_path_
;
1224 DISALLOW_COPY_AND_ASSIGN(PackExtensionTestClient
);
1227 PackExtensionTestClient::PackExtensionTestClient(
1228 const base::FilePath
& expected_crx_path
,
1229 const base::FilePath
& expected_private_key_path
)
1230 : expected_crx_path_(expected_crx_path
),
1231 expected_private_key_path_(expected_private_key_path
) {}
1233 // If packing succeeded, we make sure that the package names match our
1235 void PackExtensionTestClient::OnPackSuccess(
1236 const base::FilePath
& crx_path
,
1237 const base::FilePath
& private_key_path
) {
1238 // We got the notification and processed it; we don't expect any further tasks
1239 // to be posted to the current thread, so we should stop blocking and continue
1240 // on with the rest of the test.
1241 // This call to |Quit()| matches the call to |Run()| in the
1242 // |PackPunctuatedExtension| test.
1243 base::MessageLoop::current()->Quit();
1244 EXPECT_EQ(expected_crx_path_
.value(), crx_path
.value());
1245 EXPECT_EQ(expected_private_key_path_
.value(), private_key_path
.value());
1246 ASSERT_TRUE(base::PathExists(private_key_path
));
1249 // The tests are designed so that we never expect to see a packing error.
1250 void PackExtensionTestClient::OnPackFailure(const std::string
& error_message
,
1251 ExtensionCreator::ErrorType type
) {
1252 if (type
== ExtensionCreator::kCRXExists
)
1253 FAIL() << "Packing should not fail.";
1255 FAIL() << "Existing CRX should have been overwritten.";
1258 // Test loading good extensions from the profile directory.
1259 TEST_F(ExtensionServiceTest
, LoadAllExtensionsFromDirectorySuccess
) {
1260 InitPluginService();
1261 InitializeGoodInstalledExtensionService();
1264 uint32 expected_num_extensions
= 3u;
1265 ASSERT_EQ(expected_num_extensions
, loaded_
.size());
1267 EXPECT_EQ(std::string(good0
), loaded_
[0]->id());
1268 EXPECT_EQ(std::string("My extension 1"),
1269 loaded_
[0]->name());
1270 EXPECT_EQ(std::string("The first extension that I made."),
1271 loaded_
[0]->description());
1272 EXPECT_EQ(Manifest::INTERNAL
, loaded_
[0]->location());
1273 EXPECT_TRUE(service()->GetExtensionById(loaded_
[0]->id(), false));
1274 EXPECT_EQ(expected_num_extensions
, registry()->enabled_extensions().size());
1276 ValidatePrefKeyCount(3);
1277 ValidateIntegerPref(good0
, "state", Extension::ENABLED
);
1278 ValidateIntegerPref(good0
, "location", Manifest::INTERNAL
);
1279 ValidateIntegerPref(good1
, "state", Extension::ENABLED
);
1280 ValidateIntegerPref(good1
, "location", Manifest::INTERNAL
);
1281 ValidateIntegerPref(good2
, "state", Extension::ENABLED
);
1282 ValidateIntegerPref(good2
, "location", Manifest::INTERNAL
);
1284 URLPatternSet expected_patterns
;
1285 AddPattern(&expected_patterns
, "file:///*");
1286 AddPattern(&expected_patterns
, "http://*.google.com/*");
1287 AddPattern(&expected_patterns
, "https://*.google.com/*");
1288 const Extension
* extension
= loaded_
[0].get();
1289 const extensions::UserScriptList
& scripts
=
1290 extensions::ContentScriptsInfo::GetContentScripts(extension
);
1291 ASSERT_EQ(2u, scripts
.size());
1292 EXPECT_EQ(expected_patterns
, scripts
[0].url_patterns());
1293 EXPECT_EQ(2u, scripts
[0].js_scripts().size());
1294 ExtensionResource
resource00(extension
->id(),
1295 scripts
[0].js_scripts()[0].extension_root(),
1296 scripts
[0].js_scripts()[0].relative_path());
1297 base::FilePath expected_path
=
1298 base::MakeAbsoluteFilePath(extension
->path().AppendASCII("script1.js"));
1299 EXPECT_TRUE(resource00
.ComparePathWithDefault(expected_path
));
1300 ExtensionResource
resource01(extension
->id(),
1301 scripts
[0].js_scripts()[1].extension_root(),
1302 scripts
[0].js_scripts()[1].relative_path());
1304 base::MakeAbsoluteFilePath(extension
->path().AppendASCII("script2.js"));
1305 EXPECT_TRUE(resource01
.ComparePathWithDefault(expected_path
));
1306 EXPECT_TRUE(!extensions::PluginInfo::HasPlugins(extension
));
1307 EXPECT_EQ(1u, scripts
[1].url_patterns().patterns().size());
1308 EXPECT_EQ("http://*.news.com/*",
1309 scripts
[1].url_patterns().begin()->GetAsString());
1310 ExtensionResource
resource10(extension
->id(),
1311 scripts
[1].js_scripts()[0].extension_root(),
1312 scripts
[1].js_scripts()[0].relative_path());
1314 extension
->path().AppendASCII("js_files").AppendASCII("script3.js");
1315 expected_path
= base::MakeAbsoluteFilePath(expected_path
);
1316 EXPECT_TRUE(resource10
.ComparePathWithDefault(expected_path
));
1318 expected_patterns
.ClearPatterns();
1319 AddPattern(&expected_patterns
, "http://*.google.com/*");
1320 AddPattern(&expected_patterns
, "https://*.google.com/*");
1323 extension
->permissions_data()->active_permissions()->explicit_hosts());
1325 EXPECT_EQ(std::string(good1
), loaded_
[1]->id());
1326 EXPECT_EQ(std::string("My extension 2"), loaded_
[1]->name());
1327 EXPECT_EQ(std::string(), loaded_
[1]->description());
1328 EXPECT_EQ(loaded_
[1]->GetResourceURL("background.html"),
1329 extensions::BackgroundInfo::GetBackgroundURL(loaded_
[1].get()));
1331 extensions::ContentScriptsInfo::GetContentScripts(loaded_
[1].get())
1334 // We don't parse the plugins section on Chrome OS.
1335 #if defined(OS_CHROMEOS)
1336 EXPECT_TRUE(!extensions::PluginInfo::HasPlugins(loaded_
[1].get()));
1338 ASSERT_TRUE(extensions::PluginInfo::HasPlugins(loaded_
[1].get()));
1339 const std::vector
<extensions::PluginInfo
>* plugins
=
1340 extensions::PluginInfo::GetPlugins(loaded_
[1].get());
1341 ASSERT_TRUE(plugins
);
1342 ASSERT_EQ(2u, plugins
->size());
1343 EXPECT_EQ(loaded_
[1]->path().AppendASCII("content_plugin.dll").value(),
1344 plugins
->at(0).path
.value());
1345 EXPECT_TRUE(plugins
->at(0).is_public
);
1346 EXPECT_EQ(loaded_
[1]->path().AppendASCII("extension_plugin.dll").value(),
1347 plugins
->at(1).path
.value());
1348 EXPECT_FALSE(plugins
->at(1).is_public
);
1351 EXPECT_EQ(Manifest::INTERNAL
, loaded_
[1]->location());
1353 int index
= expected_num_extensions
- 1;
1354 EXPECT_EQ(std::string(good2
), loaded_
[index
]->id());
1355 EXPECT_EQ(std::string("My extension 3"), loaded_
[index
]->name());
1356 EXPECT_EQ(std::string(), loaded_
[index
]->description());
1358 extensions::ContentScriptsInfo::GetContentScripts(
1359 loaded_
[index
].get()).size());
1360 EXPECT_EQ(Manifest::INTERNAL
, loaded_
[index
]->location());
1363 // Test loading bad extensions from the profile directory.
1364 TEST_F(ExtensionServiceTest
, LoadAllExtensionsFromDirectoryFail
) {
1365 // Initialize the test dir with a bad Preferences/extensions.
1366 base::FilePath source_install_dir
=
1367 data_dir().AppendASCII("bad").AppendASCII("Extensions");
1368 base::FilePath pref_path
=
1369 source_install_dir
.DirName().Append(chrome::kPreferencesFilename
);
1371 InitializeInstalledExtensionService(pref_path
, source_install_dir
);
1375 ASSERT_EQ(4u, GetErrors().size());
1376 ASSERT_EQ(0u, loaded_
.size());
1378 EXPECT_TRUE(base::MatchPattern(base::UTF16ToUTF8(GetErrors()[0]),
1379 l10n_util::GetStringUTF8(IDS_EXTENSIONS_LOAD_ERROR_MESSAGE
) + " *. " +
1380 extensions::manifest_errors::kManifestUnreadable
)) <<
1381 base::UTF16ToUTF8(GetErrors()[0]);
1383 EXPECT_TRUE(base::MatchPattern(base::UTF16ToUTF8(GetErrors()[1]),
1384 l10n_util::GetStringUTF8(IDS_EXTENSIONS_LOAD_ERROR_MESSAGE
) + " *. " +
1385 extensions::manifest_errors::kManifestUnreadable
)) <<
1386 base::UTF16ToUTF8(GetErrors()[1]);
1388 EXPECT_TRUE(base::MatchPattern(base::UTF16ToUTF8(GetErrors()[2]),
1389 l10n_util::GetStringUTF8(IDS_EXTENSIONS_LOAD_ERROR_MESSAGE
) + " *. " +
1390 extensions::manifest_errors::kMissingFile
)) <<
1391 base::UTF16ToUTF8(GetErrors()[2]);
1393 EXPECT_TRUE(base::MatchPattern(base::UTF16ToUTF8(GetErrors()[3]),
1394 l10n_util::GetStringUTF8(IDS_EXTENSIONS_LOAD_ERROR_MESSAGE
) + " *. " +
1395 extensions::manifest_errors::kManifestUnreadable
)) <<
1396 base::UTF16ToUTF8(GetErrors()[3]);
1399 // Test various cases for delayed install because of missing imports.
1400 TEST_F(ExtensionServiceTest
, PendingImports
) {
1401 InitPluginService();
1403 base::FilePath source_install_dir
=
1404 data_dir().AppendASCII("pending_updates_with_imports").AppendASCII(
1406 base::FilePath pref_path
=
1407 source_install_dir
.DirName().Append(chrome::kPreferencesFilename
);
1409 InitializeInstalledExtensionService(pref_path
, source_install_dir
);
1411 // Verify there are no pending extensions initially.
1412 EXPECT_FALSE(service()->pending_extension_manager()->HasPendingExtensions());
1415 // Wait for GarbageCollectExtensions task to complete.
1416 base::RunLoop().RunUntilIdle();
1418 // These extensions are used by the extensions we test below, they must be
1420 EXPECT_TRUE(base::PathExists(extensions_install_dir().AppendASCII(
1421 "bjafgdebaacbbbecmhlhpofkepfkgcpa/1.0")));
1422 EXPECT_TRUE(base::PathExists(extensions_install_dir().AppendASCII(
1423 "hpiknbiabeeppbpihjehijgoemciehgk/2")));
1425 // Each of these extensions should have been rejected because of dependencies
1426 // that cannot be satisfied.
1427 ExtensionPrefs
* prefs
= ExtensionPrefs::Get(profile());
1429 prefs
->GetDelayedInstallInfo("aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa"));
1431 prefs
->GetInstalledExtensionInfo("aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa"));
1433 prefs
->GetDelayedInstallInfo("bbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbb"));
1435 prefs
->GetInstalledExtensionInfo("bbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbb"));
1437 prefs
->GetDelayedInstallInfo("cccccccccccccccccccccccccccccccc"));
1439 prefs
->GetInstalledExtensionInfo("cccccccccccccccccccccccccccccccc"));
1441 // Make sure the import started for the extension with a dependency.
1443 prefs
->GetDelayedInstallInfo("behllobkkfkfnphdnhnkndlbkcpglgmj"));
1444 EXPECT_EQ(ExtensionPrefs::DELAY_REASON_WAIT_FOR_IMPORTS
,
1445 prefs
->GetDelayedInstallReason("behllobkkfkfnphdnhnkndlbkcpglgmj"));
1447 EXPECT_FALSE(base::PathExists(extensions_install_dir().AppendASCII(
1448 "behllobkkfkfnphdnhnkndlbkcpglgmj/1.0.0.0")));
1450 EXPECT_TRUE(service()->pending_extension_manager()->HasPendingExtensions());
1451 std::string
pending_id("eeeeeeeeeeeeeeeeeeeeeeeeeeeeeeee");
1452 EXPECT_TRUE(service()->pending_extension_manager()->IsIdPending(pending_id
));
1453 // Remove it because we are not testing the pending extension manager's
1454 // ability to download and install extensions.
1455 EXPECT_TRUE(service()->pending_extension_manager()->Remove(pending_id
));
1458 // Test installing extensions. This test tries to install few extensions using
1459 // crx files. If you need to change those crx files, feel free to repackage
1460 // them, throw away the key used and change the id's above.
1461 TEST_F(ExtensionServiceTest
, InstallExtension
) {
1462 InitializeEmptyExtensionService();
1464 // Extensions not enabled.
1465 service()->set_extensions_enabled(false);
1466 base::FilePath path
= data_dir().AppendASCII("good.crx");
1467 InstallCRX(path
, INSTALL_FAILED
);
1468 service()->set_extensions_enabled(true);
1470 ValidatePrefKeyCount(0);
1472 // A simple extension that should install without error.
1473 path
= data_dir().AppendASCII("good.crx");
1474 InstallCRX(path
, INSTALL_NEW
);
1475 // TODO(erikkay): verify the contents of the installed extension.
1478 ValidatePrefKeyCount(++pref_count
);
1479 ValidateIntegerPref(good_crx
, "state", Extension::ENABLED
);
1480 ValidateIntegerPref(good_crx
, "location", Manifest::INTERNAL
);
1482 // An extension with page actions.
1483 path
= data_dir().AppendASCII("page_action.crx");
1484 InstallCRX(path
, INSTALL_NEW
);
1485 ValidatePrefKeyCount(++pref_count
);
1486 ValidateIntegerPref(page_action
, "state", Extension::ENABLED
);
1487 ValidateIntegerPref(page_action
, "location", Manifest::INTERNAL
);
1490 path
= data_dir().AppendASCII("bad_signature.crx");
1491 InstallCRX(path
, INSTALL_FAILED
);
1492 ValidatePrefKeyCount(pref_count
);
1494 // 0-length extension file.
1495 path
= data_dir().AppendASCII("not_an_extension.crx");
1496 InstallCRX(path
, INSTALL_FAILED
);
1497 ValidatePrefKeyCount(pref_count
);
1499 // Bad magic number.
1500 path
= data_dir().AppendASCII("bad_magic.crx");
1501 InstallCRX(path
, INSTALL_FAILED
);
1502 ValidatePrefKeyCount(pref_count
);
1504 // Packed extensions may have folders or files that have underscores.
1505 // This will only cause a warning, rather than a fatal error.
1506 path
= data_dir().AppendASCII("bad_underscore.crx");
1507 InstallCRX(path
, INSTALL_NEW
);
1508 ValidatePrefKeyCount(++pref_count
);
1510 // A test for an extension with a 2048-bit public key.
1511 path
= data_dir().AppendASCII("good2048.crx");
1512 InstallCRX(path
, INSTALL_NEW
);
1513 ValidatePrefKeyCount(++pref_count
);
1514 ValidateIntegerPref(good2048
, "state", Extension::ENABLED
);
1515 ValidateIntegerPref(good2048
, "location", Manifest::INTERNAL
);
1517 // TODO(erikkay): add more tests for many of the failure cases.
1518 // TODO(erikkay): add tests for upgrade cases.
1521 struct MockExtensionRegistryObserver
1522 : public extensions::ExtensionRegistryObserver
{
1523 void OnExtensionWillBeInstalled(content::BrowserContext
* browser_context
,
1524 const Extension
* extension
,
1526 bool from_ephemeral
,
1527 const std::string
& old_name
) override
{
1528 last_extension_installed
= extension
->id();
1531 void OnExtensionUninstalled(content::BrowserContext
* browser_context
,
1532 const Extension
* extension
,
1533 extensions::UninstallReason reason
) override
{
1534 last_extension_uninstalled
= extension
->id();
1537 std::string last_extension_installed
;
1538 std::string last_extension_uninstalled
;
1541 // Test that correct notifications are sent to ExtensionRegistryObserver on
1542 // extension install and uninstall.
1543 TEST_F(ExtensionServiceTest
, InstallObserverNotified
) {
1544 InitializeEmptyExtensionService();
1546 extensions::ExtensionRegistry
* registry(
1547 extensions::ExtensionRegistry::Get(profile()));
1548 MockExtensionRegistryObserver observer
;
1549 registry
->AddObserver(&observer
);
1551 // A simple extension that should install without error.
1552 ASSERT_TRUE(observer
.last_extension_installed
.empty());
1553 base::FilePath path
= data_dir().AppendASCII("good.crx");
1554 InstallCRX(path
, INSTALL_NEW
);
1555 ASSERT_EQ(good_crx
, observer
.last_extension_installed
);
1557 // Uninstall the extension.
1558 ASSERT_TRUE(observer
.last_extension_uninstalled
.empty());
1559 UninstallExtension(good_crx
, false);
1560 ASSERT_EQ(good_crx
, observer
.last_extension_uninstalled
);
1562 registry
->RemoveObserver(&observer
);
1565 // Tests that flags passed to OnExternalExtensionFileFound() make it to the
1566 // extension object.
1567 TEST_F(ExtensionServiceTest
, InstallingExternalExtensionWithFlags
) {
1568 const char kPrefFromBookmark
[] = "from_bookmark";
1570 InitializeEmptyExtensionService();
1572 base::FilePath path
= data_dir().AppendASCII("good.crx");
1573 service()->set_extensions_enabled(true);
1575 // Register and install an external extension.
1576 Version
version("1.0.0.0");
1577 content::WindowedNotificationObserver
observer(
1578 extensions::NOTIFICATION_CRX_INSTALLER_DONE
,
1579 content::NotificationService::AllSources());
1580 if (service()->OnExternalExtensionFileFound(
1584 Manifest::EXTERNAL_PREF
,
1585 Extension::FROM_BOOKMARK
,
1586 false /* mark_acknowledged */,
1587 false /* install_immediately */)) {
1591 const Extension
* extension
= service()->GetExtensionById(good_crx
, false);
1592 ASSERT_TRUE(extension
);
1593 ASSERT_TRUE(extension
->from_bookmark());
1594 ASSERT_TRUE(ValidateBooleanPref(good_crx
, kPrefFromBookmark
, true));
1596 // Upgrade to version 2.0, the flag should be preserved.
1597 path
= data_dir().AppendASCII("good2.crx");
1598 UpdateExtension(good_crx
, path
, ENABLED
);
1599 ASSERT_TRUE(ValidateBooleanPref(good_crx
, kPrefFromBookmark
, true));
1600 extension
= service()->GetExtensionById(good_crx
, false);
1601 ASSERT_TRUE(extension
);
1602 ASSERT_TRUE(extension
->from_bookmark());
1605 // Test the handling of Extension::EXTERNAL_EXTENSION_UNINSTALLED
1606 TEST_F(ExtensionServiceTest
, UninstallingExternalExtensions
) {
1607 InitializeEmptyExtensionService();
1609 base::FilePath path
= data_dir().AppendASCII("good.crx");
1610 service()->set_extensions_enabled(true);
1612 // Install an external extension.
1613 Version
version("1.0.0.0");
1614 content::WindowedNotificationObserver
observer(
1615 extensions::NOTIFICATION_CRX_INSTALLER_DONE
,
1616 content::NotificationService::AllSources());
1617 if (service()->OnExternalExtensionFileFound(good_crx
,
1620 Manifest::EXTERNAL_PREF
,
1621 Extension::NO_FLAGS
,
1627 ASSERT_TRUE(service()->GetExtensionById(good_crx
, false));
1629 // Uninstall it and check that its killbit gets set.
1630 UninstallExtension(good_crx
, false);
1631 ValidateIntegerPref(good_crx
, "state",
1632 Extension::EXTERNAL_EXTENSION_UNINSTALLED
);
1634 // Try to re-install it externally. This should fail because of the killbit.
1635 service()->OnExternalExtensionFileFound(good_crx
,
1638 Manifest::EXTERNAL_PREF
,
1639 Extension::NO_FLAGS
,
1642 base::RunLoop().RunUntilIdle();
1643 ASSERT_TRUE(NULL
== service()->GetExtensionById(good_crx
, false));
1644 ValidateIntegerPref(good_crx
, "state",
1645 Extension::EXTERNAL_EXTENSION_UNINSTALLED
);
1647 version
= Version("1.0.0.1");
1648 // Repeat the same thing with a newer version of the extension.
1649 path
= data_dir().AppendASCII("good2.crx");
1650 service()->OnExternalExtensionFileFound(good_crx
,
1653 Manifest::EXTERNAL_PREF
,
1654 Extension::NO_FLAGS
,
1657 base::RunLoop().RunUntilIdle();
1658 ASSERT_TRUE(NULL
== service()->GetExtensionById(good_crx
, false));
1659 ValidateIntegerPref(good_crx
, "state",
1660 Extension::EXTERNAL_EXTENSION_UNINSTALLED
);
1662 // Try adding the same extension from an external update URL.
1663 ASSERT_FALSE(service()->pending_extension_manager()->AddFromExternalUpdateUrl(
1666 GURL("http:://fake.update/url"),
1667 Manifest::EXTERNAL_PREF_DOWNLOAD
,
1668 Extension::NO_FLAGS
,
1671 ASSERT_FALSE(service()->pending_extension_manager()->IsIdPending(good_crx
));
1674 // Test that uninstalling an external extension does not crash when
1675 // the extension could not be loaded.
1676 // This extension shown in preferences file requires an experimental permission.
1677 // It could not be loaded without such permission.
1678 TEST_F(ExtensionServiceTest
, UninstallingNotLoadedExtension
) {
1679 base::FilePath source_install_dir
=
1680 data_dir().AppendASCII("good").AppendASCII("Extensions");
1681 // The preference contains an external extension
1682 // that requires 'experimental' permission.
1683 base::FilePath pref_path
= source_install_dir
1685 .AppendASCII("PreferencesExperimental");
1687 // Aforementioned extension will not be loaded if
1688 // there is no '--enable-experimental-extension-apis' command line flag.
1689 InitializeInstalledExtensionService(pref_path
, source_install_dir
);
1693 // Check and try to uninstall it.
1694 // If we don't check whether the extension is loaded before we uninstall it
1695 // in CheckExternalUninstall, a crash will happen here because we will get or
1696 // dereference a NULL pointer (extension) inside UninstallExtension.
1697 MockExtensionProvider
provider(NULL
, Manifest::EXTERNAL_REGISTRY
);
1698 service()->OnExternalProviderReady(&provider
);
1701 // Test that external extensions with incorrect IDs are not installed.
1702 TEST_F(ExtensionServiceTest
, FailOnWrongId
) {
1703 InitializeEmptyExtensionService();
1704 base::FilePath path
= data_dir().AppendASCII("good.crx");
1705 service()->set_extensions_enabled(true);
1707 Version
version("1.0.0.0");
1709 const std::string wrong_id
= all_zero
;
1710 const std::string correct_id
= good_crx
;
1711 ASSERT_NE(correct_id
, wrong_id
);
1713 // Install an external extension with an ID from the external
1714 // source that is not equal to the ID in the extension manifest.
1715 content::WindowedNotificationObserver
observer(
1716 extensions::NOTIFICATION_CRX_INSTALLER_DONE
,
1717 content::NotificationService::AllSources());
1718 service()->OnExternalExtensionFileFound(wrong_id
,
1721 Manifest::EXTERNAL_PREF
,
1722 Extension::NO_FLAGS
,
1727 ASSERT_FALSE(service()->GetExtensionById(good_crx
, false));
1729 // Try again with the right ID. Expect success.
1730 content::WindowedNotificationObserver
observer2(
1731 extensions::NOTIFICATION_CRX_INSTALLER_DONE
,
1732 content::NotificationService::AllSources());
1733 if (service()->OnExternalExtensionFileFound(correct_id
,
1736 Manifest::EXTERNAL_PREF
,
1737 Extension::NO_FLAGS
,
1742 ASSERT_TRUE(service()->GetExtensionById(good_crx
, false));
1745 // Test that external extensions with incorrect versions are not installed.
1746 TEST_F(ExtensionServiceTest
, FailOnWrongVersion
) {
1747 InitializeEmptyExtensionService();
1748 base::FilePath path
= data_dir().AppendASCII("good.crx");
1749 service()->set_extensions_enabled(true);
1751 // Install an external extension with a version from the external
1752 // source that is not equal to the version in the extension manifest.
1753 Version
wrong_version("1.2.3.4");
1754 content::WindowedNotificationObserver
observer(
1755 extensions::NOTIFICATION_CRX_INSTALLER_DONE
,
1756 content::NotificationService::AllSources());
1757 service()->OnExternalExtensionFileFound(good_crx
,
1760 Manifest::EXTERNAL_PREF
,
1761 Extension::NO_FLAGS
,
1766 ASSERT_FALSE(service()->GetExtensionById(good_crx
, false));
1768 // Try again with the right version. Expect success.
1769 service()->pending_extension_manager()->Remove(good_crx
);
1770 Version
correct_version("1.0.0.0");
1771 content::WindowedNotificationObserver
observer2(
1772 extensions::NOTIFICATION_CRX_INSTALLER_DONE
,
1773 content::NotificationService::AllSources());
1774 if (service()->OnExternalExtensionFileFound(good_crx
,
1777 Manifest::EXTERNAL_PREF
,
1778 Extension::NO_FLAGS
,
1783 ASSERT_TRUE(service()->GetExtensionById(good_crx
, false));
1786 // Install a user script (they get converted automatically to an extension)
1787 TEST_F(ExtensionServiceTest
, InstallUserScript
) {
1788 // The details of script conversion are tested elsewhere, this just tests
1789 // integration with ExtensionService.
1790 InitializeEmptyExtensionService();
1792 base::FilePath path
= data_dir().AppendASCII("user_script_basic.user.js");
1794 ASSERT_TRUE(base::PathExists(path
));
1795 scoped_refptr
<CrxInstaller
> installer(CrxInstaller::CreateSilent(service()));
1796 installer
->set_allow_silent_install(true);
1797 installer
->InstallUserScript(
1799 GURL("http://www.aaronboodman.com/scripts/user_script_basic.user.js"));
1801 base::RunLoop().RunUntilIdle();
1802 std::vector
<base::string16
> errors
= GetErrors();
1803 EXPECT_TRUE(installed_
) << "Nothing was installed.";
1804 EXPECT_FALSE(was_update_
) << path
.value();
1805 ASSERT_EQ(1u, loaded_
.size()) << "Nothing was loaded.";
1806 EXPECT_EQ(0u, errors
.size())
1807 << "There were errors: "
1808 << base::JoinString(errors
, base::ASCIIToUTF16(","));
1809 EXPECT_TRUE(service()->GetExtensionById(loaded_
[0]->id(), false))
1813 was_update_
= false;
1815 ExtensionErrorReporter::GetInstance()->ClearErrors();
1818 // Extensions don't install during shutdown.
1819 TEST_F(ExtensionServiceTest
, InstallExtensionDuringShutdown
) {
1820 InitializeEmptyExtensionService();
1822 // Simulate shutdown.
1823 service()->set_browser_terminating_for_test(true);
1825 base::FilePath path
= data_dir().AppendASCII("good.crx");
1826 scoped_refptr
<CrxInstaller
> installer(CrxInstaller::CreateSilent(service()));
1827 installer
->set_allow_silent_install(true);
1828 installer
->InstallCrx(path
);
1829 base::RunLoop().RunUntilIdle();
1831 EXPECT_FALSE(installed_
) << "Extension installed during shutdown.";
1832 ASSERT_EQ(0u, loaded_
.size()) << "Extension loaded during shutdown.";
1835 // This tests that the granted permissions preferences are correctly set when
1836 // installing an extension.
1837 TEST_F(ExtensionServiceTest
, GrantedPermissions
) {
1838 InitializeEmptyExtensionService();
1839 base::FilePath path
= data_dir().AppendASCII("permissions");
1841 base::FilePath pem_path
= path
.AppendASCII("unknown.pem");
1842 path
= path
.AppendASCII("unknown");
1844 ASSERT_TRUE(base::PathExists(pem_path
));
1845 ASSERT_TRUE(base::PathExists(path
));
1847 ExtensionPrefs
* prefs
= ExtensionPrefs::Get(profile());
1849 APIPermissionSet expected_api_perms
;
1850 URLPatternSet expected_host_perms
;
1852 // Make sure there aren't any granted permissions before the
1853 // extension is installed.
1854 scoped_refptr
<PermissionSet
> known_perms(
1855 prefs
->GetGrantedPermissions(permissions_crx
));
1856 EXPECT_FALSE(known_perms
.get());
1858 const Extension
* extension
= PackAndInstallCRX(path
, pem_path
, INSTALL_NEW
);
1860 EXPECT_EQ(0u, GetErrors().size());
1861 ASSERT_EQ(1u, registry()->enabled_extensions().size());
1862 EXPECT_EQ(permissions_crx
, extension
->id());
1864 // Verify that the valid API permissions have been recognized.
1865 expected_api_perms
.insert(APIPermission::kTab
);
1867 AddPattern(&expected_host_perms
, "http://*.google.com/*");
1868 AddPattern(&expected_host_perms
, "https://*.google.com/*");
1869 AddPattern(&expected_host_perms
, "http://*.google.com.hk/*");
1870 AddPattern(&expected_host_perms
, "http://www.example.com/*");
1872 known_perms
= prefs
->GetGrantedPermissions(extension
->id());
1873 EXPECT_TRUE(known_perms
.get());
1874 EXPECT_FALSE(known_perms
->IsEmpty());
1875 EXPECT_EQ(expected_api_perms
, known_perms
->apis());
1876 EXPECT_FALSE(known_perms
->HasEffectiveFullAccess());
1877 EXPECT_EQ(expected_host_perms
, known_perms
->effective_hosts());
1881 #if !defined(OS_CHROMEOS)
1882 // This tests that the granted permissions preferences are correctly set for
1884 TEST_F(ExtensionServiceTest
, DefaultAppsGrantedPermissions
) {
1885 InitializeEmptyExtensionService();
1886 base::FilePath path
= data_dir().AppendASCII("permissions");
1888 base::FilePath pem_path
= path
.AppendASCII("unknown.pem");
1889 path
= path
.AppendASCII("unknown");
1891 ASSERT_TRUE(base::PathExists(pem_path
));
1892 ASSERT_TRUE(base::PathExists(path
));
1894 ExtensionPrefs
* prefs
= ExtensionPrefs::Get(profile());
1896 APIPermissionSet expected_api_perms
;
1897 URLPatternSet expected_host_perms
;
1899 // Make sure there aren't any granted permissions before the
1900 // extension is installed.
1901 scoped_refptr
<PermissionSet
> known_perms(
1902 prefs
->GetGrantedPermissions(permissions_crx
));
1903 EXPECT_FALSE(known_perms
.get());
1905 const Extension
* extension
= PackAndInstallCRX(
1906 path
, pem_path
, INSTALL_NEW
, Extension::WAS_INSTALLED_BY_DEFAULT
);
1908 EXPECT_EQ(0u, GetErrors().size());
1909 ASSERT_EQ(1u, registry()->enabled_extensions().size());
1910 EXPECT_EQ(permissions_crx
, extension
->id());
1912 // Verify that the valid API permissions have been recognized.
1913 expected_api_perms
.insert(APIPermission::kTab
);
1915 known_perms
= prefs
->GetGrantedPermissions(extension
->id());
1916 EXPECT_TRUE(known_perms
.get());
1917 EXPECT_FALSE(known_perms
->IsEmpty());
1918 EXPECT_EQ(expected_api_perms
, known_perms
->apis());
1919 EXPECT_FALSE(known_perms
->HasEffectiveFullAccess());
1923 #if !defined(OS_POSIX) || defined(OS_MACOSX)
1924 // Tests that the granted permissions full_access bit gets set correctly when
1925 // an extension contains an NPAPI plugin.
1926 // Only run this on platforms that support NPAPI plugins.
1927 TEST_F(ExtensionServiceTest
, GrantedFullAccessPermissions
) {
1928 InitPluginService();
1930 InitializeEmptyExtensionService();
1932 ASSERT_TRUE(base::PathExists(good1_path()));
1933 const Extension
* extension
= PackAndInstallCRX(good1_path(), INSTALL_NEW
);
1934 EXPECT_EQ(0u, GetErrors().size());
1935 EXPECT_EQ(1u, registry()->enabled_extensions().size());
1936 ExtensionPrefs
* prefs
= ExtensionPrefs::Get(profile());
1938 scoped_refptr
<PermissionSet
> permissions(
1939 prefs
->GetGrantedPermissions(extension
->id()));
1940 EXPECT_FALSE(permissions
->IsEmpty());
1941 EXPECT_TRUE(permissions
->HasEffectiveFullAccess());
1942 EXPECT_FALSE(permissions
->apis().empty());
1943 EXPECT_TRUE(permissions
->HasAPIPermission(APIPermission::kPlugin
));
1945 // Full access implies full host access too...
1946 EXPECT_TRUE(permissions
->HasEffectiveAccessToAllHosts());
1950 // Tests that the extension is disabled when permissions are missing from
1951 // the extension's granted permissions preferences. (This simulates updating
1952 // the browser to a version which recognizes more permissions).
1953 TEST_F(ExtensionServiceTest
, GrantedAPIAndHostPermissions
) {
1954 InitializeEmptyExtensionService();
1956 base::FilePath path
=
1957 data_dir().AppendASCII("permissions").AppendASCII("unknown");
1959 ASSERT_TRUE(base::PathExists(path
));
1961 const Extension
* extension
= PackAndInstallCRX(path
, INSTALL_NEW
);
1963 EXPECT_EQ(0u, GetErrors().size());
1964 EXPECT_EQ(1u, registry()->enabled_extensions().size());
1965 std::string extension_id
= extension
->id();
1967 ExtensionPrefs
* prefs
= ExtensionPrefs::Get(profile());
1969 APIPermissionSet expected_api_permissions
;
1970 URLPatternSet expected_host_permissions
;
1972 expected_api_permissions
.insert(APIPermission::kTab
);
1973 AddPattern(&expected_host_permissions
, "http://*.google.com/*");
1974 AddPattern(&expected_host_permissions
, "https://*.google.com/*");
1975 AddPattern(&expected_host_permissions
, "http://*.google.com.hk/*");
1976 AddPattern(&expected_host_permissions
, "http://www.example.com/*");
1978 std::set
<std::string
> host_permissions
;
1980 // Test that the extension is disabled when an API permission is missing from
1981 // the extension's granted api permissions preference. (This simulates
1982 // updating the browser to a version which recognizes a new API permission).
1983 SetPref(extension_id
, "granted_permissions.api",
1984 new base::ListValue(), "granted_permissions.api");
1985 service()->ReloadExtensionsForTest();
1987 EXPECT_EQ(1u, registry()->disabled_extensions().size());
1988 extension
= registry()->disabled_extensions().begin()->get();
1990 ASSERT_TRUE(prefs
->IsExtensionDisabled(extension_id
));
1991 ASSERT_FALSE(service()->IsExtensionEnabled(extension_id
));
1992 ASSERT_TRUE(prefs
->DidExtensionEscalatePermissions(extension_id
));
1994 // Now grant and re-enable the extension, making sure the prefs are updated.
1995 service()->GrantPermissionsAndEnableExtension(extension
);
1997 ASSERT_FALSE(prefs
->IsExtensionDisabled(extension_id
));
1998 ASSERT_TRUE(service()->IsExtensionEnabled(extension_id
));
1999 ASSERT_FALSE(prefs
->DidExtensionEscalatePermissions(extension_id
));
2001 scoped_refptr
<PermissionSet
> current_perms(
2002 prefs
->GetGrantedPermissions(extension_id
));
2003 ASSERT_TRUE(current_perms
.get());
2004 ASSERT_FALSE(current_perms
->IsEmpty());
2005 ASSERT_FALSE(current_perms
->HasEffectiveFullAccess());
2006 ASSERT_EQ(expected_api_permissions
, current_perms
->apis());
2007 ASSERT_EQ(expected_host_permissions
, current_perms
->effective_hosts());
2009 // Tests that the extension is disabled when a host permission is missing from
2010 // the extension's granted host permissions preference. (This simulates
2011 // updating the browser to a version which recognizes additional host
2013 host_permissions
.clear();
2014 current_perms
= NULL
;
2016 host_permissions
.insert("http://*.google.com/*");
2017 host_permissions
.insert("https://*.google.com/*");
2018 host_permissions
.insert("http://*.google.com.hk/*");
2020 base::ListValue
* api_permissions
= new base::ListValue();
2021 api_permissions
->Append(
2022 new base::StringValue("tabs"));
2023 SetPref(extension_id
, "granted_permissions.api",
2024 api_permissions
, "granted_permissions.api");
2026 extension_id
, "granted_permissions.scriptable_host", host_permissions
);
2028 service()->ReloadExtensionsForTest();
2030 EXPECT_EQ(1u, registry()->disabled_extensions().size());
2031 extension
= registry()->disabled_extensions().begin()->get();
2033 ASSERT_TRUE(prefs
->IsExtensionDisabled(extension_id
));
2034 ASSERT_FALSE(service()->IsExtensionEnabled(extension_id
));
2035 ASSERT_TRUE(prefs
->DidExtensionEscalatePermissions(extension_id
));
2037 // Now grant and re-enable the extension, making sure the prefs are updated.
2038 service()->GrantPermissionsAndEnableExtension(extension
);
2040 ASSERT_TRUE(service()->IsExtensionEnabled(extension_id
));
2041 ASSERT_FALSE(prefs
->DidExtensionEscalatePermissions(extension_id
));
2043 current_perms
= prefs
->GetGrantedPermissions(extension_id
);
2044 ASSERT_TRUE(current_perms
.get());
2045 ASSERT_FALSE(current_perms
->IsEmpty());
2046 ASSERT_FALSE(current_perms
->HasEffectiveFullAccess());
2047 ASSERT_EQ(expected_api_permissions
, current_perms
->apis());
2048 ASSERT_EQ(expected_host_permissions
, current_perms
->effective_hosts());
2051 // Test Packaging and installing an extension.
2052 TEST_F(ExtensionServiceTest
, PackExtension
) {
2053 InitializeEmptyExtensionService();
2054 base::FilePath input_directory
=
2056 .AppendASCII("good")
2057 .AppendASCII("Extensions")
2058 .AppendASCII("behllobkkfkfnphdnhnkndlbkcpglgmj")
2059 .AppendASCII("1.0.0.0");
2061 base::ScopedTempDir temp_dir
;
2062 ASSERT_TRUE(temp_dir
.CreateUniqueTempDir());
2063 base::FilePath output_directory
= temp_dir
.path();
2065 base::FilePath
crx_path(output_directory
.AppendASCII("ex1.crx"));
2066 base::FilePath
privkey_path(output_directory
.AppendASCII("privkey.pem"));
2068 scoped_ptr
<ExtensionCreator
> creator(new ExtensionCreator());
2069 ASSERT_TRUE(creator
->Run(input_directory
, crx_path
, base::FilePath(),
2070 privkey_path
, ExtensionCreator::kNoRunFlags
));
2071 ASSERT_TRUE(base::PathExists(crx_path
));
2072 ASSERT_TRUE(base::PathExists(privkey_path
));
2074 // Repeat the run with the pem file gone, and no special flags
2075 // Should refuse to overwrite the existing crx.
2076 base::DeleteFile(privkey_path
, false);
2077 ASSERT_FALSE(creator
->Run(input_directory
, crx_path
, base::FilePath(),
2078 privkey_path
, ExtensionCreator::kNoRunFlags
));
2080 // OK, now try it with a flag to overwrite existing crx. Should work.
2081 ASSERT_TRUE(creator
->Run(input_directory
, crx_path
, base::FilePath(),
2082 privkey_path
, ExtensionCreator::kOverwriteCRX
));
2084 // Repeat the run allowing existing crx, but the existing pem is still
2085 // an error. Should fail.
2086 ASSERT_FALSE(creator
->Run(input_directory
, crx_path
, base::FilePath(),
2087 privkey_path
, ExtensionCreator::kOverwriteCRX
));
2089 ASSERT_TRUE(base::PathExists(privkey_path
));
2090 InstallCRX(crx_path
, INSTALL_NEW
);
2092 // Try packing with invalid paths.
2093 creator
.reset(new ExtensionCreator());
2095 creator
->Run(base::FilePath(), base::FilePath(), base::FilePath(),
2096 base::FilePath(), ExtensionCreator::kOverwriteCRX
));
2098 // Try packing an empty directory. Should fail because an empty directory is
2099 // not a valid extension.
2100 base::ScopedTempDir temp_dir2
;
2101 ASSERT_TRUE(temp_dir2
.CreateUniqueTempDir());
2102 creator
.reset(new ExtensionCreator());
2103 ASSERT_FALSE(creator
->Run(temp_dir2
.path(), crx_path
, privkey_path
,
2104 base::FilePath(), ExtensionCreator::kOverwriteCRX
));
2106 // Try packing with an invalid manifest.
2107 std::string invalid_manifest_content
= "I am not a manifest.";
2108 ASSERT_TRUE(base::WriteFile(
2109 temp_dir2
.path().Append(extensions::kManifestFilename
),
2110 invalid_manifest_content
.c_str(), invalid_manifest_content
.size()));
2111 creator
.reset(new ExtensionCreator());
2112 ASSERT_FALSE(creator
->Run(temp_dir2
.path(), crx_path
, privkey_path
,
2113 base::FilePath(), ExtensionCreator::kOverwriteCRX
));
2115 // Try packing with a private key that is a valid key, but invalid for the
2117 base::FilePath bad_private_key_dir
=
2118 data_dir().AppendASCII("bad_private_key");
2119 crx_path
= output_directory
.AppendASCII("bad_private_key.crx");
2120 privkey_path
= data_dir().AppendASCII("bad_private_key.pem");
2121 ASSERT_FALSE(creator
->Run(bad_private_key_dir
, crx_path
, base::FilePath(),
2122 privkey_path
, ExtensionCreator::kOverwriteCRX
));
2125 // Test Packaging and installing an extension whose name contains punctuation.
2126 TEST_F(ExtensionServiceTest
, PackPunctuatedExtension
) {
2127 InitializeEmptyExtensionService();
2128 base::FilePath input_directory
= data_dir()
2129 .AppendASCII("good")
2130 .AppendASCII("Extensions")
2132 .AppendASCII("1.0.0.0");
2134 base::ScopedTempDir temp_dir
;
2135 ASSERT_TRUE(temp_dir
.CreateUniqueTempDir());
2137 // Extension names containing punctuation, and the expected names for the
2138 // packed extensions.
2139 const base::FilePath punctuated_names
[] = {
2140 base::FilePath(FILE_PATH_LITERAL("this.extensions.name.has.periods")),
2141 base::FilePath(FILE_PATH_LITERAL(".thisextensionsnamestartswithaperiod")),
2142 base::FilePath(FILE_PATH_LITERAL("thisextensionhasaslashinitsname/")).
2143 NormalizePathSeparators(),
2145 const base::FilePath expected_crx_names
[] = {
2146 base::FilePath(FILE_PATH_LITERAL("this.extensions.name.has.periods.crx")),
2148 FILE_PATH_LITERAL(".thisextensionsnamestartswithaperiod.crx")),
2149 base::FilePath(FILE_PATH_LITERAL("thisextensionhasaslashinitsname.crx")),
2151 const base::FilePath expected_private_key_names
[] = {
2152 base::FilePath(FILE_PATH_LITERAL("this.extensions.name.has.periods.pem")),
2154 FILE_PATH_LITERAL(".thisextensionsnamestartswithaperiod.pem")),
2155 base::FilePath(FILE_PATH_LITERAL("thisextensionhasaslashinitsname.pem")),
2158 for (size_t i
= 0; i
< arraysize(punctuated_names
); ++i
) {
2159 SCOPED_TRACE(punctuated_names
[i
].value().c_str());
2160 base::FilePath output_dir
= temp_dir
.path().Append(punctuated_names
[i
]);
2162 // Copy the extension into the output directory, as PackExtensionJob doesn't
2163 // let us choose where to output the packed extension.
2164 ASSERT_TRUE(base::CopyDirectory(input_directory
, output_dir
, true));
2166 base::FilePath expected_crx_path
=
2167 temp_dir
.path().Append(expected_crx_names
[i
]);
2168 base::FilePath expected_private_key_path
=
2169 temp_dir
.path().Append(expected_private_key_names
[i
]);
2170 PackExtensionTestClient
pack_client(expected_crx_path
,
2171 expected_private_key_path
);
2172 scoped_refptr
<extensions::PackExtensionJob
> packer(
2173 new extensions::PackExtensionJob(&pack_client
, output_dir
,
2175 ExtensionCreator::kOverwriteCRX
));
2178 // The packer will post a notification task to the current thread's message
2179 // loop when it is finished. We manually run the loop here so that we
2180 // block and catch the notification; otherwise, the process would exit.
2181 // This call to |Run()| is matched by a call to |Quit()| in the
2182 // |PackExtensionTestClient|'s notification handling code.
2183 base::MessageLoop::current()->Run();
2185 if (HasFatalFailure())
2188 InstallCRX(expected_crx_path
, INSTALL_NEW
);
2192 TEST_F(ExtensionServiceTest
, PackExtensionContainingKeyFails
) {
2193 InitializeEmptyExtensionService();
2195 base::ScopedTempDir extension_temp_dir
;
2196 ASSERT_TRUE(extension_temp_dir
.CreateUniqueTempDir());
2197 base::FilePath input_directory
= extension_temp_dir
.path().AppendASCII("ext");
2199 base::CopyDirectory(data_dir()
2200 .AppendASCII("good")
2201 .AppendASCII("Extensions")
2202 .AppendASCII("behllobkkfkfnphdnhnkndlbkcpglgmj")
2203 .AppendASCII("1.0.0.0"),
2205 /*recursive=*/true));
2207 base::ScopedTempDir output_temp_dir
;
2208 ASSERT_TRUE(output_temp_dir
.CreateUniqueTempDir());
2209 base::FilePath output_directory
= output_temp_dir
.path();
2211 base::FilePath
crx_path(output_directory
.AppendASCII("ex1.crx"));
2212 base::FilePath
privkey_path(output_directory
.AppendASCII("privkey.pem"));
2214 // Pack the extension once to get a private key.
2215 scoped_ptr
<ExtensionCreator
> creator(new ExtensionCreator());
2216 ASSERT_TRUE(creator
->Run(input_directory
, crx_path
, base::FilePath(),
2217 privkey_path
, ExtensionCreator::kNoRunFlags
))
2218 << creator
->error_message();
2219 ASSERT_TRUE(base::PathExists(crx_path
));
2220 ASSERT_TRUE(base::PathExists(privkey_path
));
2222 base::DeleteFile(crx_path
, false);
2223 // Move the pem file into the extension.
2224 base::Move(privkey_path
,
2225 input_directory
.AppendASCII("privkey.pem"));
2227 // This pack should fail because of the contained private key.
2228 EXPECT_FALSE(creator
->Run(input_directory
, crx_path
, base::FilePath(),
2229 privkey_path
, ExtensionCreator::kNoRunFlags
));
2230 EXPECT_THAT(creator
->error_message(),
2231 testing::ContainsRegex(
2232 "extension includes the key file.*privkey.pem"));
2235 // Test Packaging and installing an extension using an openssl generated key.
2236 // The openssl is generated with the following:
2237 // > openssl genrsa -out privkey.pem 1024
2238 // > openssl pkcs8 -topk8 -nocrypt -in privkey.pem -out privkey_asn1.pem
2239 // The privkey.pem is a PrivateKey, and the pcks8 -topk8 creates a
2240 // PrivateKeyInfo ASN.1 structure, we our RSAPrivateKey expects.
2241 TEST_F(ExtensionServiceTest
, PackExtensionOpenSSLKey
) {
2242 InitializeEmptyExtensionService();
2243 base::FilePath input_directory
=
2245 .AppendASCII("good")
2246 .AppendASCII("Extensions")
2247 .AppendASCII("behllobkkfkfnphdnhnkndlbkcpglgmj")
2248 .AppendASCII("1.0.0.0");
2249 base::FilePath
privkey_path(
2250 data_dir().AppendASCII("openssl_privkey_asn1.pem"));
2251 ASSERT_TRUE(base::PathExists(privkey_path
));
2253 base::ScopedTempDir temp_dir
;
2254 ASSERT_TRUE(temp_dir
.CreateUniqueTempDir());
2255 base::FilePath output_directory
= temp_dir
.path();
2257 base::FilePath
crx_path(output_directory
.AppendASCII("ex1.crx"));
2259 scoped_ptr
<ExtensionCreator
> creator(new ExtensionCreator());
2260 ASSERT_TRUE(creator
->Run(input_directory
, crx_path
, privkey_path
,
2261 base::FilePath(), ExtensionCreator::kOverwriteCRX
));
2263 InstallCRX(crx_path
, INSTALL_NEW
);
2266 #if defined(THREAD_SANITIZER)
2267 // Flaky under Tsan. http://crbug.com/377702
2268 #define MAYBE_InstallTheme DISABLED_InstallTheme
2270 #define MAYBE_InstallTheme InstallTheme
2273 TEST_F(ExtensionServiceTest
, MAYBE_InstallTheme
) {
2274 InitializeEmptyExtensionService();
2278 base::FilePath path
= data_dir().AppendASCII("theme.crx");
2279 InstallCRX(path
, INSTALL_NEW
);
2281 ValidatePrefKeyCount(++pref_count
);
2282 ValidateIntegerPref(theme_crx
, "state", Extension::ENABLED
);
2283 ValidateIntegerPref(theme_crx
, "location", Manifest::INTERNAL
);
2285 // A theme when extensions are disabled. Themes can be installed, even when
2286 // extensions are disabled.
2287 service()->set_extensions_enabled(false);
2288 path
= data_dir().AppendASCII("theme2.crx");
2289 InstallCRX(path
, INSTALL_NEW
);
2290 ValidatePrefKeyCount(++pref_count
);
2291 ValidateIntegerPref(theme2_crx
, "state", Extension::ENABLED
);
2292 ValidateIntegerPref(theme2_crx
, "location", Manifest::INTERNAL
);
2294 // A theme with extension elements. Themes cannot have extension elements,
2295 // so any such elements (like content scripts) should be ignored.
2296 service()->set_extensions_enabled(true);
2298 path
= data_dir().AppendASCII("theme_with_extension.crx");
2299 const Extension
* extension
= InstallCRX(path
, INSTALL_NEW
);
2300 ValidatePrefKeyCount(++pref_count
);
2301 ASSERT_TRUE(extension
);
2302 EXPECT_TRUE(extension
->is_theme());
2305 extensions::ContentScriptsInfo::GetContentScripts(extension
).size());
2308 // A theme with image resources missing (misspelt path).
2309 path
= data_dir().AppendASCII("theme_missing_image.crx");
2310 InstallCRX(path
, INSTALL_FAILED
);
2311 ValidatePrefKeyCount(pref_count
);
2314 TEST_F(ExtensionServiceTest
, LoadLocalizedTheme
) {
2316 InitializeEmptyExtensionService();
2319 base::FilePath extension_path
= data_dir().AppendASCII("theme_i18n");
2321 extensions::UnpackedInstaller::Create(service())->Load(extension_path
);
2322 base::RunLoop().RunUntilIdle();
2323 EXPECT_EQ(0u, GetErrors().size());
2324 ASSERT_EQ(1u, loaded_
.size());
2325 EXPECT_EQ(1u, registry()->enabled_extensions().size());
2326 const Extension
* theme
= registry()->enabled_extensions().begin()->get();
2327 EXPECT_EQ("name", theme
->name());
2328 EXPECT_EQ("description", theme
->description());
2330 // Cleanup the "Cached Theme.pak" file. Ideally, this would be installed in a
2331 // temporary directory, but it automatically installs to the extension's
2332 // directory, and we don't want to copy the whole extension for a unittest.
2333 base::FilePath theme_file
= extension_path
.Append(chrome::kThemePackFilename
);
2334 ASSERT_TRUE(base::PathExists(theme_file
));
2335 ASSERT_TRUE(base::DeleteFile(theme_file
, false)); // Not recursive.
2338 #if defined(OS_POSIX)
2339 TEST_F(ExtensionServiceTest
, UnpackedExtensionMayContainSymlinkedFiles
) {
2340 base::FilePath source_data_dir
=
2341 data_dir().AppendASCII("unpacked").AppendASCII("symlinks_allowed");
2343 // Paths to test data files.
2344 base::FilePath source_manifest
= source_data_dir
.AppendASCII("manifest.json");
2345 ASSERT_TRUE(base::PathExists(source_manifest
));
2346 base::FilePath source_icon
= source_data_dir
.AppendASCII("icon.png");
2347 ASSERT_TRUE(base::PathExists(source_icon
));
2349 // Set up the temporary extension directory.
2350 base::ScopedTempDir temp
;
2351 ASSERT_TRUE(temp
.CreateUniqueTempDir());
2352 base::FilePath extension_path
= temp
.path();
2353 base::FilePath manifest
= extension_path
.Append(
2354 extensions::kManifestFilename
);
2355 base::FilePath icon_symlink
= extension_path
.AppendASCII("icon.png");
2356 base::CopyFile(source_manifest
, manifest
);
2357 base::CreateSymbolicLink(source_icon
, icon_symlink
);
2360 InitializeEmptyExtensionService();
2361 extensions::UnpackedInstaller::Create(service())->Load(extension_path
);
2362 base::RunLoop().RunUntilIdle();
2364 EXPECT_TRUE(GetErrors().empty());
2365 ASSERT_EQ(1u, loaded_
.size());
2366 EXPECT_EQ(1u, registry()->enabled_extensions().size());
2370 TEST_F(ExtensionServiceTest
, UnpackedExtensionMayNotHaveUnderscore
) {
2371 InitializeEmptyExtensionService();
2372 base::FilePath extension_path
= data_dir().AppendASCII("underscore_name");
2373 extensions::UnpackedInstaller::Create(service())->Load(extension_path
);
2374 base::RunLoop().RunUntilIdle();
2375 EXPECT_EQ(1u, GetErrors().size());
2376 EXPECT_EQ(0u, registry()->enabled_extensions().size());
2379 TEST_F(ExtensionServiceTest
, InstallLocalizedTheme
) {
2380 InitializeEmptyExtensionService();
2383 base::FilePath theme_path
= data_dir().AppendASCII("theme_i18n");
2385 const Extension
* theme
= PackAndInstallCRX(theme_path
, INSTALL_NEW
);
2387 EXPECT_EQ(0u, GetErrors().size());
2388 EXPECT_EQ(1u, registry()->enabled_extensions().size());
2389 EXPECT_EQ("name", theme
->name());
2390 EXPECT_EQ("description", theme
->description());
2393 TEST_F(ExtensionServiceTest
, InstallApps
) {
2394 InitializeEmptyExtensionService();
2397 const Extension
* app
=
2398 PackAndInstallCRX(data_dir().AppendASCII("app1"), INSTALL_NEW
);
2400 ValidatePrefKeyCount(++pref_count
);
2401 ASSERT_EQ(1u, registry()->enabled_extensions().size());
2402 ValidateIntegerPref(app
->id(), "state", Extension::ENABLED
);
2403 ValidateIntegerPref(app
->id(), "location", Manifest::INTERNAL
);
2405 // Another app with non-overlapping extent. Should succeed.
2406 PackAndInstallCRX(data_dir().AppendASCII("app2"), INSTALL_NEW
);
2407 ValidatePrefKeyCount(++pref_count
);
2409 // A third app whose extent overlaps the first. Should fail.
2410 PackAndInstallCRX(data_dir().AppendASCII("app3"), INSTALL_FAILED
);
2411 ValidatePrefKeyCount(pref_count
);
2414 // Tests that file access is OFF by default.
2415 TEST_F(ExtensionServiceTest
, DefaultFileAccess
) {
2416 InitializeEmptyExtensionService();
2417 const Extension
* extension
= PackAndInstallCRX(
2418 data_dir().AppendASCII("permissions").AppendASCII("files"), INSTALL_NEW
);
2419 EXPECT_EQ(0u, GetErrors().size());
2420 EXPECT_EQ(1u, registry()->enabled_extensions().size());
2422 ExtensionPrefs::Get(profile())->AllowFileAccess(extension
->id()));
2425 TEST_F(ExtensionServiceTest
, UpdateApps
) {
2426 InitializeEmptyExtensionService();
2427 base::FilePath extensions_path
= data_dir().AppendASCII("app_update");
2429 // First install v1 of a hosted app.
2430 const Extension
* extension
=
2431 InstallCRX(extensions_path
.AppendASCII("v1.crx"), INSTALL_NEW
);
2432 ASSERT_EQ(1u, registry()->enabled_extensions().size());
2433 std::string id
= extension
->id();
2434 ASSERT_EQ(std::string("1"), extension
->version()->GetString());
2436 // Now try updating to v2.
2438 extensions_path
.AppendASCII("v2.crx"),
2440 ASSERT_EQ(std::string("2"),
2441 service()->GetExtensionById(id
, false)->version()->GetString());
2444 // Verifies that the NTP page and launch ordinals are kept when updating apps.
2445 TEST_F(ExtensionServiceTest
, UpdateAppsRetainOrdinals
) {
2446 InitializeEmptyExtensionService();
2447 AppSorting
* sorting
= ExtensionPrefs::Get(profile())->app_sorting();
2448 base::FilePath extensions_path
= data_dir().AppendASCII("app_update");
2450 // First install v1 of a hosted app.
2451 const Extension
* extension
=
2452 InstallCRX(extensions_path
.AppendASCII("v1.crx"), INSTALL_NEW
);
2453 ASSERT_EQ(1u, registry()->enabled_extensions().size());
2454 std::string id
= extension
->id();
2455 ASSERT_EQ(std::string("1"), extension
->version()->GetString());
2457 // Modify the ordinals so we can distinguish them from the defaults.
2458 syncer::StringOrdinal new_page_ordinal
=
2459 sorting
->GetPageOrdinal(id
).CreateAfter();
2460 syncer::StringOrdinal new_launch_ordinal
=
2461 sorting
->GetAppLaunchOrdinal(id
).CreateBefore();
2463 sorting
->SetPageOrdinal(id
, new_page_ordinal
);
2464 sorting
->SetAppLaunchOrdinal(id
, new_launch_ordinal
);
2466 // Now try updating to v2.
2467 UpdateExtension(id
, extensions_path
.AppendASCII("v2.crx"), ENABLED
);
2468 ASSERT_EQ(std::string("2"),
2469 service()->GetExtensionById(id
, false)->version()->GetString());
2471 // Verify that the ordinals match.
2472 ASSERT_TRUE(new_page_ordinal
.Equals(sorting
->GetPageOrdinal(id
)));
2473 ASSERT_TRUE(new_launch_ordinal
.Equals(sorting
->GetAppLaunchOrdinal(id
)));
2476 // Ensures that the CWS has properly initialized ordinals.
2477 TEST_F(ExtensionServiceTest
, EnsureCWSOrdinalsInitialized
) {
2478 InitializeEmptyExtensionService();
2479 service()->component_loader()->Add(
2480 IDR_WEBSTORE_MANIFEST
, base::FilePath(FILE_PATH_LITERAL("web_store")));
2483 AppSorting
* sorting
= ExtensionPrefs::Get(profile())->app_sorting();
2485 sorting
->GetPageOrdinal(extensions::kWebStoreAppId
).IsValid());
2487 sorting
->GetAppLaunchOrdinal(extensions::kWebStoreAppId
).IsValid());
2490 TEST_F(ExtensionServiceTest
, InstallAppsWithUnlimitedStorage
) {
2491 InitializeEmptyExtensionService();
2492 EXPECT_TRUE(registry()->enabled_extensions().is_empty());
2496 // Install app1 with unlimited storage.
2497 const Extension
* extension
=
2498 PackAndInstallCRX(data_dir().AppendASCII("app1"), INSTALL_NEW
);
2499 ValidatePrefKeyCount(++pref_count
);
2500 ASSERT_EQ(1u, registry()->enabled_extensions().size());
2501 const std::string id1
= extension
->id();
2502 EXPECT_TRUE(extension
->permissions_data()->HasAPIPermission(
2503 APIPermission::kUnlimitedStorage
));
2504 EXPECT_TRUE(extension
->web_extent().MatchesURL(
2505 extensions::AppLaunchInfo::GetFullLaunchURL(extension
)));
2507 extensions::AppLaunchInfo::GetFullLaunchURL(extension
).GetOrigin());
2508 EXPECT_TRUE(profile()->GetExtensionSpecialStoragePolicy()->IsStorageUnlimited(
2511 // Install app2 from the same origin with unlimited storage.
2512 extension
= PackAndInstallCRX(data_dir().AppendASCII("app2"), INSTALL_NEW
);
2513 ValidatePrefKeyCount(++pref_count
);
2514 ASSERT_EQ(2u, registry()->enabled_extensions().size());
2515 const std::string id2
= extension
->id();
2516 EXPECT_TRUE(extension
->permissions_data()->HasAPIPermission(
2517 APIPermission::kUnlimitedStorage
));
2518 EXPECT_TRUE(extension
->web_extent().MatchesURL(
2519 extensions::AppLaunchInfo::GetFullLaunchURL(extension
)));
2521 extensions::AppLaunchInfo::GetFullLaunchURL(extension
).GetOrigin());
2522 EXPECT_EQ(origin1
, origin2
);
2523 EXPECT_TRUE(profile()->GetExtensionSpecialStoragePolicy()->IsStorageUnlimited(
2526 // Uninstall one of them, unlimited storage should still be granted
2528 UninstallExtension(id1
, false);
2529 EXPECT_EQ(1u, registry()->enabled_extensions().size());
2530 EXPECT_TRUE(profile()->GetExtensionSpecialStoragePolicy()->IsStorageUnlimited(
2533 // Uninstall the other, unlimited storage should be revoked.
2534 UninstallExtension(id2
, false);
2535 EXPECT_EQ(0u, registry()->enabled_extensions().size());
2537 profile()->GetExtensionSpecialStoragePolicy()->IsStorageUnlimited(
2541 TEST_F(ExtensionServiceTest
, InstallAppsAndCheckStorageProtection
) {
2542 InitializeEmptyExtensionService();
2543 EXPECT_TRUE(registry()->enabled_extensions().is_empty());
2547 const Extension
* extension
=
2548 PackAndInstallCRX(data_dir().AppendASCII("app1"), INSTALL_NEW
);
2549 ValidatePrefKeyCount(++pref_count
);
2550 ASSERT_EQ(1u, registry()->enabled_extensions().size());
2551 EXPECT_TRUE(extension
->is_app());
2552 const std::string id1
= extension
->id();
2554 extensions::AppLaunchInfo::GetFullLaunchURL(extension
).GetOrigin());
2555 EXPECT_TRUE(profile()->GetExtensionSpecialStoragePolicy()->IsStorageProtected(
2558 // App 4 has a different origin (maps.google.com).
2559 extension
= PackAndInstallCRX(data_dir().AppendASCII("app4"), INSTALL_NEW
);
2560 ValidatePrefKeyCount(++pref_count
);
2561 ASSERT_EQ(2u, registry()->enabled_extensions().size());
2562 const std::string id2
= extension
->id();
2564 extensions::AppLaunchInfo::GetFullLaunchURL(extension
).GetOrigin());
2565 ASSERT_NE(origin1
, origin2
);
2566 EXPECT_TRUE(profile()->GetExtensionSpecialStoragePolicy()->IsStorageProtected(
2569 UninstallExtension(id1
, false);
2570 EXPECT_EQ(1u, registry()->enabled_extensions().size());
2572 UninstallExtension(id2
, false);
2574 EXPECT_TRUE(registry()->enabled_extensions().is_empty());
2576 profile()->GetExtensionSpecialStoragePolicy()->IsStorageProtected(
2579 profile()->GetExtensionSpecialStoragePolicy()->IsStorageProtected(
2583 // Test that when an extension version is reinstalled, nothing happens.
2584 TEST_F(ExtensionServiceTest
, Reinstall
) {
2585 InitializeEmptyExtensionService();
2587 // A simple extension that should install without error.
2588 base::FilePath path
= data_dir().AppendASCII("good.crx");
2589 InstallCRX(path
, INSTALL_NEW
);
2591 ValidatePrefKeyCount(1);
2592 ValidateIntegerPref(good_crx
, "state", Extension::ENABLED
);
2593 ValidateIntegerPref(good_crx
, "location", Manifest::INTERNAL
);
2595 // Reinstall the same version, it should overwrite the previous one.
2596 InstallCRX(path
, INSTALL_UPDATED
);
2598 ValidatePrefKeyCount(1);
2599 ValidateIntegerPref(good_crx
, "state", Extension::ENABLED
);
2600 ValidateIntegerPref(good_crx
, "location", Manifest::INTERNAL
);
2603 // Test that we can determine if extensions came from the
2604 // Chrome web store.
2605 TEST_F(ExtensionServiceTest
, FromWebStore
) {
2606 InitializeEmptyExtensionService();
2608 // A simple extension that should install without error.
2609 base::FilePath path
= data_dir().AppendASCII("good.crx");
2610 // Not from web store.
2611 const Extension
* extension
= InstallCRX(path
, INSTALL_NEW
);
2612 std::string id
= extension
->id();
2614 ValidatePrefKeyCount(1);
2615 ASSERT_TRUE(ValidateBooleanPref(good_crx
, "from_webstore", false));
2616 ASSERT_FALSE(extension
->from_webstore());
2618 // Test install from web store.
2619 InstallCRXFromWebStore(path
, INSTALL_UPDATED
); // From web store.
2621 ValidatePrefKeyCount(1);
2622 ASSERT_TRUE(ValidateBooleanPref(good_crx
, "from_webstore", true));
2624 // Reload so extension gets reinitialized with new value.
2625 service()->ReloadExtensionsForTest();
2626 extension
= service()->GetExtensionById(id
, false);
2627 ASSERT_TRUE(extension
->from_webstore());
2629 // Upgrade to version 2.0
2630 path
= data_dir().AppendASCII("good2.crx");
2631 UpdateExtension(good_crx
, path
, ENABLED
);
2632 ValidatePrefKeyCount(1);
2633 ASSERT_TRUE(ValidateBooleanPref(good_crx
, "from_webstore", true));
2636 // Test upgrading a signed extension.
2637 TEST_F(ExtensionServiceTest
, UpgradeSignedGood
) {
2638 InitializeEmptyExtensionService();
2640 base::FilePath path
= data_dir().AppendASCII("good.crx");
2641 const Extension
* extension
= InstallCRX(path
, INSTALL_NEW
);
2642 std::string id
= extension
->id();
2644 ASSERT_EQ("1.0.0.0", extension
->version()->GetString());
2645 ASSERT_EQ(0u, GetErrors().size());
2647 // Upgrade to version 1.0.0.1.
2648 // Also test that the extension's old and new title are correctly retrieved.
2649 path
= data_dir().AppendASCII("good2.crx");
2650 InstallCRX(path
, INSTALL_UPDATED
, Extension::NO_FLAGS
, "My extension 1");
2651 extension
= service()->GetExtensionById(id
, false);
2653 ASSERT_EQ("1.0.0.1", extension
->version()->GetString());
2654 ASSERT_EQ("My updated extension 1", extension
->name());
2655 ASSERT_EQ(0u, GetErrors().size());
2658 // Test upgrading a signed extension with a bad signature.
2659 TEST_F(ExtensionServiceTest
, UpgradeSignedBad
) {
2660 InitializeEmptyExtensionService();
2662 base::FilePath path
= data_dir().AppendASCII("good.crx");
2663 InstallCRX(path
, INSTALL_NEW
);
2665 // Try upgrading with a bad signature. This should fail during the unpack,
2666 // because the key will not match the signature.
2667 path
= data_dir().AppendASCII("bad_signature.crx");
2668 InstallCRX(path
, INSTALL_FAILED
);
2671 // Test a normal update via the UpdateExtension API
2672 TEST_F(ExtensionServiceTest
, UpdateExtension
) {
2673 InitializeEmptyExtensionService();
2675 base::FilePath path
= data_dir().AppendASCII("good.crx");
2677 const Extension
* good
= InstallCRX(path
, INSTALL_NEW
);
2678 ASSERT_EQ("1.0.0.0", good
->VersionString());
2679 ASSERT_EQ(good_crx
, good
->id());
2681 path
= data_dir().AppendASCII("good2.crx");
2682 UpdateExtension(good_crx
, path
, ENABLED
);
2685 service()->GetExtensionById(good_crx
, false)->version()->GetString());
2688 // Extensions should not be updated during browser shutdown.
2689 TEST_F(ExtensionServiceTest
, UpdateExtensionDuringShutdown
) {
2690 InitializeEmptyExtensionService();
2692 // Install an extension.
2693 base::FilePath path
= data_dir().AppendASCII("good.crx");
2694 const Extension
* good
= InstallCRX(path
, INSTALL_NEW
);
2695 ASSERT_EQ(good_crx
, good
->id());
2697 // Simulate shutdown.
2698 service()->set_browser_terminating_for_test(true);
2700 // Update should fail and extension should not be updated.
2701 path
= data_dir().AppendASCII("good2.crx");
2702 bool updated
= service()->UpdateExtension(
2703 extensions::CRXFileInfo(good_crx
, path
), true, NULL
);
2704 ASSERT_FALSE(updated
);
2707 service()->GetExtensionById(good_crx
, false)->version()->GetString());
2710 // Test updating a not-already-installed extension - this should fail
2711 TEST_F(ExtensionServiceTest
, UpdateNotInstalledExtension
) {
2712 InitializeEmptyExtensionService();
2714 base::FilePath path
= data_dir().AppendASCII("good.crx");
2715 UpdateExtension(good_crx
, path
, UPDATED
);
2716 base::RunLoop().RunUntilIdle();
2718 ASSERT_EQ(0u, registry()->enabled_extensions().size());
2719 ASSERT_FALSE(installed_
);
2720 ASSERT_EQ(0u, loaded_
.size());
2723 // Makes sure you can't downgrade an extension via UpdateExtension
2724 TEST_F(ExtensionServiceTest
, UpdateWillNotDowngrade
) {
2725 InitializeEmptyExtensionService();
2727 base::FilePath path
= data_dir().AppendASCII("good2.crx");
2729 const Extension
* good
= InstallCRX(path
, INSTALL_NEW
);
2730 ASSERT_EQ("1.0.0.1", good
->VersionString());
2731 ASSERT_EQ(good_crx
, good
->id());
2733 // Change path from good2.crx -> good.crx
2734 path
= data_dir().AppendASCII("good.crx");
2735 UpdateExtension(good_crx
, path
, FAILED
);
2738 service()->GetExtensionById(good_crx
, false)->version()->GetString());
2741 // Make sure calling update with an identical version does nothing
2742 TEST_F(ExtensionServiceTest
, UpdateToSameVersionIsNoop
) {
2743 InitializeEmptyExtensionService();
2745 base::FilePath path
= data_dir().AppendASCII("good.crx");
2747 const Extension
* good
= InstallCRX(path
, INSTALL_NEW
);
2748 ASSERT_EQ(good_crx
, good
->id());
2749 UpdateExtension(good_crx
, path
, FAILED_SILENTLY
);
2752 // Tests that updating an extension does not clobber old state.
2753 TEST_F(ExtensionServiceTest
, UpdateExtensionPreservesState
) {
2754 InitializeEmptyExtensionService();
2756 base::FilePath path
= data_dir().AppendASCII("good.crx");
2758 const Extension
* good
= InstallCRX(path
, INSTALL_NEW
);
2759 ASSERT_EQ("1.0.0.0", good
->VersionString());
2760 ASSERT_EQ(good_crx
, good
->id());
2762 // Disable it and allow it to run in incognito. These settings should carry
2763 // over to the updated version.
2764 service()->DisableExtension(good
->id(), Extension::DISABLE_USER_ACTION
);
2765 extensions::util::SetIsIncognitoEnabled(good
->id(), profile(), true);
2767 path
= data_dir().AppendASCII("good2.crx");
2768 UpdateExtension(good_crx
, path
, INSTALLED
);
2769 ASSERT_EQ(1u, registry()->disabled_extensions().size());
2770 const Extension
* good2
= service()->GetExtensionById(good_crx
, true);
2771 ASSERT_EQ("1.0.0.1", good2
->version()->GetString());
2772 EXPECT_TRUE(extensions::util::IsIncognitoEnabled(good2
->id(), profile()));
2773 EXPECT_EQ(Extension::DISABLE_USER_ACTION
,
2774 ExtensionPrefs::Get(profile())->GetDisableReasons(good2
->id()));
2777 // Tests that updating preserves extension location.
2778 TEST_F(ExtensionServiceTest
, UpdateExtensionPreservesLocation
) {
2779 InitializeEmptyExtensionService();
2781 base::FilePath path
= data_dir().AppendASCII("good.crx");
2783 const Extension
* good
=
2784 InstallCRXWithLocation(path
, Manifest::EXTERNAL_PREF
, INSTALL_NEW
);
2786 ASSERT_EQ("1.0.0.0", good
->VersionString());
2787 ASSERT_EQ(good_crx
, good
->id());
2789 path
= data_dir().AppendASCII("good2.crx");
2790 UpdateExtension(good_crx
, path
, ENABLED
);
2791 const Extension
* good2
= service()->GetExtensionById(good_crx
, false);
2792 ASSERT_EQ("1.0.0.1", good2
->version()->GetString());
2793 EXPECT_EQ(good2
->location(), Manifest::EXTERNAL_PREF
);
2796 // Makes sure that LOAD extension types can downgrade.
2797 TEST_F(ExtensionServiceTest
, LoadExtensionsCanDowngrade
) {
2798 InitializeEmptyExtensionService();
2800 base::ScopedTempDir temp
;
2801 ASSERT_TRUE(temp
.CreateUniqueTempDir());
2803 // We'll write the extension manifest dynamically to a temporary path
2804 // to make it easier to change the version number.
2805 base::FilePath extension_path
= temp
.path();
2806 base::FilePath manifest_path
=
2807 extension_path
.Append(extensions::kManifestFilename
);
2808 ASSERT_FALSE(base::PathExists(manifest_path
));
2810 // Start with version 2.0.
2811 base::DictionaryValue manifest
;
2812 manifest
.SetString("version", "2.0");
2813 manifest
.SetString("name", "LOAD Downgrade Test");
2814 manifest
.SetInteger("manifest_version", 2);
2816 JSONFileValueSerializer
serializer(manifest_path
);
2817 ASSERT_TRUE(serializer
.Serialize(manifest
));
2819 extensions::UnpackedInstaller::Create(service())->Load(extension_path
);
2820 base::RunLoop().RunUntilIdle();
2822 EXPECT_EQ(0u, GetErrors().size());
2823 ASSERT_EQ(1u, loaded_
.size());
2824 EXPECT_EQ(Manifest::UNPACKED
, loaded_
[0]->location());
2825 EXPECT_EQ(1u, registry()->enabled_extensions().size());
2826 EXPECT_EQ("2.0", loaded_
[0]->VersionString());
2828 // Now set the version number to 1.0, reload the extensions and verify that
2829 // the downgrade was accepted.
2830 manifest
.SetString("version", "1.0");
2831 ASSERT_TRUE(serializer
.Serialize(manifest
));
2833 extensions::UnpackedInstaller::Create(service())->Load(extension_path
);
2834 base::RunLoop().RunUntilIdle();
2836 EXPECT_EQ(0u, GetErrors().size());
2837 ASSERT_EQ(1u, loaded_
.size());
2838 EXPECT_EQ(Manifest::UNPACKED
, loaded_
[0]->location());
2839 EXPECT_EQ(1u, registry()->enabled_extensions().size());
2840 EXPECT_EQ("1.0", loaded_
[0]->VersionString());
2843 #if !defined(OS_POSIX) || defined(OS_MACOSX)
2844 // LOAD extensions with plugins require approval.
2845 // Only run this on platforms that support NPAPI plugins.
2846 TEST_F(ExtensionServiceTest
, LoadExtensionsWithPlugins
) {
2847 base::FilePath extension_with_plugin_path
= good1_path();
2848 base::FilePath extension_no_plugin_path
= good2_path();
2850 InitPluginService();
2851 InitializeEmptyExtensionService();
2852 service()->set_show_extensions_prompts(true);
2854 // Start by canceling any install prompts.
2855 scoped_ptr
<extensions::ScopedTestDialogAutoConfirm
> auto_confirm(
2856 new extensions::ScopedTestDialogAutoConfirm(
2857 extensions::ScopedTestDialogAutoConfirm::CANCEL
));
2859 // The extension that has a plugin should not install.
2860 extensions::UnpackedInstaller::Create(service())
2861 ->Load(extension_with_plugin_path
);
2862 base::RunLoop().RunUntilIdle();
2863 EXPECT_EQ(0u, GetErrors().size());
2864 EXPECT_EQ(0u, loaded_
.size());
2865 EXPECT_EQ(0u, registry()->enabled_extensions().size());
2866 EXPECT_EQ(0u, registry()->disabled_extensions().size());
2868 // But the extension with no plugin should since there's no prompt.
2869 ExtensionErrorReporter::GetInstance()->ClearErrors();
2870 extensions::UnpackedInstaller::Create(service())
2871 ->Load(extension_no_plugin_path
);
2872 base::RunLoop().RunUntilIdle();
2873 EXPECT_EQ(0u, GetErrors().size());
2874 EXPECT_EQ(1u, loaded_
.size());
2875 EXPECT_EQ(1u, registry()->enabled_extensions().size());
2876 EXPECT_EQ(0u, registry()->disabled_extensions().size());
2877 EXPECT_TRUE(registry()->enabled_extensions().Contains(good2
));
2879 // The plugin extension should install if we accept the dialog.
2880 auto_confirm
.reset();
2881 auto_confirm
.reset(new extensions::ScopedTestDialogAutoConfirm(
2882 extensions::ScopedTestDialogAutoConfirm::ACCEPT
));
2884 ExtensionErrorReporter::GetInstance()->ClearErrors();
2885 extensions::UnpackedInstaller::Create(service())
2886 ->Load(extension_with_plugin_path
);
2887 base::RunLoop().RunUntilIdle();
2888 EXPECT_EQ(0u, GetErrors().size());
2889 EXPECT_EQ(2u, loaded_
.size());
2890 EXPECT_EQ(2u, registry()->enabled_extensions().size());
2891 EXPECT_EQ(0u, registry()->disabled_extensions().size());
2892 EXPECT_TRUE(registry()->enabled_extensions().Contains(good1
));
2893 EXPECT_TRUE(registry()->enabled_extensions().Contains(good2
));
2895 // Make sure the granted permissions have been setup.
2896 scoped_refptr
<PermissionSet
> permissions(
2897 ExtensionPrefs::Get(profile())->GetGrantedPermissions(good1
));
2898 EXPECT_FALSE(permissions
->IsEmpty());
2899 EXPECT_TRUE(permissions
->HasEffectiveFullAccess());
2900 EXPECT_FALSE(permissions
->apis().empty());
2901 EXPECT_TRUE(permissions
->HasAPIPermission(APIPermission::kPlugin
));
2903 // We should be able to reload the extension without getting another prompt.
2905 auto_confirm
.reset();
2906 auto_confirm
.reset(new extensions::ScopedTestDialogAutoConfirm(
2907 extensions::ScopedTestDialogAutoConfirm::CANCEL
));
2909 service()->ReloadExtension(good1
);
2910 base::RunLoop().RunUntilIdle();
2911 EXPECT_EQ(1u, loaded_
.size());
2912 EXPECT_EQ(2u, registry()->enabled_extensions().size());
2913 EXPECT_EQ(0u, registry()->disabled_extensions().size());
2915 #endif // !defined(OS_POSIX) || defined(OS_MACOSX)
2919 bool IsExtension(const Extension
* extension
) {
2920 return extension
->GetType() == Manifest::TYPE_EXTENSION
;
2923 #if defined(ENABLE_BLACKLIST_TESTS)
2924 std::set
<std::string
> StringSet(const std::string
& s
) {
2925 std::set
<std::string
> set
;
2929 std::set
<std::string
> StringSet(const std::string
& s1
, const std::string
& s2
) {
2930 std::set
<std::string
> set
= StringSet(s1
);
2934 #endif // defined(ENABLE_BLACKLIST_TESTS)
2938 // Test adding a pending extension.
2939 TEST_F(ExtensionServiceTest
, AddPendingExtensionFromSync
) {
2940 InitializeEmptyExtensionService();
2942 const std::string
kFakeId(all_zero
);
2943 const GURL
kFakeUpdateURL("http:://fake.update/url");
2944 const bool kFakeRemoteInstall(false);
2945 const bool kFakeInstalledByCustodian(false);
2948 service()->pending_extension_manager()->AddFromSync(
2953 kFakeInstalledByCustodian
));
2955 const extensions::PendingExtensionInfo
* pending_extension_info
;
2956 ASSERT_TRUE((pending_extension_info
=
2957 service()->pending_extension_manager()->GetById(kFakeId
)));
2958 EXPECT_EQ(kFakeUpdateURL
, pending_extension_info
->update_url());
2959 EXPECT_EQ(&IsExtension
, pending_extension_info
->should_allow_install_
);
2961 // EXPECT_TRUE(kFakeRemoteInstall == pending_extension_info->remote_install())
2963 // EXPECT_EQ(kFakeRemoteInstall, pending_extension_info->remote_install())
2964 // as gcc 4.7 issues the following warning on EXPECT_EQ(false, x), which is
2965 // turned into an error with -Werror=conversion-null:
2966 // converting 'false' to pointer type for argument 1 of
2967 // 'char testing::internal::IsNullLiteralHelper(testing::internal::Secret*)'
2968 // https://code.google.com/p/googletest/issues/detail?id=458
2969 EXPECT_TRUE(kFakeRemoteInstall
== pending_extension_info
->remote_install());
2973 const char kGoodId
[] = "ldnnhddmnhbkjipkidpdiheffobcpfmf";
2974 const char kGoodUpdateURL
[] = "http://good.update/url";
2975 const bool kGoodIsFromSync
= true;
2976 const bool kGoodRemoteInstall
= false;
2977 const bool kGoodInstalledByCustodian
= false;
2980 // Test updating a pending extension.
2981 TEST_F(ExtensionServiceTest
, UpdatePendingExtension
) {
2982 InitializeEmptyExtensionService();
2984 service()->pending_extension_manager()->AddFromSync(
2986 GURL(kGoodUpdateURL
),
2989 kGoodInstalledByCustodian
));
2990 EXPECT_TRUE(service()->pending_extension_manager()->IsIdPending(kGoodId
));
2992 base::FilePath path
= data_dir().AppendASCII("good.crx");
2993 UpdateExtension(kGoodId
, path
, ENABLED
);
2995 EXPECT_FALSE(service()->pending_extension_manager()->IsIdPending(kGoodId
));
2997 const Extension
* extension
= service()->GetExtensionById(kGoodId
, true);
2998 ASSERT_TRUE(extension
);
3003 bool IsTheme(const Extension
* extension
) {
3004 return extension
->is_theme();
3009 // Test updating a pending theme.
3010 // Disabled due to ASAN failure. http://crbug.com/108320
3011 TEST_F(ExtensionServiceTest
, DISABLED_UpdatePendingTheme
) {
3012 InitializeEmptyExtensionService();
3013 EXPECT_TRUE(service()->pending_extension_manager()->AddFromSync(
3014 theme_crx
, GURL(), &IsTheme
, false, false));
3015 EXPECT_TRUE(service()->pending_extension_manager()->IsIdPending(theme_crx
));
3017 base::FilePath path
= data_dir().AppendASCII("theme.crx");
3018 UpdateExtension(theme_crx
, path
, ENABLED
);
3020 EXPECT_FALSE(service()->pending_extension_manager()->IsIdPending(theme_crx
));
3022 const Extension
* extension
= service()->GetExtensionById(theme_crx
, true);
3023 ASSERT_TRUE(extension
);
3026 ExtensionPrefs::Get(profile())->IsExtensionDisabled(extension
->id()));
3027 EXPECT_TRUE(service()->IsExtensionEnabled(theme_crx
));
3030 #if defined(OS_CHROMEOS)
3031 // Always fails on ChromeOS: http://crbug.com/79737
3032 #define MAYBE_UpdatePendingExternalCrx DISABLED_UpdatePendingExternalCrx
3034 #define MAYBE_UpdatePendingExternalCrx UpdatePendingExternalCrx
3036 // Test updating a pending CRX as if the source is an external extension
3037 // with an update URL. In this case we don't know if the CRX is a theme
3039 TEST_F(ExtensionServiceTest
, MAYBE_UpdatePendingExternalCrx
) {
3040 InitializeEmptyExtensionService();
3041 EXPECT_TRUE(service()->pending_extension_manager()->AddFromExternalUpdateUrl(
3045 Manifest::EXTERNAL_PREF_DOWNLOAD
,
3046 Extension::NO_FLAGS
,
3049 EXPECT_TRUE(service()->pending_extension_manager()->IsIdPending(theme_crx
));
3051 base::FilePath path
= data_dir().AppendASCII("theme.crx");
3052 UpdateExtension(theme_crx
, path
, ENABLED
);
3054 EXPECT_FALSE(service()->pending_extension_manager()->IsIdPending(theme_crx
));
3056 const Extension
* extension
= service()->GetExtensionById(theme_crx
, true);
3057 ASSERT_TRUE(extension
);
3060 ExtensionPrefs::Get(profile())->IsExtensionDisabled(extension
->id()));
3061 EXPECT_TRUE(service()->IsExtensionEnabled(extension
->id()));
3063 extensions::util::IsIncognitoEnabled(extension
->id(), profile()));
3066 // Test updating a pending CRX as if the source is an external extension
3067 // with an update URL. The external update should overwrite a sync update,
3068 // but a sync update should not overwrite a non-sync update.
3069 TEST_F(ExtensionServiceTest
, UpdatePendingExternalCrxWinsOverSync
) {
3070 InitializeEmptyExtensionService();
3072 // Add a crx to be installed from the update mechanism.
3074 service()->pending_extension_manager()->AddFromSync(
3076 GURL(kGoodUpdateURL
),
3079 kGoodInstalledByCustodian
));
3081 // Check that there is a pending crx, with is_from_sync set to true.
3082 const extensions::PendingExtensionInfo
* pending_extension_info
;
3083 ASSERT_TRUE((pending_extension_info
=
3084 service()->pending_extension_manager()->GetById(kGoodId
)));
3085 EXPECT_TRUE(pending_extension_info
->is_from_sync());
3087 // Add a crx to be updated, with the same ID, from a non-sync source.
3088 EXPECT_TRUE(service()->pending_extension_manager()->AddFromExternalUpdateUrl(
3091 GURL(kGoodUpdateURL
),
3092 Manifest::EXTERNAL_PREF_DOWNLOAD
,
3093 Extension::NO_FLAGS
,
3096 // Check that there is a pending crx, with is_from_sync set to false.
3097 ASSERT_TRUE((pending_extension_info
=
3098 service()->pending_extension_manager()->GetById(kGoodId
)));
3099 EXPECT_FALSE(pending_extension_info
->is_from_sync());
3100 EXPECT_EQ(Manifest::EXTERNAL_PREF_DOWNLOAD
,
3101 pending_extension_info
->install_source());
3103 // Add a crx to be installed from the update mechanism.
3105 service()->pending_extension_manager()->AddFromSync(
3107 GURL(kGoodUpdateURL
),
3110 kGoodInstalledByCustodian
));
3112 // Check that the external, non-sync update was not overridden.
3113 ASSERT_TRUE((pending_extension_info
=
3114 service()->pending_extension_manager()->GetById(kGoodId
)));
3115 EXPECT_FALSE(pending_extension_info
->is_from_sync());
3116 EXPECT_EQ(Manifest::EXTERNAL_PREF_DOWNLOAD
,
3117 pending_extension_info
->install_source());
3120 // Updating a theme should fail if the updater is explicitly told that
3121 // the CRX is not a theme.
3122 TEST_F(ExtensionServiceTest
, UpdatePendingCrxThemeMismatch
) {
3123 InitializeEmptyExtensionService();
3124 EXPECT_TRUE(service()->pending_extension_manager()->AddFromSync(
3125 theme_crx
, GURL(), &IsExtension
, false, false));
3127 EXPECT_TRUE(service()->pending_extension_manager()->IsIdPending(theme_crx
));
3129 base::FilePath path
= data_dir().AppendASCII("theme.crx");
3130 UpdateExtension(theme_crx
, path
, FAILED_SILENTLY
);
3132 EXPECT_FALSE(service()->pending_extension_manager()->IsIdPending(theme_crx
));
3134 const Extension
* extension
= service()->GetExtensionById(theme_crx
, true);
3135 ASSERT_FALSE(extension
);
3138 // TODO(akalin): Test updating a pending extension non-silently once
3139 // we can mock out ExtensionInstallUI and inject our version into
3140 // UpdateExtension().
3142 // Test updating a pending extension which fails the should-install test.
3143 TEST_F(ExtensionServiceTest
, UpdatePendingExtensionFailedShouldInstallTest
) {
3144 InitializeEmptyExtensionService();
3145 // Add pending extension with a flipped is_theme.
3147 service()->pending_extension_manager()->AddFromSync(
3149 GURL(kGoodUpdateURL
),
3152 kGoodInstalledByCustodian
));
3153 EXPECT_TRUE(service()->pending_extension_manager()->IsIdPending(kGoodId
));
3155 base::FilePath path
= data_dir().AppendASCII("good.crx");
3156 UpdateExtension(kGoodId
, path
, UPDATED
);
3158 // TODO(akalin): Figure out how to check that the extensions
3159 // directory is cleaned up properly in OnExtensionInstalled().
3161 EXPECT_FALSE(service()->pending_extension_manager()->IsIdPending(kGoodId
));
3164 // TODO(akalin): Figure out how to test that installs of pending
3165 // unsyncable extensions are blocked.
3167 // Test updating a pending extension for one that is not pending.
3168 TEST_F(ExtensionServiceTest
, UpdatePendingExtensionNotPending
) {
3169 InitializeEmptyExtensionService();
3171 base::FilePath path
= data_dir().AppendASCII("good.crx");
3172 UpdateExtension(kGoodId
, path
, UPDATED
);
3174 EXPECT_FALSE(service()->pending_extension_manager()->IsIdPending(kGoodId
));
3177 // Test updating a pending extension for one that is already
3179 TEST_F(ExtensionServiceTest
, UpdatePendingExtensionAlreadyInstalled
) {
3180 InitializeEmptyExtensionService();
3182 base::FilePath path
= data_dir().AppendASCII("good.crx");
3183 const Extension
* good
= InstallCRX(path
, INSTALL_NEW
);
3184 ASSERT_EQ(1u, registry()->enabled_extensions().size());
3186 EXPECT_FALSE(good
->is_theme());
3188 // Use AddExtensionImpl() as AddFrom*() would balk.
3189 service()->pending_extension_manager()->AddExtensionImpl(
3192 extensions::ManifestURL::GetUpdateURL(good
),
3197 Extension::NO_FLAGS
,
3199 kGoodRemoteInstall
);
3200 UpdateExtension(good
->id(), path
, ENABLED
);
3202 EXPECT_FALSE(service()->pending_extension_manager()->IsIdPending(kGoodId
));
3205 #if defined(ENABLE_BLACKLIST_TESTS)
3206 // Tests blacklisting then unblacklisting extensions after the service has been
3208 TEST_F(ExtensionServiceTest
, SetUnsetBlacklistInPrefs
) {
3209 extensions::TestBlacklist test_blacklist
;
3210 // A profile with 3 extensions installed: good0, good1, and good2.
3211 InitializeGoodInstalledExtensionService();
3212 test_blacklist
.Attach(service()->blacklist_
);
3215 const extensions::ExtensionSet
& enabled_extensions
=
3216 registry()->enabled_extensions();
3217 const extensions::ExtensionSet
& blacklisted_extensions
=
3218 registry()->blacklisted_extensions();
3220 EXPECT_TRUE(enabled_extensions
.Contains(good0
) &&
3221 !blacklisted_extensions
.Contains(good0
));
3222 EXPECT_TRUE(enabled_extensions
.Contains(good1
) &&
3223 !blacklisted_extensions
.Contains(good1
));
3224 EXPECT_TRUE(enabled_extensions
.Contains(good2
) &&
3225 !blacklisted_extensions
.Contains(good2
));
3227 EXPECT_FALSE(IsPrefExist(good0
, "blacklist"));
3228 EXPECT_FALSE(IsPrefExist(good1
, "blacklist"));
3229 EXPECT_FALSE(IsPrefExist(good2
, "blacklist"));
3230 EXPECT_FALSE(IsPrefExist("invalid_id", "blacklist"));
3232 // Blacklist good0 and good1 (and an invalid extension ID).
3233 test_blacklist
.SetBlacklistState(
3234 good0
, extensions::BLACKLISTED_MALWARE
, true);
3235 test_blacklist
.SetBlacklistState(
3236 good1
, extensions::BLACKLISTED_MALWARE
, true);
3237 test_blacklist
.SetBlacklistState(
3238 "invalid_id", extensions::BLACKLISTED_MALWARE
, true);
3239 base::RunLoop().RunUntilIdle();
3241 EXPECT_TRUE(!enabled_extensions
.Contains(good0
) &&
3242 blacklisted_extensions
.Contains(good0
));
3243 EXPECT_TRUE(!enabled_extensions
.Contains(good1
) &&
3244 blacklisted_extensions
.Contains(good1
));
3245 EXPECT_TRUE(enabled_extensions
.Contains(good2
) &&
3246 !blacklisted_extensions
.Contains(good2
));
3248 EXPECT_TRUE(ValidateBooleanPref(good0
, "blacklist", true));
3249 EXPECT_TRUE(ValidateBooleanPref(good1
, "blacklist", true));
3250 EXPECT_FALSE(IsPrefExist(good2
, "blacklist"));
3251 EXPECT_FALSE(IsPrefExist("invalid_id", "blacklist"));
3253 // Un-blacklist good1 and blacklist good2.
3254 test_blacklist
.Clear(false);
3255 test_blacklist
.SetBlacklistState(
3256 good0
, extensions::BLACKLISTED_MALWARE
, true);
3257 test_blacklist
.SetBlacklistState(
3258 good2
, extensions::BLACKLISTED_MALWARE
, true);
3259 test_blacklist
.SetBlacklistState(
3260 "invalid_id", extensions::BLACKLISTED_MALWARE
, true);
3261 base::RunLoop().RunUntilIdle();
3263 EXPECT_TRUE(!enabled_extensions
.Contains(good0
) &&
3264 blacklisted_extensions
.Contains(good0
));
3265 EXPECT_TRUE(enabled_extensions
.Contains(good1
) &&
3266 !blacklisted_extensions
.Contains(good1
));
3267 EXPECT_TRUE(!enabled_extensions
.Contains(good2
) &&
3268 blacklisted_extensions
.Contains(good2
));
3270 EXPECT_TRUE(ValidateBooleanPref(good0
, "blacklist", true));
3271 EXPECT_FALSE(IsPrefExist(good1
, "blacklist"));
3272 EXPECT_TRUE(ValidateBooleanPref(good2
, "blacklist", true));
3273 EXPECT_FALSE(IsPrefExist("invalid_id", "blacklist"));
3275 #endif // defined(ENABLE_BLACKLIST_TESTS)
3277 #if defined(ENABLE_BLACKLIST_TESTS)
3278 // Tests trying to install a blacklisted extension.
3279 TEST_F(ExtensionServiceTest
, BlacklistedExtensionWillNotInstall
) {
3280 scoped_refptr
<FakeSafeBrowsingDatabaseManager
> blacklist_db(
3281 new FakeSafeBrowsingDatabaseManager(true));
3282 Blacklist::ScopedDatabaseManagerForTest
scoped_blacklist_db(blacklist_db
);
3284 InitializeEmptyExtensionService();
3287 // After blacklisting good_crx, we cannot install it.
3288 blacklist_db
->SetUnsafe(good_crx
).NotifyUpdate();
3289 base::RunLoop().RunUntilIdle();
3291 base::FilePath path
= data_dir().AppendASCII("good.crx");
3292 // HACK: specify WAS_INSTALLED_BY_DEFAULT so that test machinery doesn't
3293 // decide to install this silently. Somebody should fix these tests, all
3294 // 6,000 lines of them. Hah!
3295 InstallCRX(path
, INSTALL_FAILED
, Extension::WAS_INSTALLED_BY_DEFAULT
);
3296 EXPECT_EQ(0u, registry()->enabled_extensions().size());
3298 #endif // defined(ENABLE_BLACKLIST_TESTS)
3300 #if defined(ENABLE_BLACKLIST_TESTS)
3301 // Unload blacklisted extension on policy change.
3302 TEST_F(ExtensionServiceTest
, UnloadBlacklistedExtensionPolicy
) {
3303 extensions::TestBlacklist test_blacklist
;
3305 // A profile with no extensions installed.
3306 InitializeEmptyExtensionServiceWithTestingPrefs();
3307 test_blacklist
.Attach(service()->blacklist_
);
3309 base::FilePath path
= data_dir().AppendASCII("good.crx");
3311 const Extension
* good
= InstallCRX(path
, INSTALL_NEW
);
3312 EXPECT_EQ(good_crx
, good
->id());
3313 UpdateExtension(good_crx
, path
, FAILED_SILENTLY
);
3314 EXPECT_EQ(1u, registry()->enabled_extensions().size());
3317 ManagementPrefUpdater
pref(profile_
->GetTestingPrefService());
3318 pref
.SetIndividualExtensionInstallationAllowed(good_crx
, true);
3321 test_blacklist
.SetBlacklistState(
3322 good_crx
, extensions::BLACKLISTED_MALWARE
, true);
3323 base::RunLoop().RunUntilIdle();
3325 // The good_crx is blacklisted and the whitelist doesn't negate it.
3326 ASSERT_TRUE(ValidateBooleanPref(good_crx
, "blacklist", true));
3327 EXPECT_EQ(0u, registry()->enabled_extensions().size());
3329 #endif // defined(ENABLE_BLACKLIST_TESTS)
3331 #if defined(ENABLE_BLACKLIST_TESTS)
3332 // Tests that a blacklisted extension is eventually unloaded on startup, if it
3334 TEST_F(ExtensionServiceTest
, WillNotLoadBlacklistedExtensionsFromDirectory
) {
3335 extensions::TestBlacklist test_blacklist
;
3337 // A profile with 3 extensions installed: good0, good1, and good2.
3338 InitializeGoodInstalledExtensionService();
3339 test_blacklist
.Attach(service()->blacklist_
);
3341 // Blacklist good1 before the service initializes.
3342 test_blacklist
.SetBlacklistState(
3343 good1
, extensions::BLACKLISTED_MALWARE
, false);
3347 ASSERT_EQ(3u, loaded_
.size()); // hasn't had time to blacklist yet
3349 base::RunLoop().RunUntilIdle();
3351 ASSERT_EQ(1u, registry()->blacklisted_extensions().size());
3352 ASSERT_EQ(2u, registry()->enabled_extensions().size());
3354 ASSERT_TRUE(registry()->enabled_extensions().Contains(good0
));
3355 ASSERT_TRUE(registry()->blacklisted_extensions().Contains(good1
));
3356 ASSERT_TRUE(registry()->enabled_extensions().Contains(good2
));
3358 #endif // defined(ENABLE_BLACKLIST_TESTS)
3360 #if defined(ENABLE_BLACKLIST_TESTS)
3361 // Tests extensions blacklisted in prefs on startup; one still blacklisted by
3362 // safe browsing, the other not. The not-blacklisted one should recover.
3363 TEST_F(ExtensionServiceTest
, BlacklistedInPrefsFromStartup
) {
3364 extensions::TestBlacklist test_blacklist
;
3366 InitializeGoodInstalledExtensionService();
3367 test_blacklist
.Attach(service()->blacklist_
);
3368 ExtensionPrefs::Get(profile())->SetExtensionBlacklisted(good0
, true);
3369 ExtensionPrefs::Get(profile())->SetExtensionBlacklisted(good1
, true);
3371 test_blacklist
.SetBlacklistState(
3372 good1
, extensions::BLACKLISTED_MALWARE
, false);
3374 // Extension service hasn't loaded yet, but IsExtensionEnabled reads out of
3375 // prefs. Ensure it takes into account the blacklist state (crbug.com/373842).
3376 EXPECT_FALSE(service()->IsExtensionEnabled(good0
));
3377 EXPECT_FALSE(service()->IsExtensionEnabled(good1
));
3378 EXPECT_TRUE(service()->IsExtensionEnabled(good2
));
3382 EXPECT_EQ(2u, registry()->blacklisted_extensions().size());
3383 EXPECT_EQ(1u, registry()->enabled_extensions().size());
3385 EXPECT_TRUE(registry()->blacklisted_extensions().Contains(good0
));
3386 EXPECT_TRUE(registry()->blacklisted_extensions().Contains(good1
));
3387 EXPECT_TRUE(registry()->enabled_extensions().Contains(good2
));
3389 // Give time for the blacklist to update.
3390 base::RunLoop().RunUntilIdle();
3392 EXPECT_EQ(1u, registry()->blacklisted_extensions().size());
3393 EXPECT_EQ(2u, registry()->enabled_extensions().size());
3395 EXPECT_TRUE(registry()->enabled_extensions().Contains(good0
));
3396 EXPECT_TRUE(registry()->blacklisted_extensions().Contains(good1
));
3397 EXPECT_TRUE(registry()->enabled_extensions().Contains(good2
));
3399 #endif // defined(ENABLE_BLACKLIST_TESTS)
3401 #if defined(ENABLE_BLACKLIST_TESTS)
3402 // Extension is added to blacklist with BLACKLISTED_POTENTIALLY_UNWANTED state
3403 // after it is installed. It is then successfully re-enabled by the user.
3404 TEST_F(ExtensionServiceTest
, GreylistedExtensionDisabled
) {
3405 extensions::TestBlacklist test_blacklist
;
3406 // A profile with 3 extensions installed: good0, good1, and good2.
3407 InitializeGoodInstalledExtensionService();
3408 test_blacklist
.Attach(service()->blacklist_
);
3411 const extensions::ExtensionSet
& enabled_extensions
=
3412 registry()->enabled_extensions();
3413 const extensions::ExtensionSet
& disabled_extensions
=
3414 registry()->disabled_extensions();
3416 EXPECT_TRUE(enabled_extensions
.Contains(good0
));
3417 EXPECT_TRUE(enabled_extensions
.Contains(good1
));
3418 EXPECT_TRUE(enabled_extensions
.Contains(good2
));
3420 // Blacklist good0 and good1 (and an invalid extension ID).
3421 test_blacklist
.SetBlacklistState(
3422 good0
, extensions::BLACKLISTED_CWS_POLICY_VIOLATION
, true);
3423 test_blacklist
.SetBlacklistState(
3424 good1
, extensions::BLACKLISTED_POTENTIALLY_UNWANTED
, true);
3425 test_blacklist
.SetBlacklistState(
3426 "invalid_id", extensions::BLACKLISTED_MALWARE
, true);
3427 base::RunLoop().RunUntilIdle();
3429 EXPECT_FALSE(enabled_extensions
.Contains(good0
));
3430 EXPECT_TRUE(disabled_extensions
.Contains(good0
));
3431 EXPECT_FALSE(enabled_extensions
.Contains(good1
));
3432 EXPECT_TRUE(disabled_extensions
.Contains(good1
));
3433 EXPECT_TRUE(enabled_extensions
.Contains(good2
));
3434 EXPECT_FALSE(disabled_extensions
.Contains(good2
));
3436 ValidateIntegerPref(
3437 good0
, "blacklist_state", extensions::BLACKLISTED_CWS_POLICY_VIOLATION
);
3438 ValidateIntegerPref(
3439 good1
, "blacklist_state", extensions::BLACKLISTED_POTENTIALLY_UNWANTED
);
3441 // Now user enables good0.
3442 service()->EnableExtension(good0
);
3444 EXPECT_TRUE(enabled_extensions
.Contains(good0
));
3445 EXPECT_FALSE(disabled_extensions
.Contains(good0
));
3446 EXPECT_FALSE(enabled_extensions
.Contains(good1
));
3447 EXPECT_TRUE(disabled_extensions
.Contains(good1
));
3449 // Remove extensions from blacklist.
3450 test_blacklist
.SetBlacklistState(
3451 good0
, extensions::NOT_BLACKLISTED
, true);
3452 test_blacklist
.SetBlacklistState(
3453 good1
, extensions::NOT_BLACKLISTED
, true);
3454 base::RunLoop().RunUntilIdle();
3456 // All extensions are enabled.
3457 EXPECT_TRUE(enabled_extensions
.Contains(good0
));
3458 EXPECT_FALSE(disabled_extensions
.Contains(good0
));
3459 EXPECT_TRUE(enabled_extensions
.Contains(good1
));
3460 EXPECT_FALSE(disabled_extensions
.Contains(good1
));
3461 EXPECT_TRUE(enabled_extensions
.Contains(good2
));
3462 EXPECT_FALSE(disabled_extensions
.Contains(good2
));
3464 #endif // defined(ENABLE_BLACKLIST_TESTS)
3466 #if defined(ENABLE_BLACKLIST_TESTS)
3467 // When extension is removed from greylist, do not re-enable it if it is
3468 // disabled by user.
3469 TEST_F(ExtensionServiceTest
, GreylistDontEnableManuallyDisabled
) {
3470 extensions::TestBlacklist test_blacklist
;
3471 // A profile with 3 extensions installed: good0, good1, and good2.
3472 InitializeGoodInstalledExtensionService();
3473 test_blacklist
.Attach(service()->blacklist_
);
3476 const extensions::ExtensionSet
& enabled_extensions
=
3477 registry()->enabled_extensions();
3478 const extensions::ExtensionSet
& disabled_extensions
=
3479 registry()->disabled_extensions();
3481 // Manually disable.
3482 service()->DisableExtension(good0
,
3483 extensions::Extension::DISABLE_USER_ACTION
);
3485 test_blacklist
.SetBlacklistState(
3486 good0
, extensions::BLACKLISTED_CWS_POLICY_VIOLATION
, true);
3487 test_blacklist
.SetBlacklistState(
3488 good1
, extensions::BLACKLISTED_POTENTIALLY_UNWANTED
, true);
3489 test_blacklist
.SetBlacklistState(
3490 good2
, extensions::BLACKLISTED_SECURITY_VULNERABILITY
, true);
3491 base::RunLoop().RunUntilIdle();
3493 // All extensions disabled.
3494 EXPECT_FALSE(enabled_extensions
.Contains(good0
));
3495 EXPECT_TRUE(disabled_extensions
.Contains(good0
));
3496 EXPECT_FALSE(enabled_extensions
.Contains(good1
));
3497 EXPECT_TRUE(disabled_extensions
.Contains(good1
));
3498 EXPECT_FALSE(enabled_extensions
.Contains(good2
));
3499 EXPECT_TRUE(disabled_extensions
.Contains(good2
));
3501 // Greylisted extension can be enabled.
3502 service()->EnableExtension(good1
);
3503 EXPECT_TRUE(enabled_extensions
.Contains(good1
));
3504 EXPECT_FALSE(disabled_extensions
.Contains(good1
));
3506 // good1 is now manually disabled.
3507 service()->DisableExtension(good1
,
3508 extensions::Extension::DISABLE_USER_ACTION
);
3509 EXPECT_FALSE(enabled_extensions
.Contains(good1
));
3510 EXPECT_TRUE(disabled_extensions
.Contains(good1
));
3512 // Remove extensions from blacklist.
3513 test_blacklist
.SetBlacklistState(
3514 good0
, extensions::NOT_BLACKLISTED
, true);
3515 test_blacklist
.SetBlacklistState(
3516 good1
, extensions::NOT_BLACKLISTED
, true);
3517 test_blacklist
.SetBlacklistState(
3518 good2
, extensions::NOT_BLACKLISTED
, true);
3519 base::RunLoop().RunUntilIdle();
3521 // good0 and good1 remain disabled.
3522 EXPECT_FALSE(enabled_extensions
.Contains(good0
));
3523 EXPECT_TRUE(disabled_extensions
.Contains(good0
));
3524 EXPECT_FALSE(enabled_extensions
.Contains(good1
));
3525 EXPECT_TRUE(disabled_extensions
.Contains(good1
));
3526 EXPECT_TRUE(enabled_extensions
.Contains(good2
));
3527 EXPECT_FALSE(disabled_extensions
.Contains(good2
));
3529 #endif // defined(ENABLE_BLACKLIST_TESTS)
3531 #if defined(ENABLE_BLACKLIST_TESTS)
3532 // Blacklisted extension with unknown state are not enabled/disabled.
3533 TEST_F(ExtensionServiceTest
, GreylistUnknownDontChange
) {
3534 extensions::TestBlacklist test_blacklist
;
3535 // A profile with 3 extensions installed: good0, good1, and good2.
3536 InitializeGoodInstalledExtensionService();
3537 test_blacklist
.Attach(service()->blacklist_
);
3540 const extensions::ExtensionSet
& enabled_extensions
=
3541 registry()->enabled_extensions();
3542 const extensions::ExtensionSet
& disabled_extensions
=
3543 registry()->disabled_extensions();
3545 test_blacklist
.SetBlacklistState(
3546 good0
, extensions::BLACKLISTED_CWS_POLICY_VIOLATION
, true);
3547 test_blacklist
.SetBlacklistState(
3548 good1
, extensions::BLACKLISTED_POTENTIALLY_UNWANTED
, true);
3549 base::RunLoop().RunUntilIdle();
3551 EXPECT_FALSE(enabled_extensions
.Contains(good0
));
3552 EXPECT_TRUE(disabled_extensions
.Contains(good0
));
3553 EXPECT_FALSE(enabled_extensions
.Contains(good1
));
3554 EXPECT_TRUE(disabled_extensions
.Contains(good1
));
3555 EXPECT_TRUE(enabled_extensions
.Contains(good2
));
3556 EXPECT_FALSE(disabled_extensions
.Contains(good2
));
3558 test_blacklist
.SetBlacklistState(
3559 good0
, extensions::NOT_BLACKLISTED
, true);
3560 test_blacklist
.SetBlacklistState(
3561 good1
, extensions::BLACKLISTED_UNKNOWN
, true);
3562 test_blacklist
.SetBlacklistState(
3563 good2
, extensions::BLACKLISTED_UNKNOWN
, true);
3564 base::RunLoop().RunUntilIdle();
3566 // good0 re-enabled, other remain as they were.
3567 EXPECT_TRUE(enabled_extensions
.Contains(good0
));
3568 EXPECT_FALSE(disabled_extensions
.Contains(good0
));
3569 EXPECT_FALSE(enabled_extensions
.Contains(good1
));
3570 EXPECT_TRUE(disabled_extensions
.Contains(good1
));
3571 EXPECT_TRUE(enabled_extensions
.Contains(good2
));
3572 EXPECT_FALSE(disabled_extensions
.Contains(good2
));
3575 // Tests that blacklisted extensions cannot be reloaded, both those loaded
3576 // before and after extension service startup.
3577 TEST_F(ExtensionServiceTest
, ReloadBlacklistedExtension
) {
3578 extensions::TestBlacklist test_blacklist
;
3580 InitializeGoodInstalledExtensionService();
3581 test_blacklist
.Attach(service()->blacklist_
);
3583 test_blacklist
.SetBlacklistState(
3584 good1
, extensions::BLACKLISTED_MALWARE
, false);
3586 test_blacklist
.SetBlacklistState(
3587 good2
, extensions::BLACKLISTED_MALWARE
, false);
3588 base::RunLoop().RunUntilIdle();
3590 EXPECT_EQ(StringSet(good0
), registry()->enabled_extensions().GetIDs());
3591 EXPECT_EQ(StringSet(good1
, good2
),
3592 registry()->blacklisted_extensions().GetIDs());
3594 service()->ReloadExtension(good1
);
3595 service()->ReloadExtension(good2
);
3596 base::RunLoop().RunUntilIdle();
3598 EXPECT_EQ(StringSet(good0
), registry()->enabled_extensions().GetIDs());
3599 EXPECT_EQ(StringSet(good1
, good2
),
3600 registry()->blacklisted_extensions().GetIDs());
3602 #endif // defined(ENABLE_BLACKLIST_TESTS)
3604 // Tests blocking then unblocking enabled extensions after the service has been
3606 TEST_F(ExtensionServiceTest
, BlockAndUnblockEnabledExtension
) {
3607 InitializeGoodInstalledExtensionService();
3610 AssertExtensionBlocksAndUnblocks(true, good0
);
3613 // Tests blocking then unblocking disabled extensions after the service has been
3615 TEST_F(ExtensionServiceTest
, BlockAndUnblockDisabledExtension
) {
3616 InitializeGoodInstalledExtensionService();
3619 service()->DisableExtension(good0
, Extension::DISABLE_RELOAD
);
3621 AssertExtensionBlocksAndUnblocks(true, good0
);
3624 // Tests blocking then unblocking terminated extensions after the service has
3625 // been initialized.
3626 TEST_F(ExtensionServiceTest
, BlockAndUnblockTerminatedExtension
) {
3627 InitializeGoodInstalledExtensionService();
3630 TerminateExtension(good0
);
3632 AssertExtensionBlocksAndUnblocks(true, good0
);
3635 // Tests blocking then unblocking policy-forced extensions after the service has
3636 // been initialized.
3637 TEST_F(ExtensionServiceTest
, BlockAndUnblockPolicyExtension
) {
3638 InitializeEmptyExtensionServiceWithTestingPrefs();
3641 ManagementPrefUpdater
pref(profile_
->GetTestingPrefService());
3642 // // Blacklist everything.
3643 // pref.SetBlacklistedByDefault(true);
3644 // Mark good.crx for force-installation.
3645 pref
.SetIndividualExtensionAutoInstalled(
3646 good_crx
, "http://example.com/update_url", true);
3649 // Have policy force-install an extension.
3650 MockExtensionProvider
* provider
=
3651 new MockExtensionProvider(service(), Manifest::EXTERNAL_POLICY_DOWNLOAD
);
3652 AddMockExternalProvider(provider
);
3653 provider
->UpdateOrAddExtension(
3654 good_crx
, "1.0.0.0", data_dir().AppendASCII("good_crx"));
3656 // Reloading extensions should find our externally registered extension
3658 content::WindowedNotificationObserver
observer(
3659 extensions::NOTIFICATION_CRX_INSTALLER_DONE
,
3660 content::NotificationService::AllSources());
3661 service()->CheckForExternalUpdates();
3664 AssertExtensionBlocksAndUnblocks(false, good_crx
);
3668 #if defined(ENABLE_BLACKLIST_TESTS)
3669 // Tests blocking then unblocking extensions that are blacklisted both before
3670 // and after Init().
3671 TEST_F(ExtensionServiceTest
, BlockAndUnblockBlacklistedExtension
) {
3672 extensions::TestBlacklist test_blacklist
;
3674 InitializeGoodInstalledExtensionService();
3675 test_blacklist
.Attach(service()->blacklist_
);
3677 test_blacklist
.SetBlacklistState(
3678 good0
, extensions::BLACKLISTED_MALWARE
, true);
3679 base::RunLoop().RunUntilIdle();
3683 test_blacklist
.SetBlacklistState(
3684 good1
, extensions::BLACKLISTED_MALWARE
, true);
3685 base::RunLoop().RunUntilIdle();
3687 // Blacklisted extensions stay blacklisted.
3688 AssertExtensionBlocksAndUnblocks(false, good0
);
3689 AssertExtensionBlocksAndUnblocks(false, good1
);
3691 service()->BlockAllExtensions();
3693 // Remove an extension from the blacklist while the service is blocked.
3694 test_blacklist
.SetBlacklistState(
3695 good0
, extensions::NOT_BLACKLISTED
, true);
3696 // Add an extension to the blacklist while the service is blocked.
3697 test_blacklist
.SetBlacklistState(
3698 good2
, extensions::BLACKLISTED_MALWARE
, true);
3699 base::RunLoop().RunUntilIdle();
3701 // Go directly to blocked, do not pass go, do not collect $200.
3702 ASSERT_TRUE(IsBlocked(good0
));
3703 // Get on the blacklist - even if you were blocked!
3704 ASSERT_FALSE(IsBlocked(good2
));
3706 #endif // defined(ENABLE_BLACKLIST_TESTS)
3708 // Tests blocking then unblocking enabled component extensions after the service
3709 // has been initialized.
3710 TEST_F(ExtensionServiceTest
, BlockAndUnblockEnabledComponentExtension
) {
3711 InitializeEmptyExtensionServiceWithTestingPrefs();
3713 // Install a component extension.
3714 base::FilePath path
= data_dir()
3715 .AppendASCII("good")
3716 .AppendASCII("Extensions")
3718 .AppendASCII("1.0.0.0");
3719 std::string manifest
;
3720 ASSERT_TRUE(base::ReadFileToString(
3721 path
.Append(extensions::kManifestFilename
), &manifest
));
3722 service()->component_loader()->Add(manifest
, path
);
3725 // Component extension should never block.
3726 AssertExtensionBlocksAndUnblocks(false, good0
);
3729 // Tests blocking then unblocking a theme after the service has been
3731 TEST_F(ExtensionServiceTest
, BlockAndUnblockTheme
) {
3732 InitializeEmptyExtensionService();
3735 base::FilePath path
= data_dir().AppendASCII("theme.crx");
3736 InstallCRX(path
, INSTALL_NEW
);
3738 AssertExtensionBlocksAndUnblocks(true, theme_crx
);
3741 // Tests that blocking extensions before Init() results in loading blocked
3743 TEST_F(ExtensionServiceTest
, WillNotLoadExtensionsWhenBlocked
) {
3744 InitializeGoodInstalledExtensionService();
3746 service()->BlockAllExtensions();
3750 ASSERT_TRUE(IsBlocked(good0
));
3751 ASSERT_TRUE(IsBlocked(good0
));
3752 ASSERT_TRUE(IsBlocked(good0
));
3755 // Tests that IsEnabledExtension won't crash on an uninstalled extension.
3756 TEST_F(ExtensionServiceTest
, IsEnabledExtensionBlockedAndNotInstalled
) {
3757 InitializeEmptyExtensionService();
3759 service()->BlockAllExtensions();
3761 service()->IsExtensionEnabled(theme_crx
);
3764 // Will not install extension blacklisted by policy.
3765 TEST_F(ExtensionServiceTest
, BlacklistedByPolicyWillNotInstall
) {
3766 InitializeEmptyExtensionServiceWithTestingPrefs();
3768 // Blacklist everything.
3770 ManagementPrefUpdater
pref(profile_
->GetTestingPrefService());
3771 pref
.SetBlacklistedByDefault(true);
3774 // Blacklist prevents us from installing good_crx.
3775 base::FilePath path
= data_dir().AppendASCII("good.crx");
3776 InstallCRX(path
, INSTALL_FAILED
);
3777 EXPECT_EQ(0u, registry()->enabled_extensions().size());
3779 // Now whitelist this particular extension.
3781 ManagementPrefUpdater
pref(profile_
->GetTestingPrefService());
3782 pref
.SetIndividualExtensionInstallationAllowed(good_crx
, true);
3785 // Ensure we can now install good_crx.
3786 InstallCRX(path
, INSTALL_NEW
);
3787 EXPECT_EQ(1u, registry()->enabled_extensions().size());
3790 // Extension blacklisted by policy get unloaded after installing.
3791 TEST_F(ExtensionServiceTest
, BlacklistedByPolicyRemovedIfRunning
) {
3792 InitializeEmptyExtensionServiceWithTestingPrefs();
3794 // Install good_crx.
3795 base::FilePath path
= data_dir().AppendASCII("good.crx");
3796 InstallCRX(path
, INSTALL_NEW
);
3797 EXPECT_EQ(1u, registry()->enabled_extensions().size());
3800 ManagementPrefUpdater
pref(profile_
->GetTestingPrefService());
3801 // Blacklist this extension.
3802 pref
.SetIndividualExtensionInstallationAllowed(good_crx
, false);
3805 // Extension should not be running now.
3806 base::RunLoop().RunUntilIdle();
3807 EXPECT_EQ(0u, registry()->enabled_extensions().size());
3810 // Tests that component extensions are not blacklisted by policy.
3811 TEST_F(ExtensionServiceTest
, ComponentExtensionWhitelisted
) {
3812 InitializeEmptyExtensionServiceWithTestingPrefs();
3814 // Blacklist everything.
3816 ManagementPrefUpdater
pref(profile_
->GetTestingPrefService());
3817 pref
.SetBlacklistedByDefault(true);
3820 // Install a component extension.
3821 base::FilePath path
= data_dir()
3822 .AppendASCII("good")
3823 .AppendASCII("Extensions")
3825 .AppendASCII("1.0.0.0");
3826 std::string manifest
;
3827 ASSERT_TRUE(base::ReadFileToString(
3828 path
.Append(extensions::kManifestFilename
), &manifest
));
3829 service()->component_loader()->Add(manifest
, path
);
3832 // Extension should be installed despite blacklist.
3833 ASSERT_EQ(1u, registry()->enabled_extensions().size());
3834 EXPECT_TRUE(service()->GetExtensionById(good0
, false));
3836 // Poke external providers and make sure the extension is still present.
3837 service()->CheckForExternalUpdates();
3838 ASSERT_EQ(1u, registry()->enabled_extensions().size());
3839 EXPECT_TRUE(service()->GetExtensionById(good0
, false));
3841 // Extension should not be uninstalled on blacklist changes.
3843 ManagementPrefUpdater
pref(profile_
->GetTestingPrefService());
3844 pref
.SetIndividualExtensionInstallationAllowed(good0
, false);
3846 base::RunLoop().RunUntilIdle();
3847 ASSERT_EQ(1u, registry()->enabled_extensions().size());
3848 EXPECT_TRUE(service()->GetExtensionById(good0
, false));
3851 // Tests that policy-installed extensions are not blacklisted by policy.
3852 TEST_F(ExtensionServiceTest
, PolicyInstalledExtensionsWhitelisted
) {
3853 InitializeEmptyExtensionServiceWithTestingPrefs();
3856 ManagementPrefUpdater
pref(profile_
->GetTestingPrefService());
3857 // Blacklist everything.
3858 pref
.SetBlacklistedByDefault(true);
3859 // Mark good.crx for force-installation.
3860 pref
.SetIndividualExtensionAutoInstalled(
3861 good_crx
, "http://example.com/update_url", true);
3864 // Have policy force-install an extension.
3865 MockExtensionProvider
* provider
=
3866 new MockExtensionProvider(service(), Manifest::EXTERNAL_POLICY_DOWNLOAD
);
3867 AddMockExternalProvider(provider
);
3868 provider
->UpdateOrAddExtension(
3869 good_crx
, "1.0.0.0", data_dir().AppendASCII("good.crx"));
3871 // Reloading extensions should find our externally registered extension
3873 content::WindowedNotificationObserver
observer(
3874 extensions::NOTIFICATION_CRX_INSTALLER_DONE
,
3875 content::NotificationService::AllSources());
3876 service()->CheckForExternalUpdates();
3879 // Extension should be installed despite blacklist.
3880 ASSERT_EQ(1u, registry()->enabled_extensions().size());
3881 EXPECT_TRUE(service()->GetExtensionById(good_crx
, false));
3883 // Blacklist update should not uninstall the extension.
3885 ManagementPrefUpdater
pref(profile_
->GetTestingPrefService());
3886 pref
.SetIndividualExtensionInstallationAllowed(good0
, false);
3888 base::RunLoop().RunUntilIdle();
3889 ASSERT_EQ(1u, registry()->enabled_extensions().size());
3890 EXPECT_TRUE(service()->GetExtensionById(good_crx
, false));
3893 // Tests that extensions cannot be installed if the policy provider prohibits
3894 // it. This functionality is implemented in CrxInstaller::ConfirmInstall().
3895 TEST_F(ExtensionServiceTest
, ManagementPolicyProhibitsInstall
) {
3896 InitializeEmptyExtensionService();
3898 GetManagementPolicy()->UnregisterAllProviders();
3899 extensions::TestManagementPolicyProvider
provider_(
3900 extensions::TestManagementPolicyProvider::PROHIBIT_LOAD
);
3901 GetManagementPolicy()->RegisterProvider(&provider_
);
3903 InstallCRX(data_dir().AppendASCII("good.crx"), INSTALL_FAILED
);
3904 EXPECT_EQ(0u, registry()->enabled_extensions().size());
3907 // Tests that extensions cannot be loaded from prefs if the policy provider
3908 // prohibits it. This functionality is implemented in InstalledLoader::Load().
3909 TEST_F(ExtensionServiceTest
, ManagementPolicyProhibitsLoadFromPrefs
) {
3910 InitializeEmptyExtensionService();
3912 // Create a fake extension to be loaded as though it were read from prefs.
3913 base::FilePath path
=
3914 data_dir().AppendASCII("management").AppendASCII("simple_extension");
3915 base::DictionaryValue manifest
;
3916 manifest
.SetString(keys::kName
, "simple_extension");
3917 manifest
.SetString(keys::kVersion
, "1");
3918 // UNPACKED is for extensions loaded from a directory. We use it here, even
3919 // though we're testing loading from prefs, so that we don't need to provide
3920 // an extension key.
3921 extensions::ExtensionInfo
extension_info(
3922 &manifest
, std::string(), path
, Manifest::UNPACKED
);
3924 // Ensure we can load it with no management policy in place.
3925 GetManagementPolicy()->UnregisterAllProviders();
3926 EXPECT_EQ(0u, registry()->enabled_extensions().size());
3927 extensions::InstalledLoader(service()).Load(extension_info
, false);
3928 EXPECT_EQ(1u, registry()->enabled_extensions().size());
3930 const Extension
* extension
=
3931 (registry()->enabled_extensions().begin())->get();
3933 service()->UninstallExtension(extension
->id(),
3934 extensions::UNINSTALL_REASON_FOR_TESTING
,
3935 base::Bind(&base::DoNothing
),
3937 EXPECT_EQ(0u, registry()->enabled_extensions().size());
3939 // Ensure we cannot load it if management policy prohibits installation.
3940 extensions::TestManagementPolicyProvider
provider_(
3941 extensions::TestManagementPolicyProvider::PROHIBIT_LOAD
);
3942 GetManagementPolicy()->RegisterProvider(&provider_
);
3944 extensions::InstalledLoader(service()).Load(extension_info
, false);
3945 EXPECT_EQ(0u, registry()->enabled_extensions().size());
3948 // Tests disabling an extension when prohibited by the ManagementPolicy.
3949 TEST_F(ExtensionServiceTest
, ManagementPolicyProhibitsDisable
) {
3950 InitializeEmptyExtensionService();
3952 InstallCRX(data_dir().AppendASCII("good.crx"), INSTALL_NEW
);
3953 EXPECT_EQ(1u, registry()->enabled_extensions().size());
3954 EXPECT_EQ(0u, registry()->disabled_extensions().size());
3956 GetManagementPolicy()->UnregisterAllProviders();
3957 extensions::TestManagementPolicyProvider
provider(
3958 extensions::TestManagementPolicyProvider::PROHIBIT_MODIFY_STATUS
);
3959 GetManagementPolicy()->RegisterProvider(&provider
);
3961 // Attempt to disable it.
3962 service()->DisableExtension(good_crx
, Extension::DISABLE_USER_ACTION
);
3964 EXPECT_EQ(1u, registry()->enabled_extensions().size());
3965 EXPECT_TRUE(service()->GetExtensionById(good_crx
, false));
3966 EXPECT_EQ(0u, registry()->disabled_extensions().size());
3969 // Tests uninstalling an extension when prohibited by the ManagementPolicy.
3970 TEST_F(ExtensionServiceTest
, ManagementPolicyProhibitsUninstall
) {
3971 InitializeEmptyExtensionService();
3973 InstallCRX(data_dir().AppendASCII("good.crx"), INSTALL_NEW
);
3974 EXPECT_EQ(1u, registry()->enabled_extensions().size());
3975 EXPECT_EQ(0u, registry()->disabled_extensions().size());
3977 GetManagementPolicy()->UnregisterAllProviders();
3978 extensions::TestManagementPolicyProvider
provider(
3979 extensions::TestManagementPolicyProvider::PROHIBIT_MODIFY_STATUS
);
3980 GetManagementPolicy()->RegisterProvider(&provider
);
3982 // Attempt to uninstall it.
3984 service()->UninstallExtension(good_crx
,
3985 extensions::UNINSTALL_REASON_FOR_TESTING
,
3986 base::Bind(&base::DoNothing
),
3989 EXPECT_EQ(1u, registry()->enabled_extensions().size());
3990 EXPECT_TRUE(service()->GetExtensionById(good_crx
, false));
3993 // Tests that previously installed extensions that are now prohibited from
3994 // being installed are removed.
3995 TEST_F(ExtensionServiceTest
, ManagementPolicyUnloadsAllProhibited
) {
3996 InitializeEmptyExtensionService();
3998 InstallCRX(data_dir().AppendASCII("good.crx"), INSTALL_NEW
);
3999 InstallCRX(data_dir().AppendASCII("page_action.crx"), INSTALL_NEW
);
4000 EXPECT_EQ(2u, registry()->enabled_extensions().size());
4001 EXPECT_EQ(0u, registry()->disabled_extensions().size());
4003 GetManagementPolicy()->UnregisterAllProviders();
4004 extensions::TestManagementPolicyProvider
provider(
4005 extensions::TestManagementPolicyProvider::PROHIBIT_LOAD
);
4006 GetManagementPolicy()->RegisterProvider(&provider
);
4008 // Run the policy check.
4009 service()->CheckManagementPolicy();
4010 EXPECT_EQ(0u, registry()->enabled_extensions().size());
4011 EXPECT_EQ(0u, registry()->disabled_extensions().size());
4014 // Tests that previously disabled extensions that are now required to be
4015 // enabled are re-enabled on reinstall.
4016 TEST_F(ExtensionServiceTest
, ManagementPolicyRequiresEnable
) {
4017 InitializeEmptyExtensionService();
4019 // Install, then disable, an extension.
4020 InstallCRX(data_dir().AppendASCII("good.crx"), INSTALL_NEW
);
4021 EXPECT_EQ(1u, registry()->enabled_extensions().size());
4022 service()->DisableExtension(good_crx
, Extension::DISABLE_USER_ACTION
);
4023 EXPECT_EQ(1u, registry()->disabled_extensions().size());
4025 // Register an ExtensionManagementPolicy that requires the extension to remain
4027 GetManagementPolicy()->UnregisterAllProviders();
4028 extensions::TestManagementPolicyProvider
provider(
4029 extensions::TestManagementPolicyProvider::MUST_REMAIN_ENABLED
);
4030 GetManagementPolicy()->RegisterProvider(&provider
);
4032 // Reinstall the extension.
4033 InstallCRX(data_dir().AppendASCII("good.crx"), INSTALL_UPDATED
);
4034 EXPECT_EQ(1u, registry()->enabled_extensions().size());
4035 EXPECT_EQ(0u, registry()->disabled_extensions().size());
4038 // Tests that extensions disabled by management policy can be installed but
4039 // will get disabled after installing.
4040 TEST_F(ExtensionServiceTest
, ManagementPolicyProhibitsEnableOnInstalled
) {
4041 InitializeEmptyExtensionService();
4043 // Register an ExtensionManagementPolicy that disables all extensions, with
4044 // a specified Extension::DisableReason.
4045 GetManagementPolicy()->UnregisterAllProviders();
4046 extensions::TestManagementPolicyProvider
provider(
4047 extensions::TestManagementPolicyProvider::MUST_REMAIN_DISABLED
);
4048 provider
.SetDisableReason(Extension::DISABLE_NOT_VERIFIED
);
4049 GetManagementPolicy()->RegisterProvider(&provider
);
4051 // Attempts to install an extensions, it should be installed but disabled.
4052 EXPECT_EQ(0u, registry()->enabled_extensions().size());
4053 EXPECT_EQ(0u, registry()->disabled_extensions().size());
4054 InstallCRX(data_dir().AppendASCII("good.crx"), INSTALL_WITHOUT_LOAD
);
4055 EXPECT_EQ(0u, registry()->enabled_extensions().size());
4056 EXPECT_EQ(1u, registry()->disabled_extensions().size());
4058 // Verifies that the disable reason is set properly.
4059 EXPECT_EQ(Extension::DISABLE_NOT_VERIFIED
,
4060 service()->extension_prefs_
->GetDisableReasons(kGoodId
));
4063 // Tests that extensions with conflicting required permissions by enterprise
4064 // policy cannot be installed.
4065 TEST_F(ExtensionServiceTest
, PolicyBlockedPermissionNewExtensionInstall
) {
4066 InitializeEmptyExtensionServiceWithTestingPrefs();
4067 base::FilePath path
= data_dir().AppendASCII("permissions_blocklist");
4070 // Update policy to block one of the required permissions of target.
4071 ManagementPrefUpdater
pref(profile_
->GetTestingPrefService());
4072 pref
.AddBlockedPermission("*", "tabs");
4075 // The extension should be failed to install.
4076 PackAndInstallCRX(path
, INSTALL_FAILED
);
4079 // Update policy to block one of the optional permissions instead.
4080 ManagementPrefUpdater
pref(profile_
->GetTestingPrefService());
4081 pref
.ClearBlockedPermissions("*");
4082 pref
.AddBlockedPermission("*", "history");
4085 // The extension should succeed to install this time.
4086 std::string id
= PackAndInstallCRX(path
, INSTALL_NEW
)->id();
4088 // Uninstall the extension and update policy to block some arbitrary
4089 // unknown permission.
4090 UninstallExtension(id
, false);
4092 ManagementPrefUpdater
pref(profile_
->GetTestingPrefService());
4093 pref
.ClearBlockedPermissions("*");
4094 pref
.AddBlockedPermission("*", "unknown.permission.for.testing");
4097 // The extension should succeed to install as well.
4098 PackAndInstallCRX(path
, INSTALL_NEW
);
4101 // Tests that extension supposed to be force installed but with conflicting
4102 // required permissions cannot be installed.
4103 TEST_F(ExtensionServiceTest
, PolicyBlockedPermissionConflictsWithForceInstall
) {
4104 InitializeEmptyExtensionServiceWithTestingPrefs();
4106 // Pack the crx file.
4107 base::FilePath path
= data_dir().AppendASCII("permissions_blocklist");
4108 base::FilePath pem_path
= data_dir().AppendASCII("permissions_blocklist.pem");
4109 base::ScopedTempDir temp_dir
;
4110 EXPECT_TRUE(temp_dir
.CreateUniqueTempDir());
4111 base::FilePath crx_path
= temp_dir
.path().AppendASCII("temp.crx");
4113 PackCRX(path
, pem_path
, crx_path
);
4116 // Block one of the required permissions.
4117 ManagementPrefUpdater
pref(profile_
->GetTestingPrefService());
4118 pref
.AddBlockedPermission("*", "tabs");
4121 // Use MockExtensionProvider to simulate force installing extension.
4122 MockExtensionProvider
* provider
=
4123 new MockExtensionProvider(service(), Manifest::EXTERNAL_POLICY_DOWNLOAD
);
4124 AddMockExternalProvider(provider
);
4125 provider
->UpdateOrAddExtension(permissions_blocklist
, "1.0", crx_path
);
4128 // Attempts to force install this extension.
4129 content::WindowedNotificationObserver
observer(
4130 extensions::NOTIFICATION_CRX_INSTALLER_DONE
,
4131 content::NotificationService::AllSources());
4132 service()->CheckForExternalUpdates();
4136 // The extension should not be installed.
4137 ASSERT_FALSE(service()->GetInstalledExtension(permissions_blocklist
));
4139 // Remove this extension from pending extension manager as we would like to
4140 // give another attempt later.
4141 service()->pending_extension_manager()->Remove(permissions_blocklist
);
4144 // Clears the permission block list.
4145 ManagementPrefUpdater
pref(profile_
->GetTestingPrefService());
4146 pref
.ClearBlockedPermissions("*");
4150 // Attempts to force install this extension again.
4151 content::WindowedNotificationObserver
observer(
4152 extensions::NOTIFICATION_CRX_INSTALLER_DONE
,
4153 content::NotificationService::AllSources());
4154 service()->CheckForExternalUpdates();
4158 const Extension
* installed
=
4159 service()->GetInstalledExtension(permissions_blocklist
);
4160 ASSERT_TRUE(installed
);
4161 EXPECT_EQ(installed
->location(), Manifest::EXTERNAL_POLICY_DOWNLOAD
);
4164 // Tests that newer versions of an extension with conflicting required
4165 // permissions by enterprise policy cannot be updated to.
4166 TEST_F(ExtensionServiceTest
, PolicyBlockedPermissionExtensionUpdate
) {
4167 InitializeEmptyExtensionServiceWithTestingPrefs();
4169 base::FilePath path
= data_dir().AppendASCII("permissions_blocklist");
4170 base::FilePath path2
= data_dir().AppendASCII("permissions_blocklist2");
4171 base::FilePath pem_path
= data_dir().AppendASCII("permissions_blocklist.pem");
4173 // Install 'permissions_blocklist'.
4174 const Extension
* installed
= PackAndInstallCRX(path
, pem_path
, INSTALL_NEW
);
4175 EXPECT_EQ(installed
->id(), permissions_blocklist
);
4178 // Block one of the required permissions of 'permissions_blocklist2'.
4179 ManagementPrefUpdater
pref(profile_
->GetTestingPrefService());
4180 pref
.AddBlockedPermission("*", "downloads");
4183 // Install 'permissions_blocklist' again, should be updated.
4184 const Extension
* updated
= PackAndInstallCRX(path
, pem_path
, INSTALL_UPDATED
);
4185 EXPECT_EQ(updated
->id(), permissions_blocklist
);
4187 std::string old_version
= updated
->VersionString();
4189 // Attempts to update to 'permissions_blocklist2' should fail.
4190 PackAndInstallCRX(path2
, pem_path
, INSTALL_FAILED
);
4192 // Verify that the old version is still enabled.
4193 updated
= service()->GetExtensionById(permissions_blocklist
, false);
4194 ASSERT_TRUE(updated
);
4195 EXPECT_EQ(old_version
, updated
->VersionString());
4198 // Tests that policy update with additional permissions blocked revoke
4199 // conflicting granted optional permissions and unload extensions with
4200 // conflicting required permissions, including the force installed ones.
4201 TEST_F(ExtensionServiceTest
, PolicyBlockedPermissionPolicyUpdate
) {
4202 InitializeEmptyExtensionServiceWithTestingPrefs();
4204 base::FilePath path
= data_dir().AppendASCII("permissions_blocklist");
4205 base::FilePath path2
= data_dir().AppendASCII("permissions_blocklist2");
4206 base::FilePath pem_path
= data_dir().AppendASCII("permissions_blocklist.pem");
4208 // Pack the crx file.
4209 base::ScopedTempDir temp_dir
;
4210 EXPECT_TRUE(temp_dir
.CreateUniqueTempDir());
4211 base::FilePath crx_path
= temp_dir
.path().AppendASCII("temp.crx");
4213 PackCRX(path2
, pem_path
, crx_path
);
4215 // Install two arbitary extensions with specified manifest.
4216 std::string ext1
= PackAndInstallCRX(path
, INSTALL_NEW
)->id();
4217 std::string ext2
= PackAndInstallCRX(path2
, INSTALL_NEW
)->id();
4218 ASSERT_NE(ext1
, permissions_blocklist
);
4219 ASSERT_NE(ext2
, permissions_blocklist
);
4220 ASSERT_NE(ext1
, ext2
);
4222 // Force install another extension with known id and same manifest as 'ext2'.
4223 std::string ext2_forced
= permissions_blocklist
;
4224 MockExtensionProvider
* provider
=
4225 new MockExtensionProvider(service(), Manifest::EXTERNAL_POLICY_DOWNLOAD
);
4226 AddMockExternalProvider(provider
);
4227 provider
->UpdateOrAddExtension(ext2_forced
, "2.0", crx_path
);
4229 content::WindowedNotificationObserver
observer(
4230 extensions::NOTIFICATION_CRX_INSTALLER_DONE
,
4231 content::NotificationService::AllSources());
4232 service()->CheckForExternalUpdates();
4235 extensions::ExtensionRegistry
* registry
=
4236 extensions::ExtensionRegistry::Get(profile());
4238 // Verify all three extensions are installed and enabled.
4239 ASSERT_TRUE(registry
->enabled_extensions().GetByID(ext1
));
4240 ASSERT_TRUE(registry
->enabled_extensions().GetByID(ext2
));
4241 ASSERT_TRUE(registry
->enabled_extensions().GetByID(ext2_forced
));
4243 // Grant all optional permissions to each extension.
4244 GrantAllOptionalPermissions(ext1
);
4245 GrantAllOptionalPermissions(ext2
);
4246 GrantAllOptionalPermissions(ext2_forced
);
4248 scoped_refptr
<const PermissionSet
> active_permissions(
4249 ExtensionPrefs::Get(profile())->GetActivePermissions(ext1
));
4250 EXPECT_TRUE(active_permissions
->HasAPIPermission(
4251 extensions::APIPermission::kDownloads
));
4253 // Set policy to block 'downloads' permission.
4255 ManagementPrefUpdater
pref(profile_
->GetTestingPrefService());
4256 pref
.AddBlockedPermission("*", "downloads");
4259 base::RunLoop().RunUntilIdle();
4261 // 'ext1' should still be enabled, but with 'downloads' permission revoked.
4262 EXPECT_TRUE(registry
->enabled_extensions().GetByID(ext1
));
4263 active_permissions
=
4264 ExtensionPrefs::Get(profile())->GetActivePermissions(ext1
);
4265 EXPECT_FALSE(active_permissions
->HasAPIPermission(
4266 extensions::APIPermission::kDownloads
));
4268 // 'ext2' should be disabled because one of its required permissions is
4270 EXPECT_FALSE(registry
->enabled_extensions().GetByID(ext2
));
4272 // 'ext2_forced' should be handled the same as 'ext2'
4273 EXPECT_FALSE(registry
->enabled_extensions().GetByID(ext2_forced
));
4276 // Flaky on windows; http://crbug.com/309833
4278 #define MAYBE_ExternalExtensionAutoAcknowledgement DISABLED_ExternalExtensionAutoAcknowledgement
4280 #define MAYBE_ExternalExtensionAutoAcknowledgement ExternalExtensionAutoAcknowledgement
4282 TEST_F(ExtensionServiceTest
, MAYBE_ExternalExtensionAutoAcknowledgement
) {
4283 InitializeEmptyExtensionService();
4284 service()->set_extensions_enabled(true);
4287 // Register and install an external extension.
4288 MockExtensionProvider
* provider
=
4289 new MockExtensionProvider(service(), Manifest::EXTERNAL_PREF
);
4290 AddMockExternalProvider(provider
);
4291 provider
->UpdateOrAddExtension(
4292 good_crx
, "1.0.0.0", data_dir().AppendASCII("good.crx"));
4295 // Have policy force-install an extension.
4296 MockExtensionProvider
* provider
= new MockExtensionProvider(
4297 service(), Manifest::EXTERNAL_POLICY_DOWNLOAD
);
4298 AddMockExternalProvider(provider
);
4299 provider
->UpdateOrAddExtension(
4300 page_action
, "1.0.0.0", data_dir().AppendASCII("page_action.crx"));
4303 // Providers are set up. Let them run.
4305 content::WindowedNotificationObserver
observer(
4306 extensions::NOTIFICATION_CRX_INSTALLER_DONE
,
4307 base::Bind(&WaitForCountNotificationsCallback
, &count
));
4308 service()->CheckForExternalUpdates();
4312 ASSERT_EQ(2u, registry()->enabled_extensions().size());
4313 EXPECT_TRUE(service()->GetExtensionById(good_crx
, false));
4314 EXPECT_TRUE(service()->GetExtensionById(page_action
, false));
4315 ExtensionPrefs
* prefs
= ExtensionPrefs::Get(profile());
4316 ASSERT_TRUE(!prefs
->IsExternalExtensionAcknowledged(good_crx
));
4317 ASSERT_TRUE(prefs
->IsExternalExtensionAcknowledged(page_action
));
4320 #if !defined(OS_CHROMEOS)
4321 // This tests if default apps are installed correctly.
4322 TEST_F(ExtensionServiceTest
, DefaultAppsInstall
) {
4323 InitializeEmptyExtensionService();
4324 service()->set_extensions_enabled(true);
4327 std::string json_data
=
4329 " \"ldnnhddmnhbkjipkidpdiheffobcpfmf\" : {"
4330 " \"external_crx\": \"good.crx\","
4331 " \"external_version\": \"1.0.0.0\","
4332 " \"is_bookmark_app\": false"
4335 default_apps::Provider
* provider
= new default_apps::Provider(
4338 new extensions::ExternalTestingLoader(json_data
, data_dir()),
4340 Manifest::INVALID_LOCATION
,
4341 Extension::FROM_WEBSTORE
| Extension::WAS_INSTALLED_BY_DEFAULT
);
4343 AddMockExternalProvider(provider
);
4346 ASSERT_EQ(0u, registry()->enabled_extensions().size());
4347 content::WindowedNotificationObserver
observer(
4348 extensions::NOTIFICATION_CRX_INSTALLER_DONE
,
4349 content::NotificationService::AllSources());
4350 service()->CheckForExternalUpdates();
4353 ASSERT_EQ(1u, registry()->enabled_extensions().size());
4354 EXPECT_TRUE(service()->GetExtensionById(good_crx
, false));
4355 const Extension
* extension
= service()->GetExtensionById(good_crx
, false);
4356 EXPECT_TRUE(extension
->from_webstore());
4357 EXPECT_TRUE(extension
->was_installed_by_default());
4361 // Tests disabling extensions
4362 TEST_F(ExtensionServiceTest
, DisableExtension
) {
4363 InitializeEmptyExtensionService();
4365 InstallCRX(data_dir().AppendASCII("good.crx"), INSTALL_NEW
);
4366 EXPECT_TRUE(service()->GetExtensionById(good_crx
, true));
4367 EXPECT_TRUE(service()->GetExtensionById(good_crx
, false));
4369 EXPECT_EQ(1u, registry()->enabled_extensions().size());
4370 EXPECT_EQ(0u, registry()->disabled_extensions().size());
4371 EXPECT_EQ(0u, registry()->terminated_extensions().size());
4372 EXPECT_EQ(0u, registry()->blacklisted_extensions().size());
4375 service()->DisableExtension(good_crx
, Extension::DISABLE_USER_ACTION
);
4377 EXPECT_TRUE(service()->GetExtensionById(good_crx
, true));
4378 EXPECT_FALSE(service()->GetExtensionById(good_crx
, false));
4379 EXPECT_EQ(0u, registry()->enabled_extensions().size());
4380 EXPECT_EQ(1u, registry()->disabled_extensions().size());
4381 EXPECT_EQ(0u, registry()->terminated_extensions().size());
4382 EXPECT_EQ(0u, registry()->blacklisted_extensions().size());
4385 TEST_F(ExtensionServiceTest
, TerminateExtension
) {
4386 InitializeEmptyExtensionService();
4388 InstallCRX(data_dir().AppendASCII("good.crx"), INSTALL_NEW
);
4389 EXPECT_EQ(1u, registry()->enabled_extensions().size());
4390 EXPECT_EQ(0u, registry()->disabled_extensions().size());
4391 EXPECT_EQ(0u, registry()->terminated_extensions().size());
4392 EXPECT_EQ(0u, registry()->blacklisted_extensions().size());
4394 TerminateExtension(good_crx
);
4396 EXPECT_EQ(0u, registry()->enabled_extensions().size());
4397 EXPECT_EQ(0u, registry()->disabled_extensions().size());
4398 EXPECT_EQ(1u, registry()->terminated_extensions().size());
4399 EXPECT_EQ(0u, registry()->blacklisted_extensions().size());
4402 TEST_F(ExtensionServiceTest
, DisableTerminatedExtension
) {
4403 InitializeEmptyExtensionService();
4405 InstallCRX(data_dir().AppendASCII("good.crx"), INSTALL_NEW
);
4406 TerminateExtension(good_crx
);
4407 EXPECT_TRUE(registry()->GetExtensionById(
4408 good_crx
, extensions::ExtensionRegistry::TERMINATED
));
4411 service()->DisableExtension(good_crx
, Extension::DISABLE_USER_ACTION
);
4413 EXPECT_FALSE(registry()->GetExtensionById(
4414 good_crx
, extensions::ExtensionRegistry::TERMINATED
));
4415 EXPECT_TRUE(service()->GetExtensionById(good_crx
, true));
4417 EXPECT_EQ(0u, registry()->enabled_extensions().size());
4418 EXPECT_EQ(1u, registry()->disabled_extensions().size());
4419 EXPECT_EQ(0u, registry()->terminated_extensions().size());
4420 EXPECT_EQ(0u, registry()->blacklisted_extensions().size());
4423 // Tests disabling all extensions (simulating --disable-extensions flag).
4424 TEST_F(ExtensionServiceTest
, DisableAllExtensions
) {
4425 InitializeEmptyExtensionService();
4427 base::FilePath path
= data_dir().AppendASCII("good.crx");
4428 InstallCRX(path
, INSTALL_NEW
);
4430 EXPECT_EQ(1u, registry()->enabled_extensions().size());
4431 EXPECT_EQ(0u, registry()->disabled_extensions().size());
4433 // Disable extensions.
4434 service()->set_extensions_enabled(false);
4435 service()->ReloadExtensionsForTest();
4437 // There shouldn't be extensions in either list.
4438 EXPECT_EQ(0u, registry()->enabled_extensions().size());
4439 EXPECT_EQ(0u, registry()->disabled_extensions().size());
4441 // This shouldn't do anything when all extensions are disabled.
4442 service()->EnableExtension(good_crx
);
4443 service()->ReloadExtensionsForTest();
4445 // There still shouldn't be extensions in either list.
4446 EXPECT_EQ(0u, registry()->enabled_extensions().size());
4447 EXPECT_EQ(0u, registry()->disabled_extensions().size());
4449 // And then re-enable the extensions.
4450 service()->set_extensions_enabled(true);
4451 service()->ReloadExtensionsForTest();
4453 EXPECT_EQ(1u, registry()->enabled_extensions().size());
4454 EXPECT_EQ(0u, registry()->disabled_extensions().size());
4457 // Tests reloading extensions.
4458 TEST_F(ExtensionServiceTest
, ReloadExtensions
) {
4459 InitializeEmptyExtensionService();
4461 // Simple extension that should install without error.
4462 base::FilePath path
= data_dir().AppendASCII("good.crx");
4463 InstallCRX(path
, INSTALL_NEW
,
4464 Extension::FROM_WEBSTORE
| Extension::WAS_INSTALLED_BY_DEFAULT
);
4465 const char* const extension_id
= good_crx
;
4466 service()->DisableExtension(extension_id
, Extension::DISABLE_USER_ACTION
);
4468 EXPECT_EQ(0u, registry()->enabled_extensions().size());
4469 EXPECT_EQ(1u, registry()->disabled_extensions().size());
4471 service()->ReloadExtensionsForTest();
4473 // The creation flags should not change when reloading the extension.
4474 const Extension
* extension
= service()->GetExtensionById(good_crx
, true);
4475 EXPECT_TRUE(extension
->from_webstore());
4476 EXPECT_TRUE(extension
->was_installed_by_default());
4477 EXPECT_FALSE(extension
->from_bookmark());
4479 // Extension counts shouldn't change.
4480 EXPECT_EQ(0u, registry()->enabled_extensions().size());
4481 EXPECT_EQ(1u, registry()->disabled_extensions().size());
4483 service()->EnableExtension(extension_id
);
4485 EXPECT_EQ(1u, registry()->enabled_extensions().size());
4486 EXPECT_EQ(0u, registry()->disabled_extensions().size());
4488 // Need to clear |loaded_| manually before reloading as the
4489 // EnableExtension() call above inserted into it and
4490 // UnloadAllExtensions() doesn't send out notifications.
4492 service()->ReloadExtensionsForTest();
4494 // Extension counts shouldn't change.
4495 EXPECT_EQ(1u, registry()->enabled_extensions().size());
4496 EXPECT_EQ(0u, registry()->disabled_extensions().size());
4499 // Tests reloading an extension.
4500 TEST_F(ExtensionServiceTest
, ReloadExtension
) {
4501 InitializeEmptyExtensionService();
4503 // Simple extension that should install without error.
4504 const char extension_id
[] = "behllobkkfkfnphdnhnkndlbkcpglgmj";
4505 base::FilePath ext
= data_dir()
4506 .AppendASCII("good")
4507 .AppendASCII("Extensions")
4508 .AppendASCII(extension_id
)
4509 .AppendASCII("1.0.0.0");
4510 extensions::UnpackedInstaller::Create(service())->Load(ext
);
4511 base::RunLoop().RunUntilIdle();
4513 EXPECT_EQ(1u, registry()->enabled_extensions().size());
4514 EXPECT_EQ(0u, registry()->disabled_extensions().size());
4516 service()->ReloadExtension(extension_id
);
4518 // Extension should be disabled now, waiting to be reloaded.
4519 EXPECT_EQ(0u, registry()->enabled_extensions().size());
4520 EXPECT_EQ(1u, registry()->disabled_extensions().size());
4521 EXPECT_EQ(Extension::DISABLE_RELOAD
,
4522 ExtensionPrefs::Get(profile())->GetDisableReasons(extension_id
));
4524 // Reloading again should not crash.
4525 service()->ReloadExtension(extension_id
);
4528 base::RunLoop().RunUntilIdle();
4530 // Extension should be enabled again.
4531 EXPECT_EQ(1u, registry()->enabled_extensions().size());
4532 EXPECT_EQ(0u, registry()->disabled_extensions().size());
4535 TEST_F(ExtensionServiceTest
, UninstallExtension
) {
4536 InitializeEmptyExtensionService();
4537 InstallCRX(data_dir().AppendASCII("good.crx"), INSTALL_NEW
);
4538 EXPECT_EQ(1u, registry()->enabled_extensions().size());
4539 UninstallExtension(good_crx
, false);
4540 EXPECT_EQ(0u, registry()->enabled_extensions().size());
4541 EXPECT_EQ(UnloadedExtensionInfo::REASON_UNINSTALL
, unloaded_reason_
);
4544 TEST_F(ExtensionServiceTest
, UninstallTerminatedExtension
) {
4545 InitializeEmptyExtensionService();
4546 InstallCRX(data_dir().AppendASCII("good.crx"), INSTALL_NEW
);
4547 TerminateExtension(good_crx
);
4548 UninstallExtension(good_crx
, false);
4549 EXPECT_EQ(UnloadedExtensionInfo::REASON_TERMINATE
, unloaded_reason_
);
4552 // Tests the uninstaller helper.
4553 TEST_F(ExtensionServiceTest
, UninstallExtensionHelper
) {
4554 InitializeEmptyExtensionService();
4555 InstallCRX(data_dir().AppendASCII("good.crx"), INSTALL_NEW
);
4556 UninstallExtension(good_crx
, true);
4557 EXPECT_EQ(UnloadedExtensionInfo::REASON_UNINSTALL
, unloaded_reason_
);
4560 TEST_F(ExtensionServiceTest
, UninstallExtensionHelperTerminated
) {
4561 InitializeEmptyExtensionService();
4562 InstallCRX(data_dir().AppendASCII("good.crx"), INSTALL_NEW
);
4563 TerminateExtension(good_crx
);
4564 UninstallExtension(good_crx
, true);
4565 EXPECT_EQ(UnloadedExtensionInfo::REASON_TERMINATE
, unloaded_reason_
);
4568 // An extension disabled because of unsupported requirements should re-enabled
4569 // if updated to a version with supported requirements as long as there are no
4570 // other disable reasons.
4571 TEST_F(ExtensionServiceTest
, UpgradingRequirementsEnabled
) {
4572 InitializeEmptyExtensionService();
4575 base::FilePath path
= data_dir().AppendASCII("requirements");
4576 base::FilePath pem_path
=
4577 data_dir().AppendASCII("requirements").AppendASCII("v1_good.pem");
4578 const Extension
* extension_v1
= PackAndInstallCRX(path
.AppendASCII("v1_good"),
4581 std::string id
= extension_v1
->id();
4582 EXPECT_TRUE(service()->IsExtensionEnabled(id
));
4584 base::FilePath v2_bad_requirements_crx
= GetTemporaryFile();
4586 PackCRX(path
.AppendASCII("v2_bad_requirements"),
4588 v2_bad_requirements_crx
);
4589 UpdateExtension(id
, v2_bad_requirements_crx
, INSTALLED
);
4590 EXPECT_FALSE(service()->IsExtensionEnabled(id
));
4592 base::FilePath v3_good_crx
= GetTemporaryFile();
4594 PackCRX(path
.AppendASCII("v3_good"), pem_path
, v3_good_crx
);
4595 UpdateExtension(id
, v3_good_crx
, ENABLED
);
4596 EXPECT_TRUE(service()->IsExtensionEnabled(id
));
4599 // Extensions disabled through user action should stay disabled.
4600 TEST_F(ExtensionServiceTest
, UpgradingRequirementsDisabled
) {
4601 InitializeEmptyExtensionService();
4604 base::FilePath path
= data_dir().AppendASCII("requirements");
4605 base::FilePath pem_path
=
4606 data_dir().AppendASCII("requirements").AppendASCII("v1_good.pem");
4607 const Extension
* extension_v1
= PackAndInstallCRX(path
.AppendASCII("v1_good"),
4610 std::string id
= extension_v1
->id();
4611 service()->DisableExtension(id
, Extension::DISABLE_USER_ACTION
);
4612 EXPECT_FALSE(service()->IsExtensionEnabled(id
));
4614 base::FilePath v2_bad_requirements_crx
= GetTemporaryFile();
4616 PackCRX(path
.AppendASCII("v2_bad_requirements"),
4618 v2_bad_requirements_crx
);
4619 UpdateExtension(id
, v2_bad_requirements_crx
, INSTALLED
);
4620 EXPECT_FALSE(service()->IsExtensionEnabled(id
));
4622 base::FilePath v3_good_crx
= GetTemporaryFile();
4624 PackCRX(path
.AppendASCII("v3_good"), pem_path
, v3_good_crx
);
4625 UpdateExtension(id
, v3_good_crx
, INSTALLED
);
4626 EXPECT_FALSE(service()->IsExtensionEnabled(id
));
4629 // The extension should not re-enabled because it was disabled from a
4630 // permission increase.
4631 TEST_F(ExtensionServiceTest
, UpgradingRequirementsPermissions
) {
4632 InitializeEmptyExtensionService();
4635 base::FilePath path
= data_dir().AppendASCII("requirements");
4636 base::FilePath pem_path
=
4637 data_dir().AppendASCII("requirements").AppendASCII("v1_good.pem");
4638 const Extension
* extension_v1
= PackAndInstallCRX(path
.AppendASCII("v1_good"),
4641 std::string id
= extension_v1
->id();
4642 EXPECT_TRUE(service()->IsExtensionEnabled(id
));
4644 base::FilePath v2_bad_requirements_and_permissions_crx
= GetTemporaryFile();
4646 PackCRX(path
.AppendASCII("v2_bad_requirements_and_permissions"),
4648 v2_bad_requirements_and_permissions_crx
);
4649 UpdateExtension(id
, v2_bad_requirements_and_permissions_crx
, INSTALLED
);
4650 EXPECT_FALSE(service()->IsExtensionEnabled(id
));
4652 base::FilePath v3_bad_permissions_crx
= GetTemporaryFile();
4654 PackCRX(path
.AppendASCII("v3_bad_permissions"),
4656 v3_bad_permissions_crx
);
4657 UpdateExtension(id
, v3_bad_permissions_crx
, INSTALLED
);
4658 EXPECT_FALSE(service()->IsExtensionEnabled(id
));
4661 // Unpacked extensions are not allowed to be installed if they have unsupported
4663 TEST_F(ExtensionServiceTest
, UnpackedRequirements
) {
4664 InitializeEmptyExtensionService();
4667 base::FilePath path
=
4668 data_dir().AppendASCII("requirements").AppendASCII("v2_bad_requirements");
4669 extensions::UnpackedInstaller::Create(service())->Load(path
);
4670 base::RunLoop().RunUntilIdle();
4671 EXPECT_EQ(1u, GetErrors().size());
4672 EXPECT_EQ(0u, registry()->enabled_extensions().size());
4675 class ExtensionCookieCallback
{
4677 ExtensionCookieCallback()
4679 weak_factory_(base::MessageLoop::current()) {}
4681 void SetCookieCallback(bool result
) {
4682 base::ThreadTaskRunnerHandle::Get()->PostTask(
4684 base::Bind(&base::MessageLoop::Quit
, weak_factory_
.GetWeakPtr()));
4688 void GetAllCookiesCallback(const net::CookieList
& list
) {
4689 base::ThreadTaskRunnerHandle::Get()->PostTask(
4691 base::Bind(&base::MessageLoop::Quit
, weak_factory_
.GetWeakPtr()));
4694 net::CookieList list_
;
4696 base::WeakPtrFactory
<base::MessageLoop
> weak_factory_
;
4699 // Verifies extension state is removed upon uninstall.
4700 TEST_F(ExtensionServiceTest
, ClearExtensionData
) {
4701 InitializeEmptyExtensionService();
4702 ExtensionCookieCallback callback
;
4704 // Load a test extension.
4705 base::FilePath path
= data_dir();
4706 path
= path
.AppendASCII("good.crx");
4707 const Extension
* extension
= InstallCRX(path
, INSTALL_NEW
);
4708 ASSERT_TRUE(extension
);
4709 GURL
ext_url(extension
->url());
4710 std::string origin_id
= storage::GetIdentifierFromOrigin(ext_url
);
4712 // Set a cookie for the extension.
4713 net::CookieMonster
* cookie_monster
= profile()
4714 ->GetRequestContextForExtensions()
4715 ->GetURLRequestContext()
4717 ->GetCookieMonster();
4718 ASSERT_TRUE(cookie_monster
);
4719 net::CookieOptions options
;
4720 cookie_monster
->SetCookieWithOptionsAsync(
4721 ext_url
, "dummy=value", options
,
4722 base::Bind(&ExtensionCookieCallback::SetCookieCallback
,
4723 base::Unretained(&callback
)));
4724 base::RunLoop().RunUntilIdle();
4725 EXPECT_TRUE(callback
.result_
);
4727 cookie_monster
->GetAllCookiesForURLAsync(
4729 base::Bind(&ExtensionCookieCallback::GetAllCookiesCallback
,
4730 base::Unretained(&callback
)));
4731 base::RunLoop().RunUntilIdle();
4732 EXPECT_EQ(1U, callback
.list_
.size());
4735 storage::DatabaseTracker
* db_tracker
=
4736 BrowserContext::GetDefaultStoragePartition(profile())
4737 ->GetDatabaseTracker();
4738 base::string16 db_name
= base::UTF8ToUTF16("db");
4739 base::string16 description
= base::UTF8ToUTF16("db_description");
4741 db_tracker
->DatabaseOpened(origin_id
, db_name
, description
, 1, &size
);
4742 db_tracker
->DatabaseClosed(origin_id
, db_name
);
4743 std::vector
<storage::OriginInfo
> origins
;
4744 db_tracker
->GetAllOriginsInfo(&origins
);
4745 EXPECT_EQ(1U, origins
.size());
4746 EXPECT_EQ(origin_id
, origins
[0].GetOriginIdentifier());
4748 // Create local storage. We only simulate this by creating the backing files.
4749 // Note: This test depends on details of how the dom_storage library
4750 // stores data in the host file system.
4751 base::FilePath lso_dir_path
=
4752 profile()->GetPath().AppendASCII("Local Storage");
4753 base::FilePath lso_file_path
= lso_dir_path
.AppendASCII(origin_id
)
4754 .AddExtension(FILE_PATH_LITERAL(".localstorage"));
4755 EXPECT_TRUE(base::CreateDirectory(lso_dir_path
));
4756 EXPECT_EQ(0, base::WriteFile(lso_file_path
, NULL
, 0));
4757 EXPECT_TRUE(base::PathExists(lso_file_path
));
4759 // Create indexed db. Similarly, it is enough to only simulate this by
4760 // creating the directory on the disk.
4761 IndexedDBContext
* idb_context
= BrowserContext::GetDefaultStoragePartition(
4762 profile())->GetIndexedDBContext();
4763 idb_context
->SetTaskRunnerForTesting(
4764 base::MessageLoop::current()->task_runner().get());
4765 base::FilePath idb_path
= idb_context
->GetFilePathForTesting(origin_id
);
4766 EXPECT_TRUE(base::CreateDirectory(idb_path
));
4767 EXPECT_TRUE(base::DirectoryExists(idb_path
));
4769 // Uninstall the extension.
4770 base::RunLoop run_loop
;
4772 service()->UninstallExtension(good_crx
,
4773 extensions::UNINSTALL_REASON_FOR_TESTING
,
4774 run_loop
.QuitClosure(),
4776 // The data deletion happens on the IO thread.
4779 // Check that the cookie is gone.
4780 cookie_monster
->GetAllCookiesForURLAsync(
4782 base::Bind(&ExtensionCookieCallback::GetAllCookiesCallback
,
4783 base::Unretained(&callback
)));
4784 base::RunLoop().RunUntilIdle();
4785 EXPECT_EQ(0U, callback
.list_
.size());
4787 // The database should have vanished as well.
4789 db_tracker
->GetAllOriginsInfo(&origins
);
4790 EXPECT_EQ(0U, origins
.size());
4792 // Check that the LSO file has been removed.
4793 EXPECT_FALSE(base::PathExists(lso_file_path
));
4795 // Check if the indexed db has disappeared too.
4796 EXPECT_FALSE(base::DirectoryExists(idb_path
));
4799 // Verifies app state is removed upon uninstall.
4800 TEST_F(ExtensionServiceTest
, ClearAppData
) {
4801 InitializeEmptyExtensionService();
4802 ExtensionCookieCallback callback
;
4806 // Install app1 with unlimited storage.
4807 const Extension
* extension
=
4808 PackAndInstallCRX(data_dir().AppendASCII("app1"), INSTALL_NEW
);
4809 ValidatePrefKeyCount(++pref_count
);
4810 ASSERT_EQ(1u, registry()->enabled_extensions().size());
4811 const std::string id1
= extension
->id();
4812 EXPECT_TRUE(extension
->permissions_data()->HasAPIPermission(
4813 APIPermission::kUnlimitedStorage
));
4815 extensions::AppLaunchInfo::GetFullLaunchURL(extension
).GetOrigin());
4816 EXPECT_TRUE(profile()->GetExtensionSpecialStoragePolicy()->IsStorageUnlimited(
4818 std::string origin_id
= storage::GetIdentifierFromOrigin(origin1
);
4820 // Install app2 from the same origin with unlimited storage.
4821 extension
= PackAndInstallCRX(data_dir().AppendASCII("app2"), INSTALL_NEW
);
4822 ValidatePrefKeyCount(++pref_count
);
4823 ASSERT_EQ(2u, registry()->enabled_extensions().size());
4824 const std::string id2
= extension
->id();
4825 EXPECT_TRUE(extension
->permissions_data()->HasAPIPermission(
4826 APIPermission::kUnlimitedStorage
));
4827 EXPECT_TRUE(extension
->web_extent().MatchesURL(
4828 extensions::AppLaunchInfo::GetFullLaunchURL(extension
)));
4830 extensions::AppLaunchInfo::GetFullLaunchURL(extension
).GetOrigin());
4831 EXPECT_EQ(origin1
, origin2
);
4832 EXPECT_TRUE(profile()->GetExtensionSpecialStoragePolicy()->IsStorageUnlimited(
4835 // Set a cookie for the extension.
4836 net::CookieMonster
* cookie_monster
= profile()
4837 ->GetRequestContext()
4838 ->GetURLRequestContext()
4840 ->GetCookieMonster();
4841 ASSERT_TRUE(cookie_monster
);
4842 net::CookieOptions options
;
4843 cookie_monster
->SetCookieWithOptionsAsync(
4844 origin1
, "dummy=value", options
,
4845 base::Bind(&ExtensionCookieCallback::SetCookieCallback
,
4846 base::Unretained(&callback
)));
4847 base::RunLoop().RunUntilIdle();
4848 EXPECT_TRUE(callback
.result_
);
4850 cookie_monster
->GetAllCookiesForURLAsync(
4852 base::Bind(&ExtensionCookieCallback::GetAllCookiesCallback
,
4853 base::Unretained(&callback
)));
4854 base::RunLoop().RunUntilIdle();
4855 EXPECT_EQ(1U, callback
.list_
.size());
4858 storage::DatabaseTracker
* db_tracker
=
4859 BrowserContext::GetDefaultStoragePartition(profile())
4860 ->GetDatabaseTracker();
4861 base::string16 db_name
= base::UTF8ToUTF16("db");
4862 base::string16 description
= base::UTF8ToUTF16("db_description");
4864 db_tracker
->DatabaseOpened(origin_id
, db_name
, description
, 1, &size
);
4865 db_tracker
->DatabaseClosed(origin_id
, db_name
);
4866 std::vector
<storage::OriginInfo
> origins
;
4867 db_tracker
->GetAllOriginsInfo(&origins
);
4868 EXPECT_EQ(1U, origins
.size());
4869 EXPECT_EQ(origin_id
, origins
[0].GetOriginIdentifier());
4871 // Create local storage. We only simulate this by creating the backing files.
4872 // Note: This test depends on details of how the dom_storage library
4873 // stores data in the host file system.
4874 base::FilePath lso_dir_path
=
4875 profile()->GetPath().AppendASCII("Local Storage");
4876 base::FilePath lso_file_path
= lso_dir_path
.AppendASCII(origin_id
)
4877 .AddExtension(FILE_PATH_LITERAL(".localstorage"));
4878 EXPECT_TRUE(base::CreateDirectory(lso_dir_path
));
4879 EXPECT_EQ(0, base::WriteFile(lso_file_path
, NULL
, 0));
4880 EXPECT_TRUE(base::PathExists(lso_file_path
));
4882 // Create indexed db. Similarly, it is enough to only simulate this by
4883 // creating the directory on the disk.
4884 IndexedDBContext
* idb_context
= BrowserContext::GetDefaultStoragePartition(
4885 profile())->GetIndexedDBContext();
4886 idb_context
->SetTaskRunnerForTesting(
4887 base::MessageLoop::current()->task_runner().get());
4888 base::FilePath idb_path
= idb_context
->GetFilePathForTesting(origin_id
);
4889 EXPECT_TRUE(base::CreateDirectory(idb_path
));
4890 EXPECT_TRUE(base::DirectoryExists(idb_path
));
4892 // Uninstall one of them, unlimited storage should still be granted
4894 UninstallExtension(id1
, false);
4895 EXPECT_EQ(1u, registry()->enabled_extensions().size());
4896 EXPECT_TRUE(profile()->GetExtensionSpecialStoragePolicy()->IsStorageUnlimited(
4899 // Check that the cookie is still there.
4900 cookie_monster
->GetAllCookiesForURLAsync(
4902 base::Bind(&ExtensionCookieCallback::GetAllCookiesCallback
,
4903 base::Unretained(&callback
)));
4904 base::RunLoop().RunUntilIdle();
4905 EXPECT_EQ(1U, callback
.list_
.size());
4907 // Now uninstall the other. Storage should be cleared for the apps.
4908 UninstallExtension(id2
, false);
4909 EXPECT_EQ(0u, registry()->enabled_extensions().size());
4911 profile()->GetExtensionSpecialStoragePolicy()->IsStorageUnlimited(
4914 // Check that the cookie is gone.
4915 cookie_monster
->GetAllCookiesForURLAsync(
4917 base::Bind(&ExtensionCookieCallback::GetAllCookiesCallback
,
4918 base::Unretained(&callback
)));
4919 base::RunLoop().RunUntilIdle();
4920 EXPECT_EQ(0U, callback
.list_
.size());
4922 // The database should have vanished as well.
4924 db_tracker
->GetAllOriginsInfo(&origins
);
4925 EXPECT_EQ(0U, origins
.size());
4927 // Check that the LSO file has been removed.
4928 EXPECT_FALSE(base::PathExists(lso_file_path
));
4930 // Check if the indexed db has disappeared too.
4931 EXPECT_FALSE(base::DirectoryExists(idb_path
));
4934 // Tests loading single extensions (like --load-extension)
4935 // Flaky crashes. http://crbug.com/231806
4936 TEST_F(ExtensionServiceTest
, DISABLED_LoadExtension
) {
4937 InitializeEmptyExtensionService();
4939 base::FilePath ext1
= data_dir()
4940 .AppendASCII("good")
4941 .AppendASCII("Extensions")
4942 .AppendASCII("behllobkkfkfnphdnhnkndlbkcpglgmj")
4943 .AppendASCII("1.0.0.0");
4944 extensions::UnpackedInstaller::Create(service())->Load(ext1
);
4945 base::RunLoop().RunUntilIdle();
4946 EXPECT_EQ(0u, GetErrors().size());
4947 ASSERT_EQ(1u, loaded_
.size());
4948 EXPECT_EQ(Manifest::UNPACKED
, loaded_
[0]->location());
4949 EXPECT_EQ(1u, registry()->enabled_extensions().size());
4951 ValidatePrefKeyCount(1);
4953 base::FilePath no_manifest
=
4956 // .AppendASCII("Extensions")
4957 .AppendASCII("cccccccccccccccccccccccccccccccc")
4959 extensions::UnpackedInstaller::Create(service())->Load(no_manifest
);
4960 base::RunLoop().RunUntilIdle();
4961 EXPECT_EQ(1u, GetErrors().size());
4962 ASSERT_EQ(1u, loaded_
.size());
4963 EXPECT_EQ(1u, registry()->enabled_extensions().size());
4966 std::string id
= loaded_
[0]->id();
4967 EXPECT_FALSE(unloaded_id_
.length());
4968 service()->UninstallExtension(id
,
4969 extensions::UNINSTALL_REASON_FOR_TESTING
,
4970 base::Bind(&base::DoNothing
),
4972 base::RunLoop().RunUntilIdle();
4973 EXPECT_EQ(id
, unloaded_id_
);
4974 ASSERT_EQ(0u, loaded_
.size());
4975 EXPECT_EQ(0u, registry()->enabled_extensions().size());
4978 // Tests that we generate IDs when they are not specified in the manifest for
4979 // --load-extension.
4980 TEST_F(ExtensionServiceTest
, GenerateID
) {
4981 InitializeEmptyExtensionService();
4983 base::FilePath no_id_ext
= data_dir().AppendASCII("no_id");
4984 extensions::UnpackedInstaller::Create(service())->Load(no_id_ext
);
4985 base::RunLoop().RunUntilIdle();
4986 EXPECT_EQ(0u, GetErrors().size());
4987 ASSERT_EQ(1u, loaded_
.size());
4988 ASSERT_TRUE(crx_file::id_util::IdIsValid(loaded_
[0]->id()));
4989 EXPECT_EQ(loaded_
[0]->location(), Manifest::UNPACKED
);
4991 ValidatePrefKeyCount(1);
4993 std::string previous_id
= loaded_
[0]->id();
4995 // If we reload the same path, we should get the same extension ID.
4996 extensions::UnpackedInstaller::Create(service())->Load(no_id_ext
);
4997 base::RunLoop().RunUntilIdle();
4998 ASSERT_EQ(1u, loaded_
.size());
4999 ASSERT_EQ(previous_id
, loaded_
[0]->id());
5002 TEST_F(ExtensionServiceTest
, UnpackedValidatesLocales
) {
5003 InitializeEmptyExtensionService();
5005 base::FilePath bad_locale
=
5006 data_dir().AppendASCII("unpacked").AppendASCII("bad_messages_file");
5007 extensions::UnpackedInstaller::Create(service())->Load(bad_locale
);
5008 base::RunLoop().RunUntilIdle();
5009 EXPECT_EQ(1u, GetErrors().size());
5010 base::FilePath ms_messages_file
= bad_locale
.AppendASCII("_locales")
5012 .AppendASCII("messages.json");
5013 EXPECT_THAT(base::UTF16ToUTF8(GetErrors()[0]), testing::AllOf(
5015 base::UTF16ToUTF8(ms_messages_file
.LossyDisplayName())),
5016 testing::HasSubstr("Dictionary keys must be quoted.")));
5017 ASSERT_EQ(0u, loaded_
.size());
5020 void ExtensionServiceTest::TestExternalProvider(
5021 MockExtensionProvider
* provider
, Manifest::Location location
) {
5022 // Verify that starting with no providers loads no extensions.
5024 ASSERT_EQ(0u, loaded_
.size());
5026 provider
->set_visit_count(0);
5028 // Register a test extension externally using the mock registry provider.
5029 base::FilePath source_path
= data_dir().AppendASCII("good.crx");
5031 // Add the extension.
5032 provider
->UpdateOrAddExtension(good_crx
, "1.0.0.0", source_path
);
5034 // Reloading extensions should find our externally registered extension
5036 content::WindowedNotificationObserver
observer(
5037 extensions::NOTIFICATION_CRX_INSTALLER_DONE
,
5038 content::NotificationService::AllSources());
5039 service()->CheckForExternalUpdates();
5042 ASSERT_EQ(0u, GetErrors().size());
5043 ASSERT_EQ(1u, loaded_
.size());
5044 ASSERT_EQ(location
, loaded_
[0]->location());
5045 ASSERT_EQ("1.0.0.0", loaded_
[0]->version()->GetString());
5046 ValidatePrefKeyCount(1);
5047 ValidateIntegerPref(good_crx
, "state", Extension::ENABLED
);
5048 ValidateIntegerPref(good_crx
, "location", location
);
5050 // Reload extensions without changing anything. The extension should be
5053 service()->ReloadExtensionsForTest();
5054 base::RunLoop().RunUntilIdle();
5055 ASSERT_EQ(0u, GetErrors().size());
5056 ASSERT_EQ(1u, loaded_
.size());
5057 ValidatePrefKeyCount(1);
5058 ValidateIntegerPref(good_crx
, "state", Extension::ENABLED
);
5059 ValidateIntegerPref(good_crx
, "location", location
);
5061 // Now update the extension with a new version. We should get upgraded.
5062 source_path
= source_path
.DirName().AppendASCII("good2.crx");
5063 provider
->UpdateOrAddExtension(good_crx
, "1.0.0.1", source_path
);
5066 content::WindowedNotificationObserver
observer_2(
5067 extensions::NOTIFICATION_CRX_INSTALLER_DONE
,
5068 content::NotificationService::AllSources());
5069 service()->CheckForExternalUpdates();
5071 ASSERT_EQ(0u, GetErrors().size());
5072 ASSERT_EQ(1u, loaded_
.size());
5073 ASSERT_EQ("1.0.0.1", loaded_
[0]->version()->GetString());
5074 ValidatePrefKeyCount(1);
5075 ValidateIntegerPref(good_crx
, "state", Extension::ENABLED
);
5076 ValidateIntegerPref(good_crx
, "location", location
);
5078 // Uninstall the extension and reload. Nothing should happen because the
5079 // preference should prevent us from reinstalling.
5080 std::string id
= loaded_
[0]->id();
5082 GetManagementPolicy()->MustRemainEnabled(loaded_
[0].get(), NULL
);
5083 service()->UninstallExtension(id
,
5084 extensions::UNINSTALL_REASON_FOR_TESTING
,
5085 base::Bind(&base::DoNothing
),
5087 base::RunLoop().RunUntilIdle();
5089 base::FilePath install_path
= extensions_install_dir().AppendASCII(id
);
5091 // Policy controlled extensions should not have been touched by uninstall.
5092 ASSERT_TRUE(base::PathExists(install_path
));
5094 // The extension should also be gone from the install directory.
5095 ASSERT_FALSE(base::PathExists(install_path
));
5097 service()->CheckForExternalUpdates();
5098 base::RunLoop().RunUntilIdle();
5099 ASSERT_EQ(0u, loaded_
.size());
5100 ValidatePrefKeyCount(1);
5101 ValidateIntegerPref(good_crx
, "state",
5102 Extension::EXTERNAL_EXTENSION_UNINSTALLED
);
5103 ValidateIntegerPref(good_crx
, "location", location
);
5105 // Now clear the preference and reinstall.
5106 SetPrefInteg(good_crx
, "state", Extension::ENABLED
);
5109 content::WindowedNotificationObserver
observer(
5110 extensions::NOTIFICATION_CRX_INSTALLER_DONE
,
5111 content::NotificationService::AllSources());
5112 service()->CheckForExternalUpdates();
5114 ASSERT_EQ(1u, loaded_
.size());
5116 ValidatePrefKeyCount(1);
5117 ValidateIntegerPref(good_crx
, "state", Extension::ENABLED
);
5118 ValidateIntegerPref(good_crx
, "location", location
);
5120 if (GetManagementPolicy()->MustRemainEnabled(loaded_
[0].get(), NULL
)) {
5121 EXPECT_EQ(2, provider
->visit_count());
5123 // Now test an externally triggered uninstall (deleting the registry key or
5125 provider
->RemoveExtension(good_crx
);
5128 service()->OnExternalProviderReady(provider
);
5129 base::RunLoop().RunUntilIdle();
5130 ASSERT_EQ(0u, loaded_
.size());
5131 ValidatePrefKeyCount(0);
5133 // The extension should also be gone from the install directory.
5134 ASSERT_FALSE(base::PathExists(install_path
));
5136 // Now test the case where user uninstalls and then the extension is removed
5137 // from the external provider.
5138 content::WindowedNotificationObserver
observer(
5139 extensions::NOTIFICATION_CRX_INSTALLER_DONE
,
5140 content::NotificationService::AllSources());
5141 provider
->UpdateOrAddExtension(good_crx
, "1.0.0.1", source_path
);
5142 service()->CheckForExternalUpdates();
5145 ASSERT_EQ(1u, loaded_
.size());
5146 ASSERT_EQ(0u, GetErrors().size());
5150 service()->UninstallExtension(id
,
5151 extensions::UNINSTALL_REASON_FOR_TESTING
,
5152 base::Bind(&base::DoNothing
),
5154 base::RunLoop().RunUntilIdle();
5155 ASSERT_EQ(0u, loaded_
.size());
5157 // Then remove the extension from the extension provider.
5158 provider
->RemoveExtension(good_crx
);
5160 // Should still be at 0.
5162 extensions::InstalledLoader(service()).LoadAllExtensions();
5163 base::RunLoop().RunUntilIdle();
5164 ASSERT_EQ(0u, loaded_
.size());
5165 ValidatePrefKeyCount(1);
5167 EXPECT_EQ(5, provider
->visit_count());
5171 // Tests the external installation feature
5173 TEST_F(ExtensionServiceTest
, ExternalInstallRegistry
) {
5174 // This should all work, even when normal extension installation is disabled.
5175 InitializeEmptyExtensionService();
5176 service()->set_extensions_enabled(false);
5178 // Now add providers. Extension system takes ownership of the objects.
5179 MockExtensionProvider
* reg_provider
=
5180 new MockExtensionProvider(service(), Manifest::EXTERNAL_REGISTRY
);
5181 AddMockExternalProvider(reg_provider
);
5182 TestExternalProvider(reg_provider
, Manifest::EXTERNAL_REGISTRY
);
5186 TEST_F(ExtensionServiceTest
, ExternalInstallPref
) {
5187 InitializeEmptyExtensionService();
5189 // Now add providers. Extension system takes ownership of the objects.
5190 MockExtensionProvider
* pref_provider
=
5191 new MockExtensionProvider(service(), Manifest::EXTERNAL_PREF
);
5193 AddMockExternalProvider(pref_provider
);
5194 TestExternalProvider(pref_provider
, Manifest::EXTERNAL_PREF
);
5197 TEST_F(ExtensionServiceTest
, ExternalInstallPrefUpdateUrl
) {
5198 // This should all work, even when normal extension installation is disabled.
5199 InitializeEmptyExtensionService();
5200 service()->set_extensions_enabled(false);
5202 // TODO(skerner): The mock provider is not a good model of a provider
5203 // that works with update URLs, because it adds file and version info.
5204 // Extend the mock to work with update URLs. This test checks the
5205 // behavior that is common to all external extension visitors. The
5206 // browser test ExtensionManagementTest.ExternalUrlUpdate tests that
5207 // what the visitor does results in an extension being downloaded and
5209 MockExtensionProvider
* pref_provider
=
5210 new MockExtensionProvider(service(), Manifest::EXTERNAL_PREF_DOWNLOAD
);
5211 AddMockExternalProvider(pref_provider
);
5212 TestExternalProvider(pref_provider
, Manifest::EXTERNAL_PREF_DOWNLOAD
);
5215 TEST_F(ExtensionServiceTest
, ExternalInstallPolicyUpdateUrl
) {
5216 // This should all work, even when normal extension installation is disabled.
5217 InitializeEmptyExtensionService();
5218 service()->set_extensions_enabled(false);
5220 // TODO(skerner): The mock provider is not a good model of a provider
5221 // that works with update URLs, because it adds file and version info.
5222 // Extend the mock to work with update URLs. This test checks the
5223 // behavior that is common to all external extension visitors. The
5224 // browser test ExtensionManagementTest.ExternalUrlUpdate tests that
5225 // what the visitor does results in an extension being downloaded and
5227 MockExtensionProvider
* pref_provider
=
5228 new MockExtensionProvider(service(), Manifest::EXTERNAL_POLICY_DOWNLOAD
);
5229 AddMockExternalProvider(pref_provider
);
5230 TestExternalProvider(pref_provider
, Manifest::EXTERNAL_POLICY_DOWNLOAD
);
5233 // Tests that external extensions get uninstalled when the external extension
5234 // providers can't account for them.
5235 TEST_F(ExtensionServiceTest
, ExternalUninstall
) {
5236 // Start the extensions service with one external extension already installed.
5237 base::FilePath source_install_dir
=
5238 data_dir().AppendASCII("good").AppendASCII("Extensions");
5239 base::FilePath pref_path
= source_install_dir
5241 .AppendASCII("PreferencesExternal");
5243 // This initializes the extensions service with no ExternalProviders.
5244 InitializeInstalledExtensionService(pref_path
, source_install_dir
);
5245 service()->set_extensions_enabled(false);
5249 ASSERT_EQ(0u, GetErrors().size());
5250 ASSERT_EQ(0u, loaded_
.size());
5252 // Verify that it's not the disabled extensions flag causing it not to load.
5253 service()->set_extensions_enabled(true);
5254 service()->ReloadExtensionsForTest();
5255 base::RunLoop().RunUntilIdle();
5257 ASSERT_EQ(0u, GetErrors().size());
5258 ASSERT_EQ(0u, loaded_
.size());
5261 // Test that running multiple update checks simultaneously does not
5262 // keep the update from succeeding.
5263 TEST_F(ExtensionServiceTest
, MultipleExternalUpdateCheck
) {
5264 InitializeEmptyExtensionService();
5266 MockExtensionProvider
* provider
=
5267 new MockExtensionProvider(service(), Manifest::EXTERNAL_PREF
);
5268 AddMockExternalProvider(provider
);
5270 // Verify that starting with no providers loads no extensions.
5272 ASSERT_EQ(0u, loaded_
.size());
5274 // Start two checks for updates.
5275 provider
->set_visit_count(0);
5276 service()->CheckForExternalUpdates();
5277 service()->CheckForExternalUpdates();
5278 base::RunLoop().RunUntilIdle();
5280 // Two calls should cause two checks for external extensions.
5281 EXPECT_EQ(2, provider
->visit_count());
5282 EXPECT_EQ(0u, GetErrors().size());
5283 EXPECT_EQ(0u, loaded_
.size());
5285 // Register a test extension externally using the mock registry provider.
5286 base::FilePath source_path
= data_dir().AppendASCII("good.crx");
5287 provider
->UpdateOrAddExtension(good_crx
, "1.0.0.0", source_path
);
5289 // Two checks for external updates should find the extension, and install it
5291 content::WindowedNotificationObserver
observer(
5292 extensions::NOTIFICATION_CRX_INSTALLER_DONE
,
5293 content::NotificationService::AllSources());
5294 provider
->set_visit_count(0);
5295 service()->CheckForExternalUpdates();
5296 service()->CheckForExternalUpdates();
5298 EXPECT_EQ(2, provider
->visit_count());
5299 ASSERT_EQ(0u, GetErrors().size());
5300 ASSERT_EQ(1u, loaded_
.size());
5301 ASSERT_EQ(Manifest::EXTERNAL_PREF
, loaded_
[0]->location());
5302 ASSERT_EQ("1.0.0.0", loaded_
[0]->version()->GetString());
5303 ValidatePrefKeyCount(1);
5304 ValidateIntegerPref(good_crx
, "state", Extension::ENABLED
);
5305 ValidateIntegerPref(good_crx
, "location", Manifest::EXTERNAL_PREF
);
5307 provider
->RemoveExtension(good_crx
);
5308 provider
->set_visit_count(0);
5309 service()->CheckForExternalUpdates();
5310 service()->CheckForExternalUpdates();
5311 base::RunLoop().RunUntilIdle();
5313 // Two calls should cause two checks for external extensions.
5314 // Because the external source no longer includes good_crx,
5315 // good_crx will be uninstalled. So, expect that no extensions
5317 EXPECT_EQ(2, provider
->visit_count());
5318 EXPECT_EQ(0u, GetErrors().size());
5319 EXPECT_EQ(0u, loaded_
.size());
5322 TEST_F(ExtensionServiceTest
, ExternalPrefProvider
) {
5323 InitializeEmptyExtensionService();
5325 // Test some valid extension records.
5326 // Set a base path to avoid erroring out on relative paths.
5327 // Paths starting with // are absolute on every platform we support.
5328 base::FilePath
base_path(FILE_PATH_LITERAL("//base/path"));
5329 ASSERT_TRUE(base_path
.IsAbsolute());
5330 MockProviderVisitor
visitor(base_path
);
5331 std::string json_data
=
5333 " \"aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa\": {"
5334 " \"external_crx\": \"RandomExtension.crx\","
5335 " \"external_version\": \"1.0\""
5337 " \"bbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbb\": {"
5338 " \"external_crx\": \"RandomExtension2.crx\","
5339 " \"external_version\": \"2.0\""
5341 " \"cccccccccccccccccccccccccccccccc\": {"
5342 " \"external_update_url\": \"http:\\\\foo.com/update\","
5343 " \"install_parameter\": \"id\""
5346 EXPECT_EQ(3, visitor
.Visit(json_data
));
5348 // Simulate an external_extensions.json file that contains seven invalid
5350 // - One that is missing the 'external_crx' key.
5351 // - One that is missing the 'external_version' key.
5352 // - One that is specifying .. in the path.
5353 // - One that specifies both a file and update URL.
5354 // - One that specifies no file or update URL.
5355 // - One that has an update URL that is not well formed.
5356 // - One that contains a malformed version.
5357 // - One that has an invalid id.
5358 // - One that has a non-dictionary value.
5359 // - One that has an integer 'external_version' instead of a string.
5360 // The final extension is valid, and we check that it is read to make sure
5361 // failures don't stop valid records from being read.
5364 " \"aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa\": {"
5365 " \"external_version\": \"1.0\""
5367 " \"bbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbb\": {"
5368 " \"external_crx\": \"RandomExtension.crx\""
5370 " \"cccccccccccccccccccccccccccccccc\": {"
5371 " \"external_crx\": \"..\\\\foo\\\\RandomExtension2.crx\","
5372 " \"external_version\": \"2.0\""
5374 " \"dddddddddddddddddddddddddddddddd\": {"
5375 " \"external_crx\": \"RandomExtension2.crx\","
5376 " \"external_version\": \"2.0\","
5377 " \"external_update_url\": \"http:\\\\foo.com/update\""
5379 " \"eeeeeeeeeeeeeeeeeeeeeeeeeeeeeeee\": {"
5381 " \"ffffffffffffffffffffffffffffffff\": {"
5382 " \"external_update_url\": \"This string is not a valid URL\""
5384 " \"gggggggggggggggggggggggggggggggg\": {"
5385 " \"external_crx\": \"RandomExtension3.crx\","
5386 " \"external_version\": \"This is not a valid version!\""
5388 " \"This is not a valid id!\": {},"
5389 " \"hhhhhhhhhhhhhhhhhhhhhhhhhhhhhhhh\": true,"
5390 " \"iiiiiiiiiiiiiiiiiiiiiiiiiiiiiiii\": {"
5391 " \"external_crx\": \"RandomExtension4.crx\","
5392 " \"external_version\": 1.0"
5394 " \"pppppppppppppppppppppppppppppppp\": {"
5395 " \"external_crx\": \"RandomValidExtension.crx\","
5396 " \"external_version\": \"1.0\""
5399 EXPECT_EQ(1, visitor
.Visit(json_data
));
5401 // Check that if a base path is not provided, use of a relative
5403 base::FilePath empty
;
5404 MockProviderVisitor
visitor_no_relative_paths(empty
);
5406 // Use absolute paths. Expect success.
5409 " \"aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa\": {"
5410 " \"external_crx\": \"//RandomExtension1.crx\","
5411 " \"external_version\": \"3.0\""
5413 " \"bbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbb\": {"
5414 " \"external_crx\": \"//path/to/RandomExtension2.crx\","
5415 " \"external_version\": \"3.0\""
5418 EXPECT_EQ(2, visitor_no_relative_paths
.Visit(json_data
));
5420 // Use a relative path. Expect that it will error out.
5423 " \"cccccccccccccccccccccccccccccccc\": {"
5424 " \"external_crx\": \"RandomExtension2.crx\","
5425 " \"external_version\": \"3.0\""
5428 EXPECT_EQ(0, visitor_no_relative_paths
.Visit(json_data
));
5430 // Test supported_locales.
5433 " \"aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa\": {"
5434 " \"external_crx\": \"RandomExtension.crx\","
5435 " \"external_version\": \"1.0\","
5436 " \"supported_locales\": [ \"en\" ]"
5438 " \"bbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbb\": {"
5439 " \"external_crx\": \"RandomExtension2.crx\","
5440 " \"external_version\": \"2.0\","
5441 " \"supported_locales\": [ \"en-GB\" ]"
5443 " \"cccccccccccccccccccccccccccccccc\": {"
5444 " \"external_crx\": \"RandomExtension2.crx\","
5445 " \"external_version\": \"3.0\","
5446 " \"supported_locales\": [ \"en_US\", \"fr\" ]"
5450 ScopedBrowserLocale
guard("en-US");
5451 EXPECT_EQ(2, visitor
.Visit(json_data
));
5454 // Test keep_if_present.
5457 " \"aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa\": {"
5458 " \"external_crx\": \"RandomExtension.crx\","
5459 " \"external_version\": \"1.0\","
5460 " \"keep_if_present\": true"
5464 EXPECT_EQ(0, visitor
.Visit(json_data
));
5467 // Test is_bookmark_app.
5468 MockProviderVisitor
from_bookmark_visitor(
5469 base_path
, Extension::FROM_BOOKMARK
);
5472 " \"aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa\": {"
5473 " \"external_crx\": \"RandomExtension.crx\","
5474 " \"external_version\": \"1.0\","
5475 " \"is_bookmark_app\": true"
5478 EXPECT_EQ(1, from_bookmark_visitor
.Visit(json_data
));
5480 // Test is_from_webstore.
5481 MockProviderVisitor
from_webstore_visitor(
5482 base_path
, Extension::FROM_WEBSTORE
);
5485 " \"aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa\": {"
5486 " \"external_crx\": \"RandomExtension.crx\","
5487 " \"external_version\": \"1.0\","
5488 " \"is_from_webstore\": true"
5491 EXPECT_EQ(1, from_webstore_visitor
.Visit(json_data
));
5493 // Test was_installed_by_eom.
5494 MockProviderVisitor
was_installed_by_eom_visitor(
5495 base_path
, Extension::WAS_INSTALLED_BY_OEM
);
5498 " \"aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa\": {"
5499 " \"external_crx\": \"RandomExtension.crx\","
5500 " \"external_version\": \"1.0\","
5501 " \"was_installed_by_oem\": true"
5504 EXPECT_EQ(1, was_installed_by_eom_visitor
.Visit(json_data
));
5506 // Test min_profile_created_by_version.
5507 MockProviderVisitor
min_profile_created_by_version_visitor(base_path
);
5510 " \"aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa\": {"
5511 " \"external_crx\": \"RandomExtension.crx\","
5512 " \"external_version\": \"1.0\","
5513 " \"min_profile_created_by_version\": \"42.0.0.1\""
5515 " \"bbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbb\": {"
5516 " \"external_crx\": \"RandomExtension2.crx\","
5517 " \"external_version\": \"1.0\","
5518 " \"min_profile_created_by_version\": \"43.0.0.1\""
5520 " \"cccccccccccccccccccccccccccccccc\": {"
5521 " \"external_crx\": \"RandomExtension3.crx\","
5522 " \"external_version\": \"3.0\","
5523 " \"min_profile_created_by_version\": \"44.0.0.1\""
5526 min_profile_created_by_version_visitor
.profile()->GetPrefs()->SetString(
5527 prefs::kProfileCreatedByVersion
, "40.0.0.1");
5528 EXPECT_EQ(0, min_profile_created_by_version_visitor
.Visit(json_data
));
5529 min_profile_created_by_version_visitor
.profile()->GetPrefs()->SetString(
5530 prefs::kProfileCreatedByVersion
, "43.0.0.1");
5531 EXPECT_EQ(2, min_profile_created_by_version_visitor
.Visit(json_data
));
5532 min_profile_created_by_version_visitor
.profile()->GetPrefs()->SetString(
5533 prefs::kProfileCreatedByVersion
, "45.0.0.1");
5534 EXPECT_EQ(3, min_profile_created_by_version_visitor
.Visit(json_data
));
5537 TEST_F(ExtensionServiceTest
, DoNotInstallForEnterprise
) {
5538 InitializeEmptyExtensionService();
5540 const base::FilePath
base_path(FILE_PATH_LITERAL("//base/path"));
5541 ASSERT_TRUE(base_path
.IsAbsolute());
5542 MockProviderVisitor
visitor(base_path
);
5543 policy::ProfilePolicyConnector
* const connector
=
5544 policy::ProfilePolicyConnectorFactory::GetForBrowserContext(
5546 connector
->OverrideIsManagedForTesting(true);
5547 EXPECT_TRUE(connector
->IsManaged());
5549 std::string json_data
=
5551 " \"aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa\": {"
5552 " \"external_crx\": \"RandomExtension.crx\","
5553 " \"external_version\": \"1.0\","
5554 " \"do_not_install_for_enterprise\": true"
5556 " \"bbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbb\": {"
5557 " \"external_crx\": \"RandomExtension2.crx\","
5558 " \"external_version\": \"1.0\""
5561 EXPECT_EQ(1, visitor
.Visit(json_data
));
5564 // Test loading good extensions from the profile directory.
5565 TEST_F(ExtensionServiceTest
, LoadAndRelocalizeExtensions
) {
5566 // Ensure we're testing in "en" and leave global state untouched.
5567 extension_l10n_util::ScopedLocaleForTest
testLocale("en");
5569 // Initialize the test dir with a good Preferences/extensions.
5570 base::FilePath source_install_dir
= data_dir().AppendASCII("l10n");
5571 base::FilePath pref_path
=
5572 source_install_dir
.Append(chrome::kPreferencesFilename
);
5573 InitializeInstalledExtensionService(pref_path
, source_install_dir
);
5577 ASSERT_EQ(3u, loaded_
.size());
5579 // This was equal to "sr" on load.
5580 ValidateStringPref(loaded_
[0]->id(), keys::kCurrentLocale
, "en");
5582 // These are untouched by re-localization.
5583 ValidateStringPref(loaded_
[1]->id(), keys::kCurrentLocale
, "en");
5584 EXPECT_FALSE(IsPrefExist(loaded_
[1]->id(), keys::kCurrentLocale
));
5586 // This one starts with Serbian name, and gets re-localized into English.
5587 EXPECT_EQ("My name is simple.", loaded_
[0]->name());
5589 // These are untouched by re-localization.
5590 EXPECT_EQ("My name is simple.", loaded_
[1]->name());
5591 EXPECT_EQ("no l10n", loaded_
[2]->name());
5594 class ExtensionsReadyRecorder
: public content::NotificationObserver
{
5596 ExtensionsReadyRecorder() : ready_(false) {
5597 registrar_
.Add(this,
5598 extensions::NOTIFICATION_EXTENSIONS_READY_DEPRECATED
,
5599 content::NotificationService::AllSources());
5602 void set_ready(bool value
) { ready_
= value
; }
5603 bool ready() { return ready_
; }
5606 void Observe(int type
,
5607 const content::NotificationSource
& source
,
5608 const content::NotificationDetails
& details
) override
{
5610 case extensions::NOTIFICATION_EXTENSIONS_READY_DEPRECATED
:
5618 content::NotificationRegistrar registrar_
;
5622 // Test that we get enabled/disabled correctly for all the pref/command-line
5623 // combinations. We don't want to derive from the ExtensionServiceTest class
5624 // for this test, so we use ExtensionServiceTestSimple.
5626 // Also tests that we always fire EXTENSIONS_READY, no matter whether we are
5628 class ExtensionServiceTestSimple
: public testing::Test
{
5629 content::TestBrowserThreadBundle thread_bundle_
;
5632 TEST_F(ExtensionServiceTestSimple
, Enabledness
) {
5633 // Make sure the PluginService singleton is destroyed at the end of the test.
5634 base::ShadowingAtExitManager at_exit_manager
;
5635 #if defined(ENABLE_PLUGINS)
5636 content::PluginService::GetInstance()->Init();
5637 content::PluginService::GetInstance()->DisablePluginsDiscoveryForTesting();
5640 ExtensionErrorReporter::Init(false); // no noisy errors
5641 ExtensionsReadyRecorder recorder
;
5642 scoped_ptr
<TestingProfile
> profile(new TestingProfile());
5643 #if defined OS_CHROMEOS
5644 chromeos::ScopedTestDeviceSettingsService device_settings_service
;
5645 chromeos::ScopedTestCrosSettings cros_settings
;
5646 scoped_ptr
<chromeos::ScopedTestUserManager
> user_manager(
5647 new chromeos::ScopedTestUserManager
);
5649 scoped_ptr
<base::CommandLine
> command_line
;
5650 base::FilePath install_dir
= profile
->GetPath()
5651 .AppendASCII(extensions::kInstallDirectoryName
);
5653 // By default, we are enabled.
5654 command_line
.reset(new base::CommandLine(base::CommandLine::NO_PROGRAM
));
5655 ExtensionService
* service
= static_cast<extensions::TestExtensionSystem
*>(
5656 ExtensionSystem::Get(profile
.get()))->
5657 CreateExtensionService(
5661 EXPECT_TRUE(service
->extensions_enabled());
5663 base::RunLoop().RunUntilIdle();
5664 EXPECT_TRUE(recorder
.ready());
5665 #if defined OS_CHROMEOS
5666 user_manager
.reset();
5669 // If either the command line or pref is set, we are disabled.
5670 recorder
.set_ready(false);
5671 profile
.reset(new TestingProfile());
5672 command_line
->AppendSwitch(switches::kDisableExtensions
);
5673 service
= static_cast<extensions::TestExtensionSystem
*>(
5674 ExtensionSystem::Get(profile
.get()))->
5675 CreateExtensionService(
5679 EXPECT_FALSE(service
->extensions_enabled());
5681 base::RunLoop().RunUntilIdle();
5682 EXPECT_TRUE(recorder
.ready());
5684 recorder
.set_ready(false);
5685 profile
.reset(new TestingProfile());
5686 profile
->GetPrefs()->SetBoolean(prefs::kDisableExtensions
, true);
5687 service
= static_cast<extensions::TestExtensionSystem
*>(
5688 ExtensionSystem::Get(profile
.get()))->
5689 CreateExtensionService(
5693 EXPECT_FALSE(service
->extensions_enabled());
5695 base::RunLoop().RunUntilIdle();
5696 EXPECT_TRUE(recorder
.ready());
5698 recorder
.set_ready(false);
5699 profile
.reset(new TestingProfile());
5700 profile
->GetPrefs()->SetBoolean(prefs::kDisableExtensions
, true);
5701 command_line
.reset(new base::CommandLine(base::CommandLine::NO_PROGRAM
));
5702 service
= static_cast<extensions::TestExtensionSystem
*>(
5703 ExtensionSystem::Get(profile
.get()))->
5704 CreateExtensionService(
5708 EXPECT_FALSE(service
->extensions_enabled());
5710 base::RunLoop().RunUntilIdle();
5711 EXPECT_TRUE(recorder
.ready());
5713 // Explicitly delete all the resources used in this test.
5716 // Execute any pending deletion tasks.
5717 base::RunLoop().RunUntilIdle();
5720 // Test loading extensions that require limited and unlimited storage quotas.
5721 TEST_F(ExtensionServiceTest
, StorageQuota
) {
5722 InitializeEmptyExtensionService();
5724 base::FilePath extensions_path
= data_dir().AppendASCII("storage_quota");
5726 base::FilePath limited_quota_ext
=
5727 extensions_path
.AppendASCII("limited_quota")
5728 .AppendASCII("1.0");
5730 // The old permission name for unlimited quota was "unlimited_storage", but
5731 // we changed it to "unlimitedStorage". This tests both versions.
5732 base::FilePath unlimited_quota_ext
=
5733 extensions_path
.AppendASCII("unlimited_quota")
5734 .AppendASCII("1.0");
5735 base::FilePath unlimited_quota_ext2
=
5736 extensions_path
.AppendASCII("unlimited_quota")
5737 .AppendASCII("2.0");
5738 extensions::UnpackedInstaller::Create(service())->Load(limited_quota_ext
);
5739 extensions::UnpackedInstaller::Create(service())->Load(unlimited_quota_ext
);
5740 extensions::UnpackedInstaller::Create(service())->Load(unlimited_quota_ext2
);
5741 base::RunLoop().RunUntilIdle();
5743 ASSERT_EQ(3u, loaded_
.size());
5744 EXPECT_TRUE(profile());
5745 EXPECT_FALSE(profile()->IsOffTheRecord());
5747 profile()->GetExtensionSpecialStoragePolicy()->IsStorageUnlimited(
5748 loaded_
[0]->url()));
5749 EXPECT_TRUE(profile()->GetExtensionSpecialStoragePolicy()->IsStorageUnlimited(
5750 loaded_
[1]->url()));
5751 EXPECT_TRUE(profile()->GetExtensionSpecialStoragePolicy()->IsStorageUnlimited(
5752 loaded_
[2]->url()));
5755 // Tests ComponentLoader::Add().
5756 TEST_F(ExtensionServiceTest
, ComponentExtensions
) {
5757 InitializeEmptyExtensionService();
5759 // Component extensions should work even when extensions are disabled.
5760 service()->set_extensions_enabled(false);
5762 base::FilePath path
= data_dir()
5763 .AppendASCII("good")
5764 .AppendASCII("Extensions")
5765 .AppendASCII("behllobkkfkfnphdnhnkndlbkcpglgmj")
5766 .AppendASCII("1.0.0.0");
5768 std::string manifest
;
5769 ASSERT_TRUE(base::ReadFileToString(
5770 path
.Append(extensions::kManifestFilename
), &manifest
));
5772 service()->component_loader()->Add(manifest
, path
);
5775 // Note that we do not pump messages -- the extension should be loaded
5778 EXPECT_EQ(0u, GetErrors().size());
5779 ASSERT_EQ(1u, loaded_
.size());
5780 EXPECT_EQ(Manifest::COMPONENT
, loaded_
[0]->location());
5781 EXPECT_EQ(1u, registry()->enabled_extensions().size());
5783 // Component extensions get a prefs entry on first install.
5784 ValidatePrefKeyCount(1);
5786 // Reload all extensions, and make sure it comes back.
5787 std::string extension_id
= (*registry()->enabled_extensions().begin())->id();
5789 service()->ReloadExtensionsForTest();
5790 ASSERT_EQ(1u, registry()->enabled_extensions().size());
5791 EXPECT_EQ(extension_id
, (*registry()->enabled_extensions().begin())->id());
5794 TEST_F(ExtensionServiceTest
, DeferredSyncStartupPreInstalledComponent
) {
5795 InitializeEmptyExtensionService();
5797 bool flare_was_called
= false;
5798 syncer::ModelType
triggered_type(syncer::UNSPECIFIED
);
5799 base::WeakPtrFactory
<ExtensionServiceTest
> factory(this);
5800 extension_sync_service()->SetSyncStartFlareForTesting(
5801 base::Bind(&ExtensionServiceTest::MockSyncStartFlare
,
5802 factory
.GetWeakPtr(),
5803 &flare_was_called
, // Safe due to WeakPtrFactory scope.
5804 &triggered_type
)); // Safe due to WeakPtrFactory scope.
5806 // Install a component extension.
5807 std::string manifest
;
5808 ASSERT_TRUE(base::ReadFileToString(
5809 good0_path().Append(extensions::kManifestFilename
), &manifest
));
5810 service()->component_loader()->Add(manifest
, good0_path());
5811 ASSERT_FALSE(service()->is_ready());
5813 ASSERT_TRUE(service()->is_ready());
5815 // Extensions added before service is_ready() don't trigger sync startup.
5816 EXPECT_FALSE(flare_was_called
);
5817 ASSERT_EQ(syncer::UNSPECIFIED
, triggered_type
);
5820 TEST_F(ExtensionServiceTest
, DeferredSyncStartupPreInstalledNormal
) {
5821 InitializeGoodInstalledExtensionService();
5823 bool flare_was_called
= false;
5824 syncer::ModelType
triggered_type(syncer::UNSPECIFIED
);
5825 base::WeakPtrFactory
<ExtensionServiceTest
> factory(this);
5826 extension_sync_service()->SetSyncStartFlareForTesting(
5827 base::Bind(&ExtensionServiceTest::MockSyncStartFlare
,
5828 factory
.GetWeakPtr(),
5829 &flare_was_called
, // Safe due to WeakPtrFactory scope.
5830 &triggered_type
)); // Safe due to WeakPtrFactory scope.
5832 ASSERT_FALSE(service()->is_ready());
5834 ASSERT_EQ(3u, loaded_
.size());
5835 ASSERT_TRUE(service()->is_ready());
5837 // Extensions added before service is_ready() don't trigger sync startup.
5838 EXPECT_FALSE(flare_was_called
);
5839 ASSERT_EQ(syncer::UNSPECIFIED
, triggered_type
);
5842 TEST_F(ExtensionServiceTest
, DeferredSyncStartupOnInstall
) {
5843 InitializeEmptyExtensionService();
5845 ASSERT_TRUE(service()->is_ready());
5847 bool flare_was_called
= false;
5848 syncer::ModelType
triggered_type(syncer::UNSPECIFIED
);
5849 base::WeakPtrFactory
<ExtensionServiceTest
> factory(this);
5850 extension_sync_service()->SetSyncStartFlareForTesting(
5851 base::Bind(&ExtensionServiceTest::MockSyncStartFlare
,
5852 factory
.GetWeakPtr(),
5853 &flare_was_called
, // Safe due to WeakPtrFactory scope.
5854 &triggered_type
)); // Safe due to WeakPtrFactory scope.
5856 base::FilePath path
= data_dir().AppendASCII("good.crx");
5857 InstallCRX(path
, INSTALL_NEW
);
5859 EXPECT_TRUE(flare_was_called
);
5860 EXPECT_EQ(syncer::EXTENSIONS
, triggered_type
);
5863 flare_was_called
= false;
5864 triggered_type
= syncer::UNSPECIFIED
;
5866 // Once sync starts, flare should no longer be invoked.
5867 extension_sync_service()->MergeDataAndStartSyncing(
5869 syncer::SyncDataList(),
5870 scoped_ptr
<syncer::SyncChangeProcessor
>(
5871 new syncer::FakeSyncChangeProcessor
),
5872 scoped_ptr
<syncer::SyncErrorFactory
>(new syncer::SyncErrorFactoryMock()));
5873 path
= data_dir().AppendASCII("page_action.crx");
5874 InstallCRX(path
, INSTALL_NEW
);
5875 EXPECT_FALSE(flare_was_called
);
5876 ASSERT_EQ(syncer::UNSPECIFIED
, triggered_type
);
5879 TEST_F(ExtensionServiceTest
, DisableExtensionFromSync
) {
5880 // Start the extensions service with one external extension already installed.
5881 base::FilePath source_install_dir
=
5882 data_dir().AppendASCII("good").AppendASCII("Extensions");
5883 base::FilePath pref_path
=
5884 source_install_dir
.DirName().Append(chrome::kPreferencesFilename
);
5886 InitializeInstalledExtensionService(pref_path
, source_install_dir
);
5888 // The user has enabled sync.
5889 ProfileSyncService
* sync_service
=
5890 ProfileSyncServiceFactory::GetForProfile(profile());
5891 sync_service
->SetSyncSetupCompleted();
5894 ASSERT_TRUE(service()->is_ready());
5896 ASSERT_EQ(3u, loaded_
.size());
5898 // We start enabled.
5899 const Extension
* extension
= service()->GetExtensionById(good0
, true);
5900 ASSERT_TRUE(extension
);
5901 ASSERT_TRUE(service()->IsExtensionEnabled(good0
));
5904 extension_sync_service()->MergeDataAndStartSyncing(
5906 syncer::SyncDataList(),
5907 make_scoped_ptr(new syncer::FakeSyncChangeProcessor
),
5908 scoped_ptr
<syncer::SyncErrorFactory
>(new syncer::SyncErrorFactoryMock()));
5910 // Then sync data arrives telling us to disable |good0|.
5911 ExtensionSyncData
disable_good_crx(*extension
, false,
5912 Extension::DISABLE_USER_ACTION
, false,
5913 false, ExtensionSyncData::BOOLEAN_UNSET
);
5914 syncer::SyncChange
sync_change(FROM_HERE
,
5915 syncer::SyncChange::ACTION_UPDATE
,
5916 disable_good_crx
.GetSyncData());
5917 syncer::SyncChangeList
list(1, sync_change
);
5918 extension_sync_service()->ProcessSyncChanges(FROM_HERE
, list
);
5920 ASSERT_FALSE(service()->IsExtensionEnabled(good0
));
5923 TEST_F(ExtensionServiceTest
, IgnoreSyncChangesWhenLocalStateIsMoreRecent
) {
5924 // Start the extension service with three extensions already installed.
5925 base::FilePath source_install_dir
=
5926 data_dir().AppendASCII("good").AppendASCII("Extensions");
5927 base::FilePath pref_path
=
5928 source_install_dir
.DirName().Append(chrome::kPreferencesFilename
);
5930 InitializeInstalledExtensionService(pref_path
, source_install_dir
);
5932 // The user has enabled sync.
5933 ProfileSyncService
* sync_service
=
5934 ProfileSyncServiceFactory::GetForProfile(profile());
5935 sync_service
->SetSyncSetupCompleted();
5936 // Make sure ExtensionSyncService is created, so it'll be notified of changes.
5937 extension_sync_service();
5940 ASSERT_TRUE(service()->is_ready());
5941 ASSERT_EQ(3u, loaded_
.size());
5943 ASSERT_TRUE(service()->IsExtensionEnabled(good0
));
5944 ASSERT_TRUE(service()->IsExtensionEnabled(good2
));
5946 // Disable and re-enable good0 before first sync data arrives.
5947 service()->DisableExtension(good0
, Extension::DISABLE_USER_ACTION
);
5948 ASSERT_FALSE(service()->IsExtensionEnabled(good0
));
5949 service()->EnableExtension(good0
);
5950 ASSERT_TRUE(service()->IsExtensionEnabled(good0
));
5951 // Disable good2 before first sync data arrives (good1 is considered
5952 // non-syncable because it has plugin permission).
5953 service()->DisableExtension(good2
, Extension::DISABLE_USER_ACTION
);
5954 ASSERT_FALSE(service()->IsExtensionEnabled(good2
));
5956 const Extension
* extension0
= service()->GetExtensionById(good0
, true);
5957 const Extension
* extension2
= service()->GetExtensionById(good2
, true);
5958 ASSERT_TRUE(extensions::sync_helper::IsSyncable(extension0
));
5959 ASSERT_TRUE(extensions::sync_helper::IsSyncable(extension2
));
5961 // Now sync data comes in that says to disable good0 and enable good2.
5962 ExtensionSyncData
disable_good0(*extension0
, false,
5963 Extension::DISABLE_USER_ACTION
, false, false,
5964 ExtensionSyncData::BOOLEAN_UNSET
);
5965 ExtensionSyncData
enable_good2(*extension2
, true, Extension::DISABLE_NONE
,
5967 ExtensionSyncData::BOOLEAN_UNSET
);
5968 syncer::SyncDataList sync_data
;
5969 sync_data
.push_back(disable_good0
.GetSyncData());
5970 sync_data
.push_back(enable_good2
.GetSyncData());
5971 extension_sync_service()->MergeDataAndStartSyncing(
5974 make_scoped_ptr(new syncer::FakeSyncChangeProcessor
),
5975 make_scoped_ptr(new syncer::SyncErrorFactoryMock
));
5977 // Both sync changes should be ignored, since the local state was changed
5978 // before sync started, and so the local state is considered more recent.
5979 EXPECT_TRUE(service()->IsExtensionEnabled(good0
));
5980 EXPECT_FALSE(service()->IsExtensionEnabled(good2
));
5983 TEST_F(ExtensionServiceTest
, GetSyncData
) {
5984 InitializeEmptyExtensionService();
5985 InstallCRX(data_dir().AppendASCII("good.crx"), INSTALL_NEW
);
5986 const Extension
* extension
= service()->GetInstalledExtension(good_crx
);
5987 ASSERT_TRUE(extension
);
5989 extension_sync_service()->MergeDataAndStartSyncing(
5991 syncer::SyncDataList(),
5992 scoped_ptr
<syncer::SyncChangeProcessor
>(
5993 new syncer::FakeSyncChangeProcessor
),
5994 scoped_ptr
<syncer::SyncErrorFactory
>(new syncer::SyncErrorFactoryMock()));
5996 syncer::SyncDataList list
=
5997 extension_sync_service()->GetAllSyncData(syncer::EXTENSIONS
);
5998 ASSERT_EQ(list
.size(), 1U);
5999 scoped_ptr
<ExtensionSyncData
> data
=
6000 ExtensionSyncData::CreateFromSyncData(list
[0]);
6001 ASSERT_TRUE(data
.get());
6002 EXPECT_EQ(extension
->id(), data
->id());
6003 EXPECT_FALSE(data
->uninstalled());
6004 EXPECT_EQ(service()->IsExtensionEnabled(good_crx
), data
->enabled());
6005 EXPECT_EQ(extensions::util::IsIncognitoEnabled(good_crx
, profile()),
6006 data
->incognito_enabled());
6007 EXPECT_EQ(ExtensionSyncData::BOOLEAN_UNSET
, data
->all_urls_enabled());
6008 EXPECT_TRUE(data
->version().Equals(*extension
->version()));
6009 EXPECT_EQ(extensions::ManifestURL::GetUpdateURL(extension
),
6010 data
->update_url());
6011 EXPECT_EQ(extension
->name(), data
->name());
6014 TEST_F(ExtensionServiceTest
, GetSyncDataTerminated
) {
6015 InitializeEmptyExtensionService();
6016 InstallCRX(data_dir().AppendASCII("good.crx"), INSTALL_NEW
);
6017 TerminateExtension(good_crx
);
6018 const Extension
* extension
= service()->GetInstalledExtension(good_crx
);
6019 ASSERT_TRUE(extension
);
6021 syncer::FakeSyncChangeProcessor processor
;
6022 extension_sync_service()->MergeDataAndStartSyncing(
6024 syncer::SyncDataList(),
6025 scoped_ptr
<syncer::SyncChangeProcessor
>(
6026 new syncer::FakeSyncChangeProcessor
),
6027 scoped_ptr
<syncer::SyncErrorFactory
>(new syncer::SyncErrorFactoryMock()));
6029 syncer::SyncDataList list
=
6030 extension_sync_service()->GetAllSyncData(syncer::EXTENSIONS
);
6031 ASSERT_EQ(list
.size(), 1U);
6032 scoped_ptr
<ExtensionSyncData
> data
=
6033 ExtensionSyncData::CreateFromSyncData(list
[0]);
6034 ASSERT_TRUE(data
.get());
6035 EXPECT_EQ(extension
->id(), data
->id());
6036 EXPECT_FALSE(data
->uninstalled());
6037 EXPECT_EQ(service()->IsExtensionEnabled(good_crx
), data
->enabled());
6038 EXPECT_EQ(extensions::util::IsIncognitoEnabled(good_crx
, profile()),
6039 data
->incognito_enabled());
6040 EXPECT_EQ(ExtensionSyncData::BOOLEAN_UNSET
, data
->all_urls_enabled());
6041 EXPECT_TRUE(data
->version().Equals(*extension
->version()));
6042 EXPECT_EQ(extensions::ManifestURL::GetUpdateURL(extension
),
6043 data
->update_url());
6044 EXPECT_EQ(extension
->name(), data
->name());
6047 TEST_F(ExtensionServiceTest
, GetSyncDataFilter
) {
6048 InitializeEmptyExtensionService();
6049 InstallCRX(data_dir().AppendASCII("good.crx"), INSTALL_NEW
);
6050 const Extension
* extension
= service()->GetInstalledExtension(good_crx
);
6051 ASSERT_TRUE(extension
);
6053 syncer::FakeSyncChangeProcessor processor
;
6054 extension_sync_service()->MergeDataAndStartSyncing(
6056 syncer::SyncDataList(),
6057 scoped_ptr
<syncer::SyncChangeProcessor
>(
6058 new syncer::FakeSyncChangeProcessor
),
6059 scoped_ptr
<syncer::SyncErrorFactory
>(new syncer::SyncErrorFactoryMock()));
6061 syncer::SyncDataList list
=
6062 extension_sync_service()->GetAllSyncData(syncer::EXTENSIONS
);
6063 ASSERT_EQ(list
.size(), 0U);
6066 TEST_F(ExtensionServiceTest
, GetSyncExtensionDataUserSettings
) {
6067 InitializeEmptyExtensionService();
6068 InstallCRX(data_dir().AppendASCII("good.crx"), INSTALL_NEW
);
6069 const Extension
* extension
= service()->GetInstalledExtension(good_crx
);
6070 ASSERT_TRUE(extension
);
6072 syncer::FakeSyncChangeProcessor processor
;
6073 extension_sync_service()->MergeDataAndStartSyncing(
6075 syncer::SyncDataList(),
6076 scoped_ptr
<syncer::SyncChangeProcessor
>(
6077 new syncer::FakeSyncChangeProcessor
),
6078 scoped_ptr
<syncer::SyncErrorFactory
>(new syncer::SyncErrorFactoryMock()));
6081 syncer::SyncDataList list
=
6082 extension_sync_service()->GetAllSyncData(syncer::EXTENSIONS
);
6083 ASSERT_EQ(list
.size(), 1U);
6084 scoped_ptr
<ExtensionSyncData
> data
=
6085 ExtensionSyncData::CreateFromSyncData(list
[0]);
6086 ASSERT_TRUE(data
.get());
6087 EXPECT_TRUE(data
->enabled());
6088 EXPECT_FALSE(data
->incognito_enabled());
6089 EXPECT_EQ(ExtensionSyncData::BOOLEAN_UNSET
, data
->all_urls_enabled());
6092 service()->DisableExtension(good_crx
, Extension::DISABLE_USER_ACTION
);
6094 syncer::SyncDataList list
=
6095 extension_sync_service()->GetAllSyncData(syncer::EXTENSIONS
);
6096 ASSERT_EQ(list
.size(), 1U);
6097 scoped_ptr
<ExtensionSyncData
> data
=
6098 ExtensionSyncData::CreateFromSyncData(list
[0]);
6099 ASSERT_TRUE(data
.get());
6100 EXPECT_FALSE(data
->enabled());
6101 EXPECT_FALSE(data
->incognito_enabled());
6102 EXPECT_EQ(ExtensionSyncData::BOOLEAN_UNSET
, data
->all_urls_enabled());
6105 extensions::util::SetIsIncognitoEnabled(good_crx
, profile(), true);
6106 extensions::util::SetAllowedScriptingOnAllUrls(
6107 good_crx
, profile(), false);
6109 syncer::SyncDataList list
=
6110 extension_sync_service()->GetAllSyncData(syncer::EXTENSIONS
);
6111 ASSERT_EQ(list
.size(), 1U);
6112 scoped_ptr
<ExtensionSyncData
> data
=
6113 ExtensionSyncData::CreateFromSyncData(list
[0]);
6114 ASSERT_TRUE(data
.get());
6115 EXPECT_FALSE(data
->enabled());
6116 EXPECT_TRUE(data
->incognito_enabled());
6117 EXPECT_EQ(ExtensionSyncData::BOOLEAN_FALSE
, data
->all_urls_enabled());
6120 service()->EnableExtension(good_crx
);
6121 extensions::util::SetAllowedScriptingOnAllUrls(
6122 good_crx
, profile(), true);
6124 syncer::SyncDataList list
=
6125 extension_sync_service()->GetAllSyncData(syncer::EXTENSIONS
);
6126 ASSERT_EQ(list
.size(), 1U);
6127 scoped_ptr
<ExtensionSyncData
> data
=
6128 ExtensionSyncData::CreateFromSyncData(list
[0]);
6129 ASSERT_TRUE(data
.get());
6130 EXPECT_TRUE(data
->enabled());
6131 EXPECT_TRUE(data
->incognito_enabled());
6132 EXPECT_EQ(ExtensionSyncData::BOOLEAN_TRUE
, data
->all_urls_enabled());
6136 TEST_F(ExtensionServiceTest
, SyncForUninstalledExternalExtension
) {
6137 InitializeEmptyExtensionService();
6138 InstallCRXWithLocation(
6139 data_dir().AppendASCII("good.crx"), Manifest::EXTERNAL_PREF
, INSTALL_NEW
);
6140 const Extension
* extension
= service()->GetInstalledExtension(good_crx
);
6141 ASSERT_TRUE(extension
);
6143 syncer::FakeSyncChangeProcessor processor
;
6144 extension_sync_service()->MergeDataAndStartSyncing(
6146 syncer::SyncDataList(),
6147 scoped_ptr
<syncer::SyncChangeProcessor
>(
6148 new syncer::FakeSyncChangeProcessor
),
6149 scoped_ptr
<syncer::SyncErrorFactory
>(new syncer::SyncErrorFactoryMock()));
6151 UninstallExtension(good_crx
, false);
6153 ExtensionPrefs::Get(profile())->IsExternalExtensionUninstalled(good_crx
));
6155 sync_pb::EntitySpecifics specifics
;
6156 sync_pb::AppSpecifics
* app_specifics
= specifics
.mutable_app();
6157 sync_pb::ExtensionSpecifics
* extension_specifics
=
6158 app_specifics
->mutable_extension();
6159 extension_specifics
->set_id(good_crx
);
6160 extension_specifics
->set_version("1.0");
6161 extension_specifics
->set_enabled(true);
6163 syncer::SyncData sync_data
=
6164 syncer::SyncData::CreateLocalData(good_crx
, "Name", specifics
);
6165 syncer::SyncChange
sync_change(FROM_HERE
,
6166 syncer::SyncChange::ACTION_UPDATE
,
6168 syncer::SyncChangeList
list(1);
6169 list
[0] = sync_change
;
6171 extension_sync_service()->ProcessSyncChanges(FROM_HERE
, list
);
6173 ExtensionPrefs::Get(profile())->IsExternalExtensionUninstalled(good_crx
));
6176 TEST_F(ExtensionServiceTest
, GetSyncAppDataUserSettings
) {
6177 InitializeEmptyExtensionService();
6178 const Extension
* app
=
6179 PackAndInstallCRX(data_dir().AppendASCII("app"), INSTALL_NEW
);
6181 ASSERT_TRUE(app
->is_app());
6183 syncer::FakeSyncChangeProcessor processor
;
6184 extension_sync_service()->MergeDataAndStartSyncing(
6186 syncer::SyncDataList(),
6187 scoped_ptr
<syncer::SyncChangeProcessor
>(
6188 new syncer::FakeSyncChangeProcessor
),
6189 scoped_ptr
<syncer::SyncErrorFactory
>(new syncer::SyncErrorFactoryMock()));
6191 syncer::StringOrdinal initial_ordinal
=
6192 syncer::StringOrdinal::CreateInitialOrdinal();
6194 syncer::SyncDataList list
=
6195 extension_sync_service()->GetAllSyncData(syncer::APPS
);
6196 ASSERT_EQ(list
.size(), 1U);
6198 scoped_ptr
<ExtensionSyncData
> app_sync_data
=
6199 ExtensionSyncData::CreateFromSyncData(list
[0]);
6200 EXPECT_TRUE(initial_ordinal
.Equals(app_sync_data
->app_launch_ordinal()));
6201 EXPECT_TRUE(initial_ordinal
.Equals(app_sync_data
->page_ordinal()));
6204 AppSorting
* sorting
= ExtensionPrefs::Get(profile())->app_sorting();
6205 sorting
->SetAppLaunchOrdinal(app
->id(), initial_ordinal
.CreateAfter());
6207 syncer::SyncDataList list
=
6208 extension_sync_service()->GetAllSyncData(syncer::APPS
);
6209 ASSERT_EQ(list
.size(), 1U);
6211 scoped_ptr
<ExtensionSyncData
> app_sync_data
=
6212 ExtensionSyncData::CreateFromSyncData(list
[0]);
6213 ASSERT_TRUE(app_sync_data
.get());
6214 EXPECT_TRUE(initial_ordinal
.LessThan(app_sync_data
->app_launch_ordinal()));
6215 EXPECT_TRUE(initial_ordinal
.Equals(app_sync_data
->page_ordinal()));
6218 sorting
->SetPageOrdinal(app
->id(), initial_ordinal
.CreateAfter());
6220 syncer::SyncDataList list
=
6221 extension_sync_service()->GetAllSyncData(syncer::APPS
);
6222 ASSERT_EQ(list
.size(), 1U);
6224 scoped_ptr
<ExtensionSyncData
> app_sync_data
=
6225 ExtensionSyncData::CreateFromSyncData(list
[0]);
6226 ASSERT_TRUE(app_sync_data
.get());
6227 EXPECT_TRUE(initial_ordinal
.LessThan(app_sync_data
->app_launch_ordinal()));
6228 EXPECT_TRUE(initial_ordinal
.LessThan(app_sync_data
->page_ordinal()));
6232 // TODO (rdevlin.cronin): The OnExtensionMoved() method has been removed from
6233 // ExtensionService, so this test probably needs a new home. Unfortunately, it
6234 // relies pretty heavily on things like InitializeExtension[Sync]Service() and
6235 // PackAndInstallCRX(). When we clean up a bit more, this should move out.
6236 TEST_F(ExtensionServiceTest
, GetSyncAppDataUserSettingsOnExtensionMoved
) {
6237 InitializeEmptyExtensionService();
6238 const size_t kAppCount
= 3;
6239 const Extension
* apps
[kAppCount
];
6240 apps
[0] = PackAndInstallCRX(data_dir().AppendASCII("app1"), INSTALL_NEW
);
6241 apps
[1] = PackAndInstallCRX(data_dir().AppendASCII("app2"), INSTALL_NEW
);
6242 apps
[2] = PackAndInstallCRX(data_dir().AppendASCII("app4"), INSTALL_NEW
);
6243 for (size_t i
= 0; i
< kAppCount
; ++i
) {
6244 ASSERT_TRUE(apps
[i
]);
6245 ASSERT_TRUE(apps
[i
]->is_app());
6248 syncer::FakeSyncChangeProcessor processor
;
6249 extension_sync_service()->MergeDataAndStartSyncing(
6251 syncer::SyncDataList(),
6252 scoped_ptr
<syncer::SyncChangeProcessor
>(
6253 new syncer::FakeSyncChangeProcessor
),
6254 scoped_ptr
<syncer::SyncErrorFactory
>(new syncer::SyncErrorFactoryMock()));
6256 ExtensionPrefs::Get(service()->GetBrowserContext())
6258 ->OnExtensionMoved(apps
[0]->id(), apps
[1]->id(), apps
[2]->id());
6260 syncer::SyncDataList list
=
6261 extension_sync_service()->GetAllSyncData(syncer::APPS
);
6262 ASSERT_EQ(list
.size(), 3U);
6264 scoped_ptr
<ExtensionSyncData
> data
[kAppCount
];
6265 for (size_t i
= 0; i
< kAppCount
; ++i
) {
6266 data
[i
] = ExtensionSyncData::CreateFromSyncData(list
[i
]);
6267 ASSERT_TRUE(data
[i
].get());
6270 // The sync data is not always in the same order our apps were installed in,
6271 // so we do that sorting here so we can make sure the values are changed as
6273 syncer::StringOrdinal app_launch_ordinals
[kAppCount
];
6274 for (size_t i
= 0; i
< kAppCount
; ++i
) {
6275 for (size_t j
= 0; j
< kAppCount
; ++j
) {
6276 if (apps
[i
]->id() == data
[j
]->id())
6277 app_launch_ordinals
[i
] = data
[j
]->app_launch_ordinal();
6281 EXPECT_TRUE(app_launch_ordinals
[1].LessThan(app_launch_ordinals
[0]));
6282 EXPECT_TRUE(app_launch_ordinals
[0].LessThan(app_launch_ordinals
[2]));
6286 TEST_F(ExtensionServiceTest
, GetSyncDataList
) {
6287 InitializeEmptyExtensionService();
6288 InstallCRX(data_dir().AppendASCII("good.crx"), INSTALL_NEW
);
6289 InstallCRX(data_dir().AppendASCII("page_action.crx"), INSTALL_NEW
);
6290 InstallCRX(data_dir().AppendASCII("theme.crx"), INSTALL_NEW
);
6291 InstallCRX(data_dir().AppendASCII("theme2.crx"), INSTALL_NEW
);
6293 syncer::FakeSyncChangeProcessor processor
;
6294 extension_sync_service()->MergeDataAndStartSyncing(
6296 syncer::SyncDataList(),
6297 scoped_ptr
<syncer::SyncChangeProcessor
>(
6298 new syncer::FakeSyncChangeProcessor
),
6299 scoped_ptr
<syncer::SyncErrorFactory
>(new syncer::SyncErrorFactoryMock()));
6300 extension_sync_service()->MergeDataAndStartSyncing(
6302 syncer::SyncDataList(),
6303 scoped_ptr
<syncer::SyncChangeProcessor
>(
6304 new syncer::FakeSyncChangeProcessor
),
6305 scoped_ptr
<syncer::SyncErrorFactory
>(new syncer::SyncErrorFactoryMock()));
6307 service()->DisableExtension(page_action
, Extension::DISABLE_USER_ACTION
);
6308 TerminateExtension(theme2_crx
);
6310 EXPECT_EQ(0u, extension_sync_service()->GetAllSyncData(syncer::APPS
).size());
6312 2u, extension_sync_service()->GetAllSyncData(syncer::EXTENSIONS
).size());
6315 TEST_F(ExtensionServiceTest
, ProcessSyncDataUninstall
) {
6316 InitializeEmptyExtensionService();
6317 syncer::FakeSyncChangeProcessor processor
;
6318 extension_sync_service()->MergeDataAndStartSyncing(
6320 syncer::SyncDataList(),
6321 scoped_ptr
<syncer::SyncChangeProcessor
>(
6322 new syncer::FakeSyncChangeProcessor
),
6323 scoped_ptr
<syncer::SyncErrorFactory
>(new syncer::SyncErrorFactoryMock()));
6325 sync_pb::EntitySpecifics specifics
;
6326 sync_pb::ExtensionSpecifics
* ext_specifics
= specifics
.mutable_extension();
6327 ext_specifics
->set_id(good_crx
);
6328 ext_specifics
->set_version("1.0");
6329 syncer::SyncData sync_data
=
6330 syncer::SyncData::CreateLocalData(good_crx
, "Name", specifics
);
6331 syncer::SyncChange
sync_change(FROM_HERE
,
6332 syncer::SyncChange::ACTION_DELETE
,
6334 syncer::SyncChangeList
list(1);
6335 list
[0] = sync_change
;
6337 // Should do nothing.
6338 extension_sync_service()->ProcessSyncChanges(FROM_HERE
, list
);
6339 EXPECT_FALSE(service()->GetExtensionById(good_crx
, true));
6341 // Install the extension.
6342 base::FilePath extension_path
= data_dir().AppendASCII("good.crx");
6343 InstallCRX(extension_path
, INSTALL_NEW
);
6344 EXPECT_TRUE(service()->GetExtensionById(good_crx
, true));
6346 // Should uninstall the extension.
6347 extension_sync_service()->ProcessSyncChanges(FROM_HERE
, list
);
6348 EXPECT_FALSE(service()->GetExtensionById(good_crx
, true));
6350 // Should again do nothing.
6351 extension_sync_service()->ProcessSyncChanges(FROM_HERE
, list
);
6352 EXPECT_FALSE(service()->GetExtensionById(good_crx
, true));
6355 TEST_F(ExtensionServiceTest
, ProcessSyncDataWrongType
) {
6356 InitializeEmptyExtensionService();
6358 // Install the extension.
6359 base::FilePath extension_path
= data_dir().AppendASCII("good.crx");
6360 InstallCRX(extension_path
, INSTALL_NEW
);
6361 EXPECT_TRUE(service()->GetExtensionById(good_crx
, true));
6363 sync_pb::EntitySpecifics specifics
;
6364 sync_pb::AppSpecifics
* app_specifics
= specifics
.mutable_app();
6365 sync_pb::ExtensionSpecifics
* extension_specifics
=
6366 app_specifics
->mutable_extension();
6367 extension_specifics
->set_id(good_crx
);
6368 extension_specifics
->set_version(
6369 service()->GetInstalledExtension(good_crx
)->version()->GetString());
6372 extension_specifics
->set_enabled(true);
6373 syncer::SyncData sync_data
=
6374 syncer::SyncData::CreateLocalData(good_crx
, "Name", specifics
);
6375 syncer::SyncChange
sync_change(FROM_HERE
,
6376 syncer::SyncChange::ACTION_DELETE
,
6378 syncer::SyncChangeList
list(1);
6379 list
[0] = sync_change
;
6381 // Should do nothing
6382 extension_sync_service()->ProcessSyncChanges(FROM_HERE
, list
);
6383 EXPECT_TRUE(service()->GetExtensionById(good_crx
, true));
6387 extension_specifics
->set_enabled(false);
6388 syncer::SyncData sync_data
=
6389 syncer::SyncData::CreateLocalData(good_crx
, "Name", specifics
);
6390 syncer::SyncChange
sync_change(FROM_HERE
,
6391 syncer::SyncChange::ACTION_UPDATE
,
6393 syncer::SyncChangeList
list(1);
6394 list
[0] = sync_change
;
6396 // Should again do nothing.
6397 extension_sync_service()->ProcessSyncChanges(FROM_HERE
, list
);
6398 EXPECT_TRUE(service()->GetExtensionById(good_crx
, false));
6402 TEST_F(ExtensionServiceTest
, ProcessSyncDataSettings
) {
6403 InitializeEmptyExtensionService();
6404 syncer::FakeSyncChangeProcessor processor
;
6405 extension_sync_service()->MergeDataAndStartSyncing(
6407 syncer::SyncDataList(),
6408 scoped_ptr
<syncer::SyncChangeProcessor
>(
6409 new syncer::FakeSyncChangeProcessor
),
6410 scoped_ptr
<syncer::SyncErrorFactory
>(new syncer::SyncErrorFactoryMock()));
6412 InstallCRX(data_dir().AppendASCII("good.crx"), INSTALL_NEW
);
6413 EXPECT_TRUE(service()->IsExtensionEnabled(good_crx
));
6414 EXPECT_FALSE(extensions::util::IsIncognitoEnabled(good_crx
, profile()));
6415 EXPECT_FALSE(extensions::util::HasSetAllowedScriptingOnAllUrls(
6416 good_crx
, profile()));
6417 const bool kDefaultAllowedScripting
=
6418 extensions::util::DefaultAllowedScriptingOnAllUrls();
6419 EXPECT_EQ(kDefaultAllowedScripting
,
6420 extensions::util::AllowedScriptingOnAllUrls(good_crx
, profile()));
6422 sync_pb::EntitySpecifics specifics
;
6423 sync_pb::ExtensionSpecifics
* ext_specifics
= specifics
.mutable_extension();
6424 ext_specifics
->set_id(good_crx
);
6425 ext_specifics
->set_version(
6426 service()->GetInstalledExtension(good_crx
)->version()->GetString());
6427 ext_specifics
->set_enabled(false);
6430 syncer::SyncData sync_data
=
6431 syncer::SyncData::CreateLocalData(good_crx
, "Name", specifics
);
6432 syncer::SyncChange
sync_change(FROM_HERE
,
6433 syncer::SyncChange::ACTION_UPDATE
,
6435 syncer::SyncChangeList
list(1);
6436 list
[0] = sync_change
;
6437 extension_sync_service()->ProcessSyncChanges(FROM_HERE
, list
);
6438 EXPECT_FALSE(service()->IsExtensionEnabled(good_crx
));
6439 EXPECT_FALSE(extensions::util::IsIncognitoEnabled(good_crx
, profile()));
6440 EXPECT_FALSE(extensions::util::HasSetAllowedScriptingOnAllUrls(
6441 good_crx
, profile()));
6442 EXPECT_EQ(kDefaultAllowedScripting
,
6443 extensions::util::AllowedScriptingOnAllUrls(good_crx
, profile()));
6447 ext_specifics
->set_enabled(true);
6448 ext_specifics
->set_incognito_enabled(true);
6449 syncer::SyncData sync_data
=
6450 syncer::SyncData::CreateLocalData(good_crx
, "Name", specifics
);
6451 syncer::SyncChange
sync_change(FROM_HERE
,
6452 syncer::SyncChange::ACTION_UPDATE
,
6454 syncer::SyncChangeList
list(1);
6455 list
[0] = sync_change
;
6456 extension_sync_service()->ProcessSyncChanges(FROM_HERE
, list
);
6457 EXPECT_TRUE(service()->IsExtensionEnabled(good_crx
));
6458 EXPECT_TRUE(extensions::util::IsIncognitoEnabled(good_crx
, profile()));
6462 ext_specifics
->set_enabled(false);
6463 ext_specifics
->set_incognito_enabled(true);
6464 syncer::SyncData sync_data
=
6465 syncer::SyncData::CreateLocalData(good_crx
, "Name", specifics
);
6466 syncer::SyncChange
sync_change(FROM_HERE
,
6467 syncer::SyncChange::ACTION_UPDATE
,
6469 syncer::SyncChangeList
list(1);
6470 list
[0] = sync_change
;
6471 extension_sync_service()->ProcessSyncChanges(FROM_HERE
, list
);
6472 EXPECT_FALSE(service()->IsExtensionEnabled(good_crx
));
6473 EXPECT_TRUE(extensions::util::IsIncognitoEnabled(good_crx
, profile()));
6477 ext_specifics
->set_enabled(true);
6478 ext_specifics
->set_all_urls_enabled(!kDefaultAllowedScripting
);
6479 syncer::SyncData sync_data
=
6480 syncer::SyncData::CreateLocalData(good_crx
, "Name", specifics
);
6481 syncer::SyncChange
sync_change(FROM_HERE
,
6482 syncer::SyncChange::ACTION_UPDATE
,
6484 syncer::SyncChangeList
list(1);
6485 list
[0] = sync_change
;
6486 extension_sync_service()->ProcessSyncChanges(FROM_HERE
, list
);
6487 EXPECT_TRUE(service()->IsExtensionEnabled(good_crx
));
6488 EXPECT_TRUE(extensions::util::HasSetAllowedScriptingOnAllUrls(
6489 good_crx
, profile()));
6490 EXPECT_EQ(!kDefaultAllowedScripting
,
6491 extensions::util::AllowedScriptingOnAllUrls(good_crx
, profile()));
6495 ext_specifics
->set_all_urls_enabled(kDefaultAllowedScripting
);
6496 syncer::SyncData sync_data
=
6497 syncer::SyncData::CreateLocalData(good_crx
, "Name", specifics
);
6498 syncer::SyncChange
sync_change(FROM_HERE
,
6499 syncer::SyncChange::ACTION_UPDATE
,
6501 syncer::SyncChangeList
list(1);
6502 list
[0] = sync_change
;
6503 extension_sync_service()->ProcessSyncChanges(FROM_HERE
, list
);
6504 EXPECT_TRUE(service()->IsExtensionEnabled(good_crx
));
6505 EXPECT_TRUE(extensions::util::HasSetAllowedScriptingOnAllUrls(
6506 good_crx
, profile()));
6507 EXPECT_EQ(kDefaultAllowedScripting
,
6508 extensions::util::AllowedScriptingOnAllUrls(good_crx
, profile()));
6511 EXPECT_FALSE(service()->pending_extension_manager()->IsIdPending(good_crx
));
6514 TEST_F(ExtensionServiceTest
, ProcessSyncDataNewExtension
) {
6515 InitializeEmptyExtensionService();
6516 syncer::FakeSyncChangeProcessor processor
;
6517 extension_sync_service()->MergeDataAndStartSyncing(
6519 syncer::SyncDataList(),
6520 scoped_ptr
<syncer::SyncChangeProcessor
>(
6521 new syncer::FakeSyncChangeProcessor
),
6522 scoped_ptr
<syncer::SyncErrorFactory
>(new syncer::SyncErrorFactoryMock()));
6524 const base::FilePath path
= data_dir().AppendASCII("good.crx");
6525 const ExtensionPrefs
* prefs
= ExtensionPrefs::Get(profile());
6528 const char* name
; // For failure output only.
6529 bool sync_enabled
; // The "enabled" flag coming in from Sync.
6530 // The disable reason(s) coming in from Sync, or -1 for "not set".
6531 int sync_disable_reasons
;
6532 // The disable reason(s) that should be set on the installed extension.
6533 // This will usually be the same as |sync_disable_reasons|, but see the
6535 int expect_disable_reasons
;
6536 // Whether the extension's permissions should be auto-granted during
6538 bool expect_permissions_granted
;
6540 // Standard case: Extension comes in enabled; permissions should be granted
6541 // during installation.
6542 { "Standard", true, 0, 0, true },
6543 // If the extension comes in disabled, its permissions should still be
6544 // granted (the user already approved them on another machine).
6545 { "Disabled", false, Extension::DISABLE_USER_ACTION
,
6546 Extension::DISABLE_USER_ACTION
, true },
6547 // Legacy case (<M45): No disable reasons come in from Sync (see
6548 // crbug.com/484214). After installation, the reason should be set to
6549 // DISABLE_UNKNOWN_FROM_SYNC.
6550 { "Legacy", false, -1, Extension::DISABLE_UNKNOWN_FROM_SYNC
, true },
6551 // If the extension came in disabled due to a permissions increase, then the
6552 // user has *not* approved the permissions, and they shouldn't be granted.
6554 { "PermissionsIncrease", false, Extension::DISABLE_PERMISSIONS_INCREASE
,
6555 Extension::DISABLE_PERMISSIONS_INCREASE
, false },
6558 for (const TestCase
& test_case
: test_cases
) {
6559 SCOPED_TRACE(test_case
.name
);
6561 sync_pb::EntitySpecifics specifics
;
6562 sync_pb::ExtensionSpecifics
* ext_specifics
= specifics
.mutable_extension();
6563 ext_specifics
->set_id(good_crx
);
6564 ext_specifics
->set_version(base::Version("1").GetString());
6565 ext_specifics
->set_enabled(test_case
.sync_enabled
);
6566 if (test_case
.sync_disable_reasons
!= -1)
6567 ext_specifics
->set_disable_reasons(test_case
.sync_disable_reasons
);
6569 syncer::SyncData sync_data
=
6570 syncer::SyncData::CreateLocalData(good_crx
, "Name", specifics
);
6571 syncer::SyncChange
sync_change(FROM_HERE
,
6572 syncer::SyncChange::ACTION_UPDATE
,
6574 syncer::SyncChangeList
list(1, sync_change
);
6575 extension_sync_service()->ProcessSyncChanges(FROM_HERE
, list
);
6577 ASSERT_TRUE(service()->pending_extension_manager()->IsIdPending(good_crx
));
6578 UpdateExtension(good_crx
, path
, test_case
.sync_enabled
? ENABLED
6580 EXPECT_EQ(test_case
.expect_disable_reasons
,
6581 prefs
->GetDisableReasons(good_crx
));
6582 scoped_refptr
<PermissionSet
> permissions(
6583 prefs
->GetGrantedPermissions(good_crx
));
6584 EXPECT_EQ(test_case
.expect_permissions_granted
, !permissions
->IsEmpty());
6585 ASSERT_FALSE(service()->pending_extension_manager()->IsIdPending(good_crx
));
6587 // Remove the extension again, so we can install it again for the next case.
6588 UninstallExtension(good_crx
, false,
6589 test_case
.sync_enabled
? Extension::ENABLED
6590 : Extension::DISABLED
);
6594 TEST_F(ExtensionServiceTest
, ProcessSyncDataTerminatedExtension
) {
6595 InitializeExtensionServiceWithUpdater();
6596 syncer::FakeSyncChangeProcessor processor
;
6597 extension_sync_service()->MergeDataAndStartSyncing(
6599 syncer::SyncDataList(),
6600 scoped_ptr
<syncer::SyncChangeProcessor
>(
6601 new syncer::FakeSyncChangeProcessor
),
6602 scoped_ptr
<syncer::SyncErrorFactory
>(new syncer::SyncErrorFactoryMock()));
6604 InstallCRX(data_dir().AppendASCII("good.crx"), INSTALL_NEW
);
6605 TerminateExtension(good_crx
);
6606 EXPECT_TRUE(service()->IsExtensionEnabled(good_crx
));
6607 EXPECT_FALSE(extensions::util::IsIncognitoEnabled(good_crx
, profile()));
6609 sync_pb::EntitySpecifics specifics
;
6610 sync_pb::ExtensionSpecifics
* ext_specifics
= specifics
.mutable_extension();
6611 ext_specifics
->set_id(good_crx
);
6612 ext_specifics
->set_version(
6613 service()->GetInstalledExtension(good_crx
)->version()->GetString());
6614 ext_specifics
->set_enabled(false);
6615 ext_specifics
->set_incognito_enabled(true);
6616 syncer::SyncData sync_data
=
6617 syncer::SyncData::CreateLocalData(good_crx
, "Name", specifics
);
6618 syncer::SyncChange
sync_change(FROM_HERE
,
6619 syncer::SyncChange::ACTION_UPDATE
,
6621 syncer::SyncChangeList
list(1);
6622 list
[0] = sync_change
;
6624 extension_sync_service()->ProcessSyncChanges(FROM_HERE
, list
);
6625 EXPECT_FALSE(service()->IsExtensionEnabled(good_crx
));
6626 EXPECT_TRUE(extensions::util::IsIncognitoEnabled(good_crx
, profile()));
6628 EXPECT_FALSE(service()->pending_extension_manager()->IsIdPending(good_crx
));
6631 TEST_F(ExtensionServiceTest
, ProcessSyncDataVersionCheck
) {
6632 InitializeExtensionServiceWithUpdater();
6633 syncer::FakeSyncChangeProcessor processor
;
6634 extension_sync_service()->MergeDataAndStartSyncing(
6636 syncer::SyncDataList(),
6637 scoped_ptr
<syncer::SyncChangeProcessor
>(
6638 new syncer::FakeSyncChangeProcessor
),
6639 scoped_ptr
<syncer::SyncErrorFactory
>(new syncer::SyncErrorFactoryMock()));
6641 InstallCRX(data_dir().AppendASCII("good.crx"), INSTALL_NEW
);
6642 EXPECT_TRUE(service()->IsExtensionEnabled(good_crx
));
6643 EXPECT_FALSE(extensions::util::IsIncognitoEnabled(good_crx
, profile()));
6645 sync_pb::EntitySpecifics specifics
;
6646 sync_pb::ExtensionSpecifics
* ext_specifics
= specifics
.mutable_extension();
6647 ext_specifics
->set_id(good_crx
);
6648 ext_specifics
->set_enabled(true);
6650 const base::Version installed_version
=
6651 *service()->GetInstalledExtension(good_crx
)->version();
6654 ext_specifics
->set_version(installed_version
.GetString());
6655 syncer::SyncData sync_data
=
6656 syncer::SyncData::CreateLocalData(good_crx
, "Name", specifics
);
6657 syncer::SyncChange
sync_change(FROM_HERE
,
6658 syncer::SyncChange::ACTION_UPDATE
,
6660 syncer::SyncChangeList
list(1, sync_change
);
6662 // Should do nothing if extension version == sync version.
6663 extension_sync_service()->ProcessSyncChanges(FROM_HERE
, list
);
6664 EXPECT_FALSE(service()->updater()->WillCheckSoon());
6665 // Make sure the version we'll send back to sync didn't change.
6666 syncer::SyncDataList data
=
6667 extension_sync_service()->GetAllSyncData(syncer::EXTENSIONS
);
6668 ASSERT_EQ(1u, data
.size());
6669 scoped_ptr
<ExtensionSyncData
> extension_data
=
6670 ExtensionSyncData::CreateFromSyncData(data
[0]);
6671 ASSERT_TRUE(extension_data
);
6672 EXPECT_TRUE(installed_version
.Equals(extension_data
->version()));
6675 // Should do nothing if extension version > sync version.
6677 ext_specifics
->set_version("0.0.0.0");
6678 syncer::SyncData sync_data
=
6679 syncer::SyncData::CreateLocalData(good_crx
, "Name", specifics
);
6680 syncer::SyncChange
sync_change(FROM_HERE
,
6681 syncer::SyncChange::ACTION_UPDATE
,
6683 syncer::SyncChangeList
list(1, sync_change
);
6685 extension_sync_service()->ProcessSyncChanges(FROM_HERE
, list
);
6686 EXPECT_FALSE(service()->updater()->WillCheckSoon());
6687 // Make sure the version we'll send back to sync didn't change.
6688 syncer::SyncDataList data
=
6689 extension_sync_service()->GetAllSyncData(syncer::EXTENSIONS
);
6690 ASSERT_EQ(1u, data
.size());
6691 scoped_ptr
<ExtensionSyncData
> extension_data
=
6692 ExtensionSyncData::CreateFromSyncData(data
[0]);
6693 ASSERT_TRUE(extension_data
);
6694 EXPECT_TRUE(installed_version
.Equals(extension_data
->version()));
6697 // Should kick off an update if extension version < sync version.
6699 const base::Version
new_version("9.9.9.9");
6700 ext_specifics
->set_version(new_version
.GetString());
6701 syncer::SyncData sync_data
=
6702 syncer::SyncData::CreateLocalData(good_crx
, "Name", specifics
);
6703 syncer::SyncChange
sync_change(FROM_HERE
,
6704 syncer::SyncChange::ACTION_UPDATE
,
6706 syncer::SyncChangeList
list(1, sync_change
);
6708 extension_sync_service()->ProcessSyncChanges(FROM_HERE
, list
);
6709 EXPECT_TRUE(service()->updater()->WillCheckSoon());
6710 // Make sure that we'll send the NEW version back to sync, even though we
6711 // haven't actually updated yet. This is to prevent the data in sync from
6712 // flip-flopping back and forth until all clients are up to date.
6713 syncer::SyncDataList data
=
6714 extension_sync_service()->GetAllSyncData(syncer::EXTENSIONS
);
6715 ASSERT_EQ(1u, data
.size());
6716 scoped_ptr
<ExtensionSyncData
> extension_data
=
6717 ExtensionSyncData::CreateFromSyncData(data
[0]);
6718 ASSERT_TRUE(extension_data
);
6719 EXPECT_TRUE(new_version
.Equals(extension_data
->version()));
6722 EXPECT_FALSE(service()->pending_extension_manager()->IsIdPending(good_crx
));
6725 TEST_F(ExtensionServiceTest
, ProcessSyncDataNotInstalled
) {
6726 InitializeExtensionServiceWithUpdater();
6727 syncer::FakeSyncChangeProcessor processor
;
6728 extension_sync_service()->MergeDataAndStartSyncing(
6730 syncer::SyncDataList(),
6731 scoped_ptr
<syncer::SyncChangeProcessor
>(
6732 new syncer::FakeSyncChangeProcessor
),
6733 scoped_ptr
<syncer::SyncErrorFactory
>(new syncer::SyncErrorFactoryMock()));
6735 sync_pb::EntitySpecifics specifics
;
6736 sync_pb::ExtensionSpecifics
* ext_specifics
= specifics
.mutable_extension();
6737 ext_specifics
->set_id(good_crx
);
6738 ext_specifics
->set_enabled(false);
6739 ext_specifics
->set_incognito_enabled(true);
6740 ext_specifics
->set_update_url("http://www.google.com/");
6741 ext_specifics
->set_version("1.2.3.4");
6742 syncer::SyncData sync_data
=
6743 syncer::SyncData::CreateLocalData(good_crx
, "Name", specifics
);
6744 syncer::SyncChange
sync_change(FROM_HERE
,
6745 syncer::SyncChange::ACTION_UPDATE
,
6747 syncer::SyncChangeList
list(1);
6748 list
[0] = sync_change
;
6750 EXPECT_TRUE(service()->IsExtensionEnabled(good_crx
));
6751 EXPECT_FALSE(extensions::util::IsIncognitoEnabled(good_crx
, profile()));
6752 extension_sync_service()->ProcessSyncChanges(FROM_HERE
, list
);
6753 EXPECT_TRUE(service()->updater()->WillCheckSoon());
6754 EXPECT_FALSE(service()->IsExtensionEnabled(good_crx
));
6755 EXPECT_TRUE(extensions::util::IsIncognitoEnabled(good_crx
, profile()));
6757 const extensions::PendingExtensionInfo
* info
;
6759 (info
= service()->pending_extension_manager()->GetById(good_crx
)));
6760 EXPECT_EQ(ext_specifics
->update_url(), info
->update_url().spec());
6761 EXPECT_TRUE(info
->is_from_sync());
6762 EXPECT_EQ(Manifest::INTERNAL
, info
->install_source());
6763 // TODO(akalin): Figure out a way to test |info.ShouldAllowInstall()|.
6766 TEST_F(ExtensionServiceTest
, ProcessSyncDataEnableDisable
) {
6767 InitializeEmptyExtensionService();
6768 extension_sync_service()->MergeDataAndStartSyncing(
6770 syncer::SyncDataList(),
6771 scoped_ptr
<syncer::SyncChangeProcessor
>(
6772 new syncer::FakeSyncChangeProcessor
),
6773 scoped_ptr
<syncer::SyncErrorFactory
>(new syncer::SyncErrorFactoryMock()));
6775 const ExtensionPrefs
* prefs
= ExtensionPrefs::Get(profile());
6778 const char* name
; // For failure output only.
6779 // Set of disable reasons before any Sync data comes in. If this is != 0,
6780 // the extension is disabled.
6781 int previous_disable_reasons
;
6782 bool sync_enable
; // The enabled flag coming in from Sync.
6783 // The disable reason(s) coming in from Sync, or -1 for "not set".
6784 int sync_disable_reasons
;
6785 // The expected set of disable reasons after processing the Sync update. The
6786 // extension should be disabled iff this is != 0.
6787 int expect_disable_reasons
;
6789 { "NopEnable", 0, true, 0, 0 },
6790 { "NopDisable", Extension::DISABLE_USER_ACTION
, false,
6791 Extension::DISABLE_USER_ACTION
, Extension::DISABLE_USER_ACTION
},
6792 { "Disable", 0, false, Extension::DISABLE_USER_ACTION
,
6793 Extension::DISABLE_USER_ACTION
},
6794 { "DisableLegacy", 0, false, -1, Extension::DISABLE_UNKNOWN_FROM_SYNC
},
6795 { "AddDisableReason", Extension::DISABLE_REMOTE_INSTALL
, false,
6796 Extension::DISABLE_REMOTE_INSTALL
| Extension::DISABLE_USER_ACTION
,
6797 Extension::DISABLE_REMOTE_INSTALL
| Extension::DISABLE_USER_ACTION
},
6798 { "AddDisableReasonLegacy", Extension::DISABLE_USER_ACTION
, false, -1,
6799 Extension::DISABLE_USER_ACTION
| Extension::DISABLE_UNKNOWN_FROM_SYNC
},
6800 { "RemoveDisableReason",
6801 Extension::DISABLE_REMOTE_INSTALL
| Extension::DISABLE_USER_ACTION
, false,
6802 Extension::DISABLE_USER_ACTION
, Extension::DISABLE_USER_ACTION
},
6803 { "Enable", Extension::DISABLE_USER_ACTION
, true, 0, 0 },
6804 { "EnableLegacy", Extension::DISABLE_USER_ACTION
, true, -1, 0 },
6807 for (const TestCase
& test_case
: test_cases
) {
6808 SCOPED_TRACE(test_case
.name
);
6811 std::string version
;
6812 // Don't keep |extension| around longer than necessary.
6814 const Extension
* extension
=
6815 InstallCRX(data_dir().AppendASCII("good.crx"), INSTALL_NEW
);
6816 // The extension should now be installed and enabled.
6817 ASSERT_TRUE(extension
);
6818 id
= extension
->id();
6819 version
= extension
->VersionString();
6821 ASSERT_TRUE(registry()->enabled_extensions().Contains(id
));
6823 // Disable it if the test case says so.
6824 if (test_case
.previous_disable_reasons
) {
6825 service()->DisableExtension(id
, test_case
.previous_disable_reasons
);
6826 ASSERT_TRUE(registry()->disabled_extensions().Contains(id
));
6829 // Now a sync update comes in.
6830 sync_pb::EntitySpecifics specifics
;
6831 sync_pb::ExtensionSpecifics
* ext_specifics
= specifics
.mutable_extension();
6832 ext_specifics
->set_id(id
);
6833 ext_specifics
->set_enabled(test_case
.sync_enable
);
6834 ext_specifics
->set_version(version
);
6835 if (test_case
.sync_disable_reasons
!= -1)
6836 ext_specifics
->set_disable_reasons(test_case
.sync_disable_reasons
);
6838 syncer::SyncData sync_data
=
6839 syncer::SyncData::CreateLocalData(good_crx
, "Name", specifics
);
6840 syncer::SyncChange
sync_change(FROM_HERE
,
6841 syncer::SyncChange::ACTION_UPDATE
,
6843 syncer::SyncChangeList
list(1, sync_change
);
6844 extension_sync_service()->ProcessSyncChanges(FROM_HERE
, list
);
6846 // Check expectations.
6847 const bool expect_enabled
= !test_case
.expect_disable_reasons
;
6848 EXPECT_EQ(expect_enabled
, service()->IsExtensionEnabled(id
));
6849 EXPECT_EQ(test_case
.expect_disable_reasons
, prefs
->GetDisableReasons(id
));
6851 // Remove the extension again, so we can install it again for the next case.
6852 UninstallExtension(id
, false, expect_enabled
? Extension::ENABLED
6853 : Extension::DISABLED
);
6857 TEST_F(ExtensionServiceTest
, ProcessSyncDataPermissionApproval
) {
6858 // This is the update URL specified in the test extension. Setting it here is
6859 // necessary to make it considered syncable.
6860 base::CommandLine::ForCurrentProcess()->AppendSwitchASCII(
6861 switches::kAppsGalleryUpdateURL
,
6862 "http://localhost/autoupdate/updates.xml");
6864 InitializeEmptyExtensionService();
6865 extension_sync_service()->MergeDataAndStartSyncing(
6867 syncer::SyncDataList(),
6868 scoped_ptr
<syncer::SyncChangeProcessor
>(
6869 new syncer::FakeSyncChangeProcessor
),
6870 scoped_ptr
<syncer::SyncErrorFactory
>(new syncer::SyncErrorFactoryMock()));
6872 const base::FilePath base_path
=
6873 data_dir().AppendASCII("permissions_increase");
6874 const base::FilePath pem_path
= base_path
.AppendASCII("permissions.pem");
6875 const base::FilePath path_v1
= base_path
.AppendASCII("v1");
6876 const base::FilePath path_v2
= base_path
.AppendASCII("v2");
6878 base::ScopedTempDir crx_dir
;
6879 ASSERT_TRUE(crx_dir
.CreateUniqueTempDir());
6880 const base::FilePath crx_path_v1
= crx_dir
.path().AppendASCII("temp1.crx");
6881 PackCRX(path_v1
, pem_path
, crx_path_v1
);
6882 const base::FilePath crx_path_v2
= crx_dir
.path().AppendASCII("temp2.crx");
6883 PackCRX(path_v2
, pem_path
, crx_path_v2
);
6885 const std::string
v1("1");
6886 const std::string
v2("2");
6888 const ExtensionPrefs
* prefs
= ExtensionPrefs::Get(profile());
6891 const char* name
; // For failure output only.
6892 const std::string
& sync_version
; // The version coming in from Sync.
6893 // The disable reason(s) coming in from Sync, or -1 for "not set".
6894 int sync_disable_reasons
;
6895 // Whether the extension's permissions should be auto-granted.
6896 bool expect_permissions_granted
;
6898 // Sync tells us to re-enable an older version. No permissions should be
6899 // granted, since we can't be sure if the user actually approved the right
6900 // set of permissions. Note that the extension will get disabled again the
6901 // next time ExtensionService::CheckPermissionsIncrease runs because of the
6902 // extra permissions.
6903 { "OldVersion", v1
, 0, false },
6904 // Legacy case: Sync tells us to re-enable the extension, but doesn't
6905 // specify disable reasons. No permissions should be granted.
6906 { "Legacy", v2
, -1, false },
6907 // Sync tells us to re-enable the extension and explicitly removes the
6908 // disable reasons. Now the extension should have its permissions granted.
6909 { "GrantPermissions", v2
, 0, true },
6912 for (const TestCase
& test_case
: test_cases
) {
6913 SCOPED_TRACE(test_case
.name
);
6916 // Don't keep |extension| around longer than necessary (it'll be destroyed
6917 // during updating).
6919 const Extension
* extension
= InstallCRX(crx_path_v1
, INSTALL_NEW
);
6920 // The extension should now be installed and enabled.
6921 ASSERT_TRUE(extension
);
6922 ASSERT_EQ(v1
, extension
->VersionString());
6923 id
= extension
->id();
6925 ASSERT_TRUE(registry()->enabled_extensions().Contains(id
));
6927 scoped_refptr
<PermissionSet
> granted_permissions_v1(
6928 prefs
->GetGrantedPermissions(id
));
6930 // Update to a new version with increased permissions.
6931 UpdateExtension(id
, crx_path_v2
, DISABLED
);
6933 // Now the extension should be disabled due to a permissions increase.
6935 const Extension
* extension
=
6936 registry()->disabled_extensions().GetByID(id
);
6937 ASSERT_TRUE(extension
);
6938 ASSERT_EQ(v2
, extension
->VersionString());
6940 ASSERT_TRUE(prefs
->HasDisableReason(
6941 id
, Extension::DISABLE_PERMISSIONS_INCREASE
));
6943 // No new permissions should have been granted.
6944 scoped_refptr
<PermissionSet
> granted_permissions_v2(
6945 prefs
->GetGrantedPermissions(id
));
6946 ASSERT_EQ(*granted_permissions_v1
, *granted_permissions_v2
);
6948 // Now a sync update comes in.
6949 sync_pb::EntitySpecifics specifics
;
6950 sync_pb::ExtensionSpecifics
* ext_specifics
= specifics
.mutable_extension();
6951 ext_specifics
->set_id(id
);
6952 ext_specifics
->set_enabled(true);
6953 ext_specifics
->set_version(test_case
.sync_version
);
6954 if (test_case
.sync_disable_reasons
!= -1)
6955 ext_specifics
->set_disable_reasons(test_case
.sync_disable_reasons
);
6957 syncer::SyncData sync_data
=
6958 syncer::SyncData::CreateLocalData(good_crx
, "Name", specifics
);
6959 syncer::SyncChange
sync_change(FROM_HERE
,
6960 syncer::SyncChange::ACTION_UPDATE
,
6962 syncer::SyncChangeList
list(1, sync_change
);
6963 extension_sync_service()->ProcessSyncChanges(FROM_HERE
, list
);
6965 // Check expectations.
6966 EXPECT_TRUE(registry()->GetExtensionById(id
, ExtensionRegistry::ENABLED
));
6967 scoped_refptr
<PermissionSet
> granted_permissions(
6968 prefs
->GetGrantedPermissions(id
));
6969 if (test_case
.expect_permissions_granted
) {
6970 scoped_refptr
<PermissionSet
> active_permissions(
6971 prefs
->GetActivePermissions(id
));
6972 EXPECT_EQ(*granted_permissions
, *active_permissions
);
6974 EXPECT_EQ(*granted_permissions
, *granted_permissions_v1
);
6976 EXPECT_EQ(Extension::DISABLE_NONE
, prefs
->GetDisableReasons(id
));
6978 // Remove the extension again, so we can install it again for the next case.
6979 UninstallExtension(id
, false);
6983 #if defined(ENABLE_SUPERVISED_USERS)
6984 class ScopedSupervisedUserServiceDelegate
6985 : public SupervisedUserService::Delegate
{
6987 explicit ScopedSupervisedUserServiceDelegate(SupervisedUserService
* service
)
6988 : service_(service
) {
6989 service_
->SetDelegate(this);
6991 ~ScopedSupervisedUserServiceDelegate() override
{
6992 service_
->SetDelegate(nullptr);
6995 // This prevents the legacy supervised user init code from running.
6996 bool SetActive(bool active
) override
{ return true; }
6999 SupervisedUserService
* service_
;
7002 class MockPermissionRequestCreator
: public PermissionRequestCreator
{
7004 MockPermissionRequestCreator() {}
7005 ~MockPermissionRequestCreator() override
{}
7007 bool IsEnabled() const override
{ return true; }
7009 void CreateURLAccessRequest(const GURL
& url_requested
,
7010 const SuccessCallback
& callback
) override
{
7014 MOCK_METHOD2(CreateExtensionUpdateRequest
,
7015 void(const std::string
& id
,
7016 const SupervisedUserService::SuccessCallback
& callback
));
7019 DISALLOW_COPY_AND_ASSIGN(MockPermissionRequestCreator
);
7022 TEST_F(ExtensionServiceTest
, SupervisedUserInstallOnlyAllowedByCustodian
) {
7023 ExtensionServiceInitParams params
= CreateDefaultInitParams();
7024 params
.profile_is_supervised
= true;
7025 InitializeExtensionService(params
);
7027 SupervisedUserService
* supervised_user_service
=
7028 SupervisedUserServiceFactory::GetForProfile(profile());
7029 ScopedSupervisedUserServiceDelegate
delegate(supervised_user_service
);
7030 supervised_user_service
->Init();
7032 base::FilePath path1
= data_dir().AppendASCII("good.crx");
7033 base::FilePath path2
= data_dir().AppendASCII("good2048.crx");
7034 const Extension
* extensions
[] = {
7035 InstallCRX(path1
, INSTALL_FAILED
),
7036 InstallCRX(path2
, INSTALL_NEW
, Extension::WAS_INSTALLED_BY_CUSTODIAN
)
7039 // Only the extension with the "installed by custodian" flag should have been
7040 // installed and enabled.
7041 EXPECT_FALSE(extensions
[0]);
7042 ASSERT_TRUE(extensions
[1]);
7043 EXPECT_TRUE(registry()->enabled_extensions().Contains(extensions
[1]->id()));
7046 TEST_F(ExtensionServiceTest
, SupervisedUserPreinstalledExtension
) {
7047 ExtensionServiceInitParams params
= CreateDefaultInitParams();
7048 // Do *not* set the profile to supervised here!
7049 InitializeExtensionService(params
);
7051 SupervisedUserService
* supervised_user_service
=
7052 SupervisedUserServiceFactory::GetForProfile(profile());
7053 ScopedSupervisedUserServiceDelegate
delegate(supervised_user_service
);
7054 supervised_user_service
->Init();
7056 // Install an extension.
7057 base::FilePath path
= data_dir().AppendASCII("good.crx");
7058 const Extension
* extension
= InstallCRX(path
, INSTALL_NEW
);
7059 std::string id
= extension
->id();
7061 // Now make the profile supervised.
7062 profile()->AsTestingProfile()->SetSupervisedUserId(
7063 supervised_users::kChildAccountSUID
);
7065 // The extension should not be enabled anymore.
7066 EXPECT_FALSE(registry()->enabled_extensions().Contains(id
));
7069 TEST_F(ExtensionServiceTest
, SupervisedUserUpdateWithoutPermissionIncrease
) {
7070 ExtensionServiceInitParams params
= CreateDefaultInitParams();
7071 params
.profile_is_supervised
= true;
7072 InitializeExtensionService(params
);
7074 SupervisedUserService
* supervised_user_service
=
7075 SupervisedUserServiceFactory::GetForProfile(profile());
7076 ScopedSupervisedUserServiceDelegate
delegate(supervised_user_service
);
7077 supervised_user_service
->Init();
7079 base::FilePath base_path
= data_dir().AppendASCII("autoupdate");
7080 base::FilePath pem_path
= base_path
.AppendASCII("key.pem");
7082 base::FilePath path
= base_path
.AppendASCII("v1");
7083 const Extension
* extension
=
7084 PackAndInstallCRX(path
, pem_path
, INSTALL_NEW
,
7085 Extension::WAS_INSTALLED_BY_CUSTODIAN
);
7086 // The extension must now be installed and enabled.
7087 ASSERT_TRUE(extension
);
7088 ASSERT_TRUE(registry()->enabled_extensions().Contains(extension
->id()));
7090 // Save the id, as the extension object will be destroyed during updating.
7091 std::string id
= extension
->id();
7093 std::string old_version
= extension
->VersionString();
7095 // Update to a new version.
7096 path
= base_path
.AppendASCII("v2");
7097 PackCRXAndUpdateExtension(id
, path
, pem_path
, ENABLED
);
7099 // The extension should still be there and enabled.
7100 extension
= registry()->enabled_extensions().GetByID(id
);
7101 ASSERT_TRUE(extension
);
7102 // The version should have changed.
7103 EXPECT_NE(extension
->VersionString(), old_version
);
7106 // Helper class that allows us to parameterize the UpdateWithPermissionIncrease
7107 // test over |bool need_custodian_approval|.
7108 class ExtensionServiceTestSupervisedUserPermissionIncrease
:
7109 public ExtensionServiceTest
, public testing::WithParamInterface
<bool> {};
7111 TEST_P(ExtensionServiceTestSupervisedUserPermissionIncrease
,
7112 UpdateWithPermissionIncrease
) {
7113 bool need_custodian_approval
= GetParam();
7114 base::FieldTrialList
field_trial_list(new base::MockEntropyProvider());
7115 base::FieldTrialList::CreateFieldTrial(
7116 "SupervisedUserExtensionPermissionIncrease",
7117 need_custodian_approval
? "NeedCustodianApproval" : "");
7119 ExtensionServiceInitParams params
= CreateDefaultInitParams();
7120 params
.profile_is_supervised
= true;
7121 InitializeExtensionService(params
);
7123 SupervisedUserService
* supervised_user_service
=
7124 SupervisedUserServiceFactory::GetForProfile(profile());
7125 ScopedSupervisedUserServiceDelegate
delegate(supervised_user_service
);
7126 supervised_user_service
->Init();
7127 MockPermissionRequestCreator
* creator
= new MockPermissionRequestCreator
;
7128 supervised_user_service
->AddPermissionRequestCreator(
7129 make_scoped_ptr(creator
));
7131 base::FilePath base_path
= data_dir().AppendASCII("permissions_increase");
7132 base::FilePath pem_path
= base_path
.AppendASCII("permissions.pem");
7134 base::FilePath path
= base_path
.AppendASCII("v1");
7135 const Extension
* extension
=
7136 PackAndInstallCRX(path
, pem_path
, INSTALL_NEW
,
7137 Extension::WAS_INSTALLED_BY_CUSTODIAN
);
7138 // The extension must now be installed and enabled.
7139 ASSERT_TRUE(extension
);
7140 ASSERT_TRUE(registry()->enabled_extensions().Contains(extension
->id()));
7142 // Save the id, as the extension object will be destroyed during updating.
7143 std::string id
= extension
->id();
7145 std::string old_version
= extension
->VersionString();
7147 // Update to a new version with increased permissions.
7148 EXPECT_CALL(*creator
, CreateExtensionUpdateRequest(id
+ ":2", testing::_
))
7149 .Times(need_custodian_approval
? 1 : 0);
7150 path
= base_path
.AppendASCII("v2");
7151 PackCRXAndUpdateExtension(id
, path
, pem_path
, DISABLED
);
7153 // The extension should still be there, but disabled.
7154 EXPECT_FALSE(registry()->enabled_extensions().Contains(id
));
7155 extension
= registry()->disabled_extensions().GetByID(id
);
7156 ASSERT_TRUE(extension
);
7157 // The version should have changed.
7158 EXPECT_NE(extension
->VersionString(), old_version
);
7160 INSTANTIATE_TEST_CASE_P(NeedCustodianApproval
,
7161 ExtensionServiceTestSupervisedUserPermissionIncrease
,
7164 TEST_F(ExtensionServiceTest
,
7165 SupervisedUserSyncUninstallByCustodianSkipsPolicy
) {
7166 InitializeEmptyExtensionService();
7167 extension_sync_service()->MergeDataAndStartSyncing(
7169 syncer::SyncDataList(),
7170 scoped_ptr
<syncer::SyncChangeProcessor
>(
7171 new syncer::FakeSyncChangeProcessor
),
7172 scoped_ptr
<syncer::SyncErrorFactory
>(new syncer::SyncErrorFactoryMock()));
7174 // Install two extensions.
7175 base::FilePath path1
= data_dir().AppendASCII("good.crx");
7176 base::FilePath path2
= data_dir().AppendASCII("good2048.crx");
7177 const Extension
* extensions
[] = {
7178 InstallCRX(path1
, INSTALL_NEW
),
7179 InstallCRX(path2
, INSTALL_NEW
, Extension::WAS_INSTALLED_BY_CUSTODIAN
)
7182 // Add a policy provider that will disallow any changes.
7183 extensions::TestManagementPolicyProvider
provider(
7184 extensions::TestManagementPolicyProvider::PROHIBIT_MODIFY_STATUS
);
7185 GetManagementPolicy()->RegisterProvider(&provider
);
7187 // Create a sync deletion for each extension.
7188 syncer::SyncChangeList change_list
;
7189 for (size_t i
= 0; i
< arraysize(extensions
); i
++) {
7190 const std::string
& id
= extensions
[i
]->id();
7191 sync_pb::EntitySpecifics specifics
;
7192 sync_pb::ExtensionSpecifics
* ext_specifics
= specifics
.mutable_extension();
7193 ext_specifics
->set_id(id
);
7194 ext_specifics
->set_version("1.0");
7195 ext_specifics
->set_installed_by_custodian(
7196 extensions
[i
]->was_installed_by_custodian());
7197 syncer::SyncData sync_data
=
7198 syncer::SyncData::CreateLocalData(id
, "Name", specifics
);
7199 change_list
.push_back(syncer::SyncChange(FROM_HERE
,
7200 syncer::SyncChange::ACTION_DELETE
,
7204 // Save the extension ids, as uninstalling destroys the Extension instance.
7205 std::string extension_ids
[] = {
7206 extensions
[0]->id(),
7210 // Now apply the uninstallations.
7211 extension_sync_service()->ProcessSyncChanges(FROM_HERE
, change_list
);
7213 // Uninstalling the extension without installed_by_custodian should have been
7214 // blocked by policy, so it should still be there.
7215 EXPECT_TRUE(registry()->enabled_extensions().Contains(extension_ids
[0]));
7217 // But installed_by_custodian should result in bypassing the policy check.
7219 registry()->GenerateInstalledExtensionsSet()->Contains(extension_ids
[1]));
7221 #endif // defined(ENABLE_SUPERVISED_USERS)
7223 TEST_F(ExtensionServiceTest
, InstallPriorityExternalUpdateUrl
) {
7224 InitializeEmptyExtensionService();
7226 base::FilePath path
= data_dir().AppendASCII("good.crx");
7227 InstallCRX(path
, INSTALL_NEW
);
7228 ValidatePrefKeyCount(1u);
7229 ValidateIntegerPref(good_crx
, "state", Extension::ENABLED
);
7230 ValidateIntegerPref(good_crx
, "location", Manifest::INTERNAL
);
7232 extensions::PendingExtensionManager
* pending
=
7233 service()->pending_extension_manager();
7234 EXPECT_FALSE(pending
->IsIdPending(kGoodId
));
7236 // Skip install when the location is the same.
7238 service()->OnExternalExtensionUpdateUrlFound(kGoodId
,
7240 GURL(kGoodUpdateURL
),
7242 Extension::NO_FLAGS
,
7244 EXPECT_FALSE(pending
->IsIdPending(kGoodId
));
7246 // Install when the location has higher priority.
7247 EXPECT_TRUE(service()->OnExternalExtensionUpdateUrlFound(
7250 GURL(kGoodUpdateURL
),
7251 Manifest::EXTERNAL_POLICY_DOWNLOAD
,
7252 Extension::NO_FLAGS
,
7254 EXPECT_TRUE(pending
->IsIdPending(kGoodId
));
7256 // Try the low priority again. Should be rejected.
7257 EXPECT_FALSE(service()->OnExternalExtensionUpdateUrlFound(
7260 GURL(kGoodUpdateURL
),
7261 Manifest::EXTERNAL_PREF_DOWNLOAD
,
7262 Extension::NO_FLAGS
,
7264 // The existing record should still be present in the pending extension
7266 EXPECT_TRUE(pending
->IsIdPending(kGoodId
));
7268 pending
->Remove(kGoodId
);
7270 // Skip install when the location has the same priority as the installed
7273 service()->OnExternalExtensionUpdateUrlFound(kGoodId
,
7275 GURL(kGoodUpdateURL
),
7277 Extension::NO_FLAGS
,
7280 EXPECT_FALSE(pending
->IsIdPending(kGoodId
));
7283 TEST_F(ExtensionServiceTest
, InstallPriorityExternalLocalFile
) {
7284 Version
older_version("0.1.0.0");
7285 Version
newer_version("2.0.0.0");
7287 // We don't want the extension to be installed. A path that doesn't
7288 // point to a valid CRX ensures this.
7289 const base::FilePath
kInvalidPathToCrx(FILE_PATH_LITERAL("invalid_path"));
7291 const int kCreationFlags
= 0;
7292 const bool kDontMarkAcknowledged
= false;
7293 const bool kDontInstallImmediately
= false;
7295 InitializeEmptyExtensionService();
7297 // The test below uses install source constants to test that
7298 // priority is enforced. It assumes a specific ranking of install
7299 // sources: Registry (EXTERNAL_REGISTRY) overrides external pref
7300 // (EXTERNAL_PREF), and external pref overrides user install (INTERNAL).
7301 // The following assertions verify these assumptions:
7302 ASSERT_EQ(Manifest::EXTERNAL_REGISTRY
,
7303 Manifest::GetHigherPriorityLocation(Manifest::EXTERNAL_REGISTRY
,
7304 Manifest::EXTERNAL_PREF
));
7305 ASSERT_EQ(Manifest::EXTERNAL_REGISTRY
,
7306 Manifest::GetHigherPriorityLocation(Manifest::EXTERNAL_REGISTRY
,
7307 Manifest::INTERNAL
));
7308 ASSERT_EQ(Manifest::EXTERNAL_PREF
,
7309 Manifest::GetHigherPriorityLocation(Manifest::EXTERNAL_PREF
,
7310 Manifest::INTERNAL
));
7312 extensions::PendingExtensionManager
* pending
=
7313 service()->pending_extension_manager();
7314 EXPECT_FALSE(pending
->IsIdPending(kGoodId
));
7317 // Simulate an external source adding the extension as INTERNAL.
7318 content::WindowedNotificationObserver
observer(
7319 extensions::NOTIFICATION_CRX_INSTALLER_DONE
,
7320 content::NotificationService::AllSources());
7321 EXPECT_TRUE(service()->OnExternalExtensionFileFound(
7327 kDontMarkAcknowledged
,
7328 kDontInstallImmediately
));
7329 EXPECT_TRUE(pending
->IsIdPending(kGoodId
));
7331 VerifyCrxInstall(kInvalidPathToCrx
, INSTALL_FAILED
);
7335 // Simulate an external source adding the extension as EXTERNAL_PREF.
7336 content::WindowedNotificationObserver
observer(
7337 extensions::NOTIFICATION_CRX_INSTALLER_DONE
,
7338 content::NotificationService::AllSources());
7339 EXPECT_TRUE(service()->OnExternalExtensionFileFound(
7343 Manifest::EXTERNAL_PREF
,
7345 kDontMarkAcknowledged
,
7346 kDontInstallImmediately
));
7347 EXPECT_TRUE(pending
->IsIdPending(kGoodId
));
7349 VerifyCrxInstall(kInvalidPathToCrx
, INSTALL_FAILED
);
7352 // Simulate an external source adding as EXTERNAL_PREF again.
7353 // This is rejected because the version and the location are the same as
7354 // the previous installation, which is still pending.
7355 EXPECT_FALSE(service()->OnExternalExtensionFileFound(
7359 Manifest::EXTERNAL_PREF
,
7361 kDontMarkAcknowledged
,
7362 kDontInstallImmediately
));
7363 EXPECT_TRUE(pending
->IsIdPending(kGoodId
));
7365 // Try INTERNAL again. Should fail.
7366 EXPECT_FALSE(service()->OnExternalExtensionFileFound(
7372 kDontMarkAcknowledged
,
7373 kDontInstallImmediately
));
7374 EXPECT_TRUE(pending
->IsIdPending(kGoodId
));
7377 // Now the registry adds the extension.
7378 content::WindowedNotificationObserver
observer(
7379 extensions::NOTIFICATION_CRX_INSTALLER_DONE
,
7380 content::NotificationService::AllSources());
7381 EXPECT_TRUE(service()->OnExternalExtensionFileFound(
7385 Manifest::EXTERNAL_REGISTRY
,
7387 kDontMarkAcknowledged
,
7388 kDontInstallImmediately
));
7389 EXPECT_TRUE(pending
->IsIdPending(kGoodId
));
7391 VerifyCrxInstall(kInvalidPathToCrx
, INSTALL_FAILED
);
7394 // Registry outranks both external pref and internal, so both fail.
7395 EXPECT_FALSE(service()->OnExternalExtensionFileFound(
7399 Manifest::EXTERNAL_PREF
,
7401 kDontMarkAcknowledged
,
7402 kDontInstallImmediately
));
7403 EXPECT_TRUE(pending
->IsIdPending(kGoodId
));
7405 EXPECT_FALSE(service()->OnExternalExtensionFileFound(
7411 kDontMarkAcknowledged
,
7412 kDontInstallImmediately
));
7413 EXPECT_TRUE(pending
->IsIdPending(kGoodId
));
7415 pending
->Remove(kGoodId
);
7417 // Install the extension.
7418 base::FilePath path
= data_dir().AppendASCII("good.crx");
7419 const Extension
* ext
= InstallCRX(path
, INSTALL_NEW
);
7420 ValidatePrefKeyCount(1u);
7421 ValidateIntegerPref(good_crx
, "state", Extension::ENABLED
);
7422 ValidateIntegerPref(good_crx
, "location", Manifest::INTERNAL
);
7424 // Now test the logic of OnExternalExtensionFileFound() when the extension
7425 // being added is already installed.
7427 // Tests assume |older_version| is less than the installed version, and
7428 // |newer_version| is greater. Verify this:
7429 ASSERT_TRUE(older_version
.IsOlderThan(ext
->VersionString()));
7430 ASSERT_TRUE(ext
->version()->IsOlderThan(newer_version
.GetString()));
7432 // An external install for the same location should fail if the version is
7433 // older, or the same, and succeed if the version is newer.
7435 // Older than the installed version...
7436 EXPECT_FALSE(service()->OnExternalExtensionFileFound(
7442 kDontMarkAcknowledged
,
7443 kDontInstallImmediately
));
7444 EXPECT_FALSE(pending
->IsIdPending(kGoodId
));
7446 // Same version as the installed version...
7447 EXPECT_FALSE(service()->OnExternalExtensionFileFound(
7453 kDontMarkAcknowledged
,
7454 kDontInstallImmediately
));
7455 EXPECT_FALSE(pending
->IsIdPending(kGoodId
));
7457 // Newer than the installed version...
7458 EXPECT_TRUE(service()->OnExternalExtensionFileFound(
7464 kDontMarkAcknowledged
,
7465 kDontInstallImmediately
));
7466 EXPECT_TRUE(pending
->IsIdPending(kGoodId
));
7468 // An external install for a higher priority install source should succeed
7469 // if the version is greater. |older_version| is not...
7470 EXPECT_FALSE(service()->OnExternalExtensionFileFound(
7474 Manifest::EXTERNAL_PREF
,
7476 kDontMarkAcknowledged
,
7477 kDontInstallImmediately
));
7478 EXPECT_TRUE(pending
->IsIdPending(kGoodId
));
7480 // |newer_version| is newer.
7481 EXPECT_TRUE(service()->OnExternalExtensionFileFound(
7485 Manifest::EXTERNAL_PREF
,
7487 kDontMarkAcknowledged
,
7488 kDontInstallImmediately
));
7489 EXPECT_TRUE(pending
->IsIdPending(kGoodId
));
7491 // An external install for an even higher priority install source should
7492 // succeed if the version is greater.
7493 EXPECT_TRUE(service()->OnExternalExtensionFileFound(
7497 Manifest::EXTERNAL_REGISTRY
,
7499 kDontMarkAcknowledged
,
7500 kDontInstallImmediately
));
7501 EXPECT_TRUE(pending
->IsIdPending(kGoodId
));
7503 // Because EXTERNAL_PREF is a lower priority source than EXTERNAL_REGISTRY,
7504 // adding from external pref will now fail.
7505 EXPECT_FALSE(service()->OnExternalExtensionFileFound(
7509 Manifest::EXTERNAL_PREF
,
7511 kDontMarkAcknowledged
,
7512 kDontInstallImmediately
));
7513 EXPECT_TRUE(pending
->IsIdPending(kGoodId
));
7516 TEST_F(ExtensionServiceTest
, ConcurrentExternalLocalFile
) {
7517 Version
kVersion123("1.2.3");
7518 Version
kVersion124("1.2.4");
7519 Version
kVersion125("1.2.5");
7520 const base::FilePath
kInvalidPathToCrx(FILE_PATH_LITERAL("invalid_path"));
7521 const int kCreationFlags
= 0;
7522 const bool kDontMarkAcknowledged
= false;
7523 const bool kDontInstallImmediately
= false;
7525 InitializeEmptyExtensionService();
7527 extensions::PendingExtensionManager
* pending
=
7528 service()->pending_extension_manager();
7529 EXPECT_FALSE(pending
->IsIdPending(kGoodId
));
7531 // An external provider starts installing from a local crx.
7532 EXPECT_TRUE(service()->OnExternalExtensionFileFound(
7536 Manifest::EXTERNAL_PREF
,
7538 kDontMarkAcknowledged
,
7539 kDontInstallImmediately
));
7540 const extensions::PendingExtensionInfo
* info
;
7541 EXPECT_TRUE((info
= pending
->GetById(kGoodId
)));
7542 EXPECT_TRUE(info
->version().IsValid());
7543 EXPECT_TRUE(info
->version().Equals(kVersion123
));
7545 // Adding a newer version overrides the currently pending version.
7546 EXPECT_TRUE(service()->OnExternalExtensionFileFound(
7550 Manifest::EXTERNAL_PREF
,
7552 kDontMarkAcknowledged
,
7553 kDontInstallImmediately
));
7554 EXPECT_TRUE((info
= pending
->GetById(kGoodId
)));
7555 EXPECT_TRUE(info
->version().IsValid());
7556 EXPECT_TRUE(info
->version().Equals(kVersion124
));
7558 // Adding an older version fails.
7559 EXPECT_FALSE(service()->OnExternalExtensionFileFound(
7563 Manifest::EXTERNAL_PREF
,
7565 kDontMarkAcknowledged
,
7566 kDontInstallImmediately
));
7567 EXPECT_TRUE((info
= pending
->GetById(kGoodId
)));
7568 EXPECT_TRUE(info
->version().IsValid());
7569 EXPECT_TRUE(info
->version().Equals(kVersion124
));
7571 // Adding an older version fails even when coming from a higher-priority
7573 EXPECT_FALSE(service()->OnExternalExtensionFileFound(
7577 Manifest::EXTERNAL_REGISTRY
,
7579 kDontMarkAcknowledged
,
7580 kDontInstallImmediately
));
7581 EXPECT_TRUE((info
= pending
->GetById(kGoodId
)));
7582 EXPECT_TRUE(info
->version().IsValid());
7583 EXPECT_TRUE(info
->version().Equals(kVersion124
));
7585 // Adding the latest version from the webstore overrides a specific version.
7586 GURL
kUpdateUrl("http://example.com/update");
7587 EXPECT_TRUE(service()->OnExternalExtensionUpdateUrlFound(
7591 Manifest::EXTERNAL_POLICY_DOWNLOAD
,
7592 Extension::NO_FLAGS
,
7594 EXPECT_TRUE((info
= pending
->GetById(kGoodId
)));
7595 EXPECT_FALSE(info
->version().IsValid());
7598 // This makes sure we can package and install CRX files that use whitelisted
7600 TEST_F(ExtensionServiceTest
, InstallWhitelistedExtension
) {
7601 std::string test_id
= "hdkklepkcpckhnpgjnmbdfhehckloojk";
7602 base::CommandLine::ForCurrentProcess()->AppendSwitchASCII(
7603 extensions::switches::kWhitelistedExtensionID
, test_id
);
7605 InitializeEmptyExtensionService();
7606 base::FilePath path
= data_dir().AppendASCII("permissions");
7607 base::FilePath pem_path
= path
7608 .AppendASCII("whitelist.pem");
7610 .AppendASCII("whitelist");
7612 const Extension
* extension
= PackAndInstallCRX(path
, pem_path
, INSTALL_NEW
);
7613 EXPECT_EQ(0u, GetErrors().size());
7614 ASSERT_EQ(1u, registry()->enabled_extensions().size());
7615 EXPECT_EQ(test_id
, extension
->id());
7618 // Test that when multiple sources try to install an extension,
7619 // we consistently choose the right one. To make tests easy to read,
7620 // methods that fake requests to install crx files in several ways
7622 class ExtensionSourcePriorityTest
: public ExtensionServiceTest
{
7624 void SetUp() override
{
7625 ExtensionServiceTest::SetUp();
7627 // All tests use a single extension. Put the id and path in member vars
7628 // that all methods can read.
7630 crx_path_
= data_dir().AppendASCII("good.crx");
7633 // Fake an external source adding a URL to fetch an extension from.
7634 bool AddPendingExternalPrefUrl() {
7635 return service()->pending_extension_manager()->AddFromExternalUpdateUrl(
7639 Manifest::EXTERNAL_PREF_DOWNLOAD
,
7640 Extension::NO_FLAGS
,
7644 // Fake an external file from external_extensions.json.
7645 bool AddPendingExternalPrefFileInstall() {
7646 Version
version("1.0.0.0");
7648 return service()->OnExternalExtensionFileFound(crx_id_
,
7651 Manifest::EXTERNAL_PREF
,
7652 Extension::NO_FLAGS
,
7657 // Fake a request from sync to install an extension.
7658 bool AddPendingSyncInstall() {
7659 return service()->pending_extension_manager()->AddFromSync(
7661 GURL(kGoodUpdateURL
),
7664 kGoodInstalledByCustodian
);
7667 // Fake a policy install.
7668 bool AddPendingPolicyInstall() {
7669 // Get path to the CRX with id |kGoodId|.
7670 return service()->OnExternalExtensionUpdateUrlFound(
7674 Manifest::EXTERNAL_POLICY_DOWNLOAD
,
7675 Extension::NO_FLAGS
,
7679 // Get the install source of a pending extension.
7680 Manifest::Location
GetPendingLocation() {
7681 const extensions::PendingExtensionInfo
* info
;
7683 (info
= service()->pending_extension_manager()->GetById(crx_id_
)));
7684 return info
->install_source();
7687 // Is an extension pending from a sync request?
7688 bool GetPendingIsFromSync() {
7689 const extensions::PendingExtensionInfo
* info
;
7691 (info
= service()->pending_extension_manager()->GetById(crx_id_
)));
7692 return info
->is_from_sync();
7695 // Is the CRX id these tests use pending?
7696 bool IsCrxPending() {
7697 return service()->pending_extension_manager()->IsIdPending(crx_id_
);
7700 // Is an extension installed?
7701 bool IsCrxInstalled() {
7702 return (service()->GetExtensionById(crx_id_
, true) != NULL
);
7706 // All tests use a single extension. Making the id and path member
7707 // vars avoids pasing the same argument to every method.
7708 std::string crx_id_
;
7709 base::FilePath crx_path_
;
7712 // Test that a pending request for installation of an external CRX from
7713 // an update URL overrides a pending request to install the same extension
7715 TEST_F(ExtensionSourcePriorityTest
, PendingExternalFileOverSync
) {
7716 InitializeEmptyExtensionService();
7718 ASSERT_FALSE(IsCrxInstalled());
7720 // Install pending extension from sync.
7721 content::WindowedNotificationObserver
observer(
7722 extensions::NOTIFICATION_CRX_INSTALLER_DONE
,
7723 content::NotificationService::AllSources());
7724 EXPECT_TRUE(AddPendingSyncInstall());
7725 ASSERT_EQ(Manifest::INTERNAL
, GetPendingLocation());
7726 EXPECT_TRUE(GetPendingIsFromSync());
7727 ASSERT_FALSE(IsCrxInstalled());
7729 // Install pending as external prefs json would.
7730 AddPendingExternalPrefFileInstall();
7731 ASSERT_EQ(Manifest::EXTERNAL_PREF
, GetPendingLocation());
7732 ASSERT_FALSE(IsCrxInstalled());
7734 // Another request from sync should be ignored.
7735 EXPECT_FALSE(AddPendingSyncInstall());
7736 ASSERT_EQ(Manifest::EXTERNAL_PREF
, GetPendingLocation());
7737 ASSERT_FALSE(IsCrxInstalled());
7740 VerifyCrxInstall(crx_path_
, INSTALL_NEW
);
7741 ASSERT_TRUE(IsCrxInstalled());
7744 // Test that an install of an external CRX from an update overrides
7745 // an install of the same extension from sync.
7746 TEST_F(ExtensionSourcePriorityTest
, PendingExternalUrlOverSync
) {
7747 InitializeEmptyExtensionService();
7748 ASSERT_FALSE(IsCrxInstalled());
7750 EXPECT_TRUE(AddPendingSyncInstall());
7751 ASSERT_EQ(Manifest::INTERNAL
, GetPendingLocation());
7752 EXPECT_TRUE(GetPendingIsFromSync());
7753 ASSERT_FALSE(IsCrxInstalled());
7755 ASSERT_TRUE(AddPendingExternalPrefUrl());
7756 ASSERT_EQ(Manifest::EXTERNAL_PREF_DOWNLOAD
, GetPendingLocation());
7757 EXPECT_FALSE(GetPendingIsFromSync());
7758 ASSERT_FALSE(IsCrxInstalled());
7760 EXPECT_FALSE(AddPendingSyncInstall());
7761 ASSERT_EQ(Manifest::EXTERNAL_PREF_DOWNLOAD
, GetPendingLocation());
7762 EXPECT_FALSE(GetPendingIsFromSync());
7763 ASSERT_FALSE(IsCrxInstalled());
7766 // Test that an external install request stops sync from installing
7767 // the same extension.
7768 TEST_F(ExtensionSourcePriorityTest
, InstallExternalBlocksSyncRequest
) {
7769 InitializeEmptyExtensionService();
7770 ASSERT_FALSE(IsCrxInstalled());
7772 // External prefs starts an install.
7773 AddPendingExternalPrefFileInstall();
7775 // Crx installer was made, but has not yet run.
7776 ASSERT_FALSE(IsCrxInstalled());
7778 // Before the CRX installer runs, Sync requests that the same extension
7779 // be installed. Should fail, because an external source is pending.
7780 content::WindowedNotificationObserver
observer(
7781 extensions::NOTIFICATION_CRX_INSTALLER_DONE
,
7782 content::NotificationService::AllSources());
7783 ASSERT_FALSE(AddPendingSyncInstall());
7785 // Wait for the external source to install.
7787 VerifyCrxInstall(crx_path_
, INSTALL_NEW
);
7788 ASSERT_TRUE(IsCrxInstalled());
7790 // Now that the extension is installed, sync request should fail
7791 // because the extension is already installed.
7792 ASSERT_FALSE(AddPendingSyncInstall());
7795 // Test that installing an external extension displays a GlobalError.
7796 TEST_F(ExtensionServiceTest
, ExternalInstallGlobalError
) {
7797 FeatureSwitch::ScopedOverride
prompt(
7798 FeatureSwitch::prompt_for_external_extensions(), true);
7800 InitializeEmptyExtensionService();
7801 MockExtensionProvider
* provider
=
7802 new MockExtensionProvider(service(), Manifest::EXTERNAL_PREF
);
7803 AddMockExternalProvider(provider
);
7805 service()->external_install_manager()->UpdateExternalExtensionAlert();
7806 // Should return false, meaning there aren't any extensions that the user
7807 // needs to know about.
7809 service()->external_install_manager()->HasExternalInstallError());
7811 // This is a normal extension, installed normally.
7812 // This should NOT trigger an alert.
7813 service()->set_extensions_enabled(true);
7814 base::FilePath path
= data_dir().AppendASCII("good.crx");
7815 InstallCRX(path
, INSTALL_NEW
);
7817 service()->CheckForExternalUpdates();
7818 base::RunLoop().RunUntilIdle();
7820 service()->external_install_manager()->HasExternalInstallError());
7822 // A hosted app, installed externally.
7823 // This should NOT trigger an alert.
7824 provider
->UpdateOrAddExtension(
7825 hosted_app
, "1.0.0.0", data_dir().AppendASCII("hosted_app.crx"));
7827 content::WindowedNotificationObserver
observer(
7828 extensions::NOTIFICATION_CRX_INSTALLER_DONE
,
7829 content::NotificationService::AllSources());
7830 service()->CheckForExternalUpdates();
7833 service()->external_install_manager()->HasExternalInstallError());
7835 // Another normal extension, but installed externally.
7836 // This SHOULD trigger an alert.
7837 provider
->UpdateOrAddExtension(
7838 page_action
, "1.0.0.0", data_dir().AppendASCII("page_action.crx"));
7840 content::WindowedNotificationObserver
observer2(
7841 extensions::NOTIFICATION_CRX_INSTALLER_DONE
,
7842 content::NotificationService::AllSources());
7843 service()->CheckForExternalUpdates();
7845 EXPECT_TRUE(service()->external_install_manager()->HasExternalInstallError());
7848 // Test that external extensions are initially disabled, and that enabling
7849 // them clears the prompt.
7850 TEST_F(ExtensionServiceTest
, ExternalInstallInitiallyDisabled
) {
7851 FeatureSwitch::ScopedOverride
prompt(
7852 FeatureSwitch::prompt_for_external_extensions(), true);
7854 InitializeEmptyExtensionService();
7855 MockExtensionProvider
* provider
=
7856 new MockExtensionProvider(service(), Manifest::EXTERNAL_PREF
);
7857 AddMockExternalProvider(provider
);
7859 provider
->UpdateOrAddExtension(
7860 page_action
, "1.0.0.0", data_dir().AppendASCII("page_action.crx"));
7862 content::WindowedNotificationObserver
observer(
7863 extensions::NOTIFICATION_CRX_INSTALLER_DONE
,
7864 content::NotificationService::AllSources());
7865 service()->CheckForExternalUpdates();
7867 EXPECT_TRUE(service()->external_install_manager()->HasExternalInstallError());
7868 EXPECT_FALSE(service()->IsExtensionEnabled(page_action
));
7870 const Extension
* extension
=
7871 registry()->disabled_extensions().GetByID(page_action
);
7872 EXPECT_TRUE(extension
);
7873 EXPECT_EQ(page_action
, extension
->id());
7875 service()->EnableExtension(page_action
);
7877 service()->external_install_manager()->HasExternalInstallError());
7878 EXPECT_TRUE(service()->IsExtensionEnabled(page_action
));
7881 // Test that installing multiple external extensions works.
7882 // Flaky on windows; http://crbug.com/295757 .
7883 // Causes race conditions with an in-process utility thread, so disable under
7884 // TSan: https://crbug.com/518957
7885 #if defined(OS_WIN) || defined(THREAD_SANITIZER)
7886 #define MAYBE_ExternalInstallMultiple DISABLED_ExternalInstallMultiple
7888 #define MAYBE_ExternalInstallMultiple ExternalInstallMultiple
7890 TEST_F(ExtensionServiceTest
, MAYBE_ExternalInstallMultiple
) {
7891 FeatureSwitch::ScopedOverride
prompt(
7892 FeatureSwitch::prompt_for_external_extensions(), true);
7894 InitializeEmptyExtensionService();
7895 MockExtensionProvider
* provider
=
7896 new MockExtensionProvider(service(), Manifest::EXTERNAL_PREF
);
7897 AddMockExternalProvider(provider
);
7899 provider
->UpdateOrAddExtension(
7900 page_action
, "1.0.0.0", data_dir().AppendASCII("page_action.crx"));
7901 provider
->UpdateOrAddExtension(
7902 good_crx
, "1.0.0.0", data_dir().AppendASCII("good.crx"));
7903 provider
->UpdateOrAddExtension(
7904 theme_crx
, "2.0", data_dir().AppendASCII("theme.crx"));
7907 content::WindowedNotificationObserver
observer(
7908 extensions::NOTIFICATION_CRX_INSTALLER_DONE
,
7909 base::Bind(&WaitForCountNotificationsCallback
, &count
));
7910 service()->CheckForExternalUpdates();
7912 EXPECT_TRUE(service()->external_install_manager()->HasExternalInstallError());
7913 EXPECT_FALSE(service()->IsExtensionEnabled(page_action
));
7914 EXPECT_FALSE(service()->IsExtensionEnabled(good_crx
));
7915 EXPECT_FALSE(service()->IsExtensionEnabled(theme_crx
));
7917 service()->EnableExtension(page_action
);
7918 EXPECT_TRUE(service()->external_install_manager()->HasExternalInstallError());
7919 EXPECT_FALSE(service()
7920 ->external_install_manager()
7921 ->HasExternalInstallBubbleForTesting());
7923 service()->EnableExtension(theme_crx
);
7924 EXPECT_TRUE(service()->external_install_manager()->HasExternalInstallError());
7925 EXPECT_FALSE(service()
7926 ->external_install_manager()
7927 ->HasExternalInstallBubbleForTesting());
7929 service()->EnableExtension(good_crx
);
7931 service()->external_install_manager()->HasExternalInstallError());
7932 EXPECT_FALSE(service()
7933 ->external_install_manager()
7934 ->HasExternalInstallBubbleForTesting());
7937 // Test that there is a bubble for external extensions that update
7938 // from the webstore if the profile is not new.
7939 TEST_F(ExtensionServiceTest
, ExternalInstallUpdatesFromWebstoreOldProfile
) {
7940 FeatureSwitch::ScopedOverride
prompt(
7941 FeatureSwitch::prompt_for_external_extensions(), true);
7943 // This sets up the ExtensionPrefs used by our ExtensionService to be
7945 ExtensionServiceInitParams params
= CreateDefaultInitParams();
7946 params
.is_first_run
= false;
7947 InitializeExtensionService(params
);
7949 base::FilePath crx_path
= temp_dir().path().AppendASCII("webstore.crx");
7950 PackCRX(data_dir().AppendASCII("update_from_webstore"),
7951 data_dir().AppendASCII("update_from_webstore.pem"),
7954 MockExtensionProvider
* provider
=
7955 new MockExtensionProvider(service(), Manifest::EXTERNAL_PREF
);
7956 AddMockExternalProvider(provider
);
7957 provider
->UpdateOrAddExtension(updates_from_webstore
, "1", crx_path
);
7959 content::WindowedNotificationObserver
observer(
7960 extensions::NOTIFICATION_CRX_INSTALLER_DONE
,
7961 content::NotificationService::AllSources());
7962 service()->CheckForExternalUpdates();
7964 EXPECT_TRUE(service()->external_install_manager()->HasExternalInstallError());
7965 EXPECT_TRUE(service()
7966 ->external_install_manager()
7967 ->HasExternalInstallBubbleForTesting());
7968 EXPECT_FALSE(service()->IsExtensionEnabled(updates_from_webstore
));
7971 // Test that there is no bubble for external extensions if the profile is new.
7972 TEST_F(ExtensionServiceTest
, ExternalInstallUpdatesFromWebstoreNewProfile
) {
7973 FeatureSwitch::ScopedOverride
prompt(
7974 FeatureSwitch::prompt_for_external_extensions(), true);
7976 InitializeEmptyExtensionService();
7978 base::FilePath crx_path
= temp_dir().path().AppendASCII("webstore.crx");
7979 PackCRX(data_dir().AppendASCII("update_from_webstore"),
7980 data_dir().AppendASCII("update_from_webstore.pem"),
7983 MockExtensionProvider
* provider
=
7984 new MockExtensionProvider(service(), Manifest::EXTERNAL_PREF
);
7985 AddMockExternalProvider(provider
);
7986 provider
->UpdateOrAddExtension(updates_from_webstore
, "1", crx_path
);
7988 content::WindowedNotificationObserver
observer(
7989 extensions::NOTIFICATION_CRX_INSTALLER_DONE
,
7990 content::NotificationService::AllSources());
7991 service()->CheckForExternalUpdates();
7993 EXPECT_TRUE(service()->external_install_manager()->HasExternalInstallError());
7994 EXPECT_FALSE(service()
7995 ->external_install_manager()
7996 ->HasExternalInstallBubbleForTesting());
7997 EXPECT_FALSE(service()->IsExtensionEnabled(updates_from_webstore
));
8000 // Test that clicking to remove the extension on an external install warning
8001 // uninstalls the extension.
8002 TEST_F(ExtensionServiceTest
, ExternalInstallClickToRemove
) {
8003 FeatureSwitch::ScopedOverride
prompt(
8004 FeatureSwitch::prompt_for_external_extensions(), true);
8006 ExtensionServiceInitParams params
= CreateDefaultInitParams();
8007 params
.is_first_run
= false;
8008 InitializeExtensionService(params
);
8010 base::FilePath crx_path
= temp_dir().path().AppendASCII("webstore.crx");
8011 PackCRX(data_dir().AppendASCII("update_from_webstore"),
8012 data_dir().AppendASCII("update_from_webstore.pem"),
8015 MockExtensionProvider
* provider
=
8016 new MockExtensionProvider(service_
, Manifest::EXTERNAL_PREF
);
8017 AddMockExternalProvider(provider
);
8018 provider
->UpdateOrAddExtension(updates_from_webstore
, "1", crx_path
);
8020 content::WindowedNotificationObserver
observer(
8021 extensions::NOTIFICATION_CRX_INSTALLER_DONE
,
8022 content::NotificationService::AllSources());
8023 service_
->CheckForExternalUpdates();
8025 EXPECT_TRUE(service_
->external_install_manager()->HasExternalInstallError());
8027 // We check both enabled and disabled, since these are "eventually exclusive"
8029 EXPECT_TRUE(registry()->disabled_extensions().GetByID(updates_from_webstore
));
8030 EXPECT_FALSE(registry()->enabled_extensions().GetByID(updates_from_webstore
));
8032 // Click the negative response.
8033 service_
->external_install_manager()->error_for_testing()->InstallUIAbort(
8035 // The Extension should be uninstalled.
8036 EXPECT_FALSE(registry()->GetExtensionById(updates_from_webstore
,
8037 ExtensionRegistry::EVERYTHING
));
8038 // The error should be removed.
8039 EXPECT_FALSE(service_
->external_install_manager()->HasExternalInstallError());
8042 // Test that clicking to keep the extension on an external install warning
8043 // re-enables the extension.
8044 TEST_F(ExtensionServiceTest
, ExternalInstallClickToKeep
) {
8045 FeatureSwitch::ScopedOverride
prompt(
8046 FeatureSwitch::prompt_for_external_extensions(), true);
8048 ExtensionServiceInitParams params
= CreateDefaultInitParams();
8049 params
.is_first_run
= false;
8050 InitializeExtensionService(params
);
8052 base::FilePath crx_path
= temp_dir().path().AppendASCII("webstore.crx");
8053 PackCRX(data_dir().AppendASCII("update_from_webstore"),
8054 data_dir().AppendASCII("update_from_webstore.pem"),
8057 MockExtensionProvider
* provider
=
8058 new MockExtensionProvider(service_
, Manifest::EXTERNAL_PREF
);
8059 AddMockExternalProvider(provider
);
8060 provider
->UpdateOrAddExtension(updates_from_webstore
, "1", crx_path
);
8062 content::WindowedNotificationObserver
observer(
8063 extensions::NOTIFICATION_CRX_INSTALLER_DONE
,
8064 content::NotificationService::AllSources());
8065 service_
->CheckForExternalUpdates();
8067 EXPECT_TRUE(service_
->external_install_manager()->HasExternalInstallError());
8069 // We check both enabled and disabled, since these are "eventually exclusive"
8071 EXPECT_TRUE(registry()->disabled_extensions().GetByID(updates_from_webstore
));
8072 EXPECT_FALSE(registry()->enabled_extensions().GetByID(updates_from_webstore
));
8074 // Accept the extension.
8075 service_
->external_install_manager()->error_for_testing()->InstallUIProceed();
8077 // It should be enabled again.
8078 EXPECT_TRUE(registry()->enabled_extensions().GetByID(updates_from_webstore
));
8080 registry()->disabled_extensions().GetByID(updates_from_webstore
));
8082 // The error should be removed.
8083 EXPECT_FALSE(service_
->external_install_manager()->HasExternalInstallError());
8086 TEST_F(ExtensionServiceTest
, InstallBlacklistedExtension
) {
8087 InitializeEmptyExtensionService();
8089 scoped_refptr
<Extension
> extension
= extensions::ExtensionBuilder()
8090 .SetManifest(extensions::DictionaryBuilder()
8091 .Set("name", "extension")
8092 .Set("version", "1.0")
8093 .Set("manifest_version", 2).Build())
8095 ASSERT_TRUE(extension
.get());
8096 const std::string
& id
= extension
->id();
8098 std::set
<std::string
> id_set
;
8100 extensions::ExtensionNotificationObserver
notifications(
8101 content::NotificationService::AllSources(), id_set
);
8103 // Installation should be allowed but the extension should never have been
8104 // loaded and it should be blacklisted in prefs.
8105 service()->OnExtensionInstalled(
8107 syncer::StringOrdinal(),
8108 (extensions::kInstallFlagIsBlacklistedForMalware
|
8109 extensions::kInstallFlagInstallImmediately
));
8110 base::RunLoop().RunUntilIdle();
8112 // Extension was installed but not loaded.
8113 EXPECT_TRUE(notifications
.CheckNotifications(
8114 extensions::NOTIFICATION_EXTENSION_WILL_BE_INSTALLED_DEPRECATED
));
8115 EXPECT_TRUE(service()->GetInstalledExtension(id
));
8117 EXPECT_FALSE(registry()->enabled_extensions().Contains(id
));
8118 EXPECT_TRUE(registry()->blacklisted_extensions().Contains(id
));
8120 EXPECT_TRUE(ExtensionPrefs::Get(profile())->IsExtensionBlacklisted(id
));
8122 ExtensionPrefs::Get(profile())->IsBlacklistedExtensionAcknowledged(id
));
8125 // Tests a profile being destroyed correctly disables extensions.
8126 TEST_F(ExtensionServiceTest
, DestroyingProfileClearsExtensions
) {
8127 InitializeEmptyExtensionService();
8129 InstallCRX(data_dir().AppendASCII("good.crx"), INSTALL_NEW
);
8130 EXPECT_NE(UnloadedExtensionInfo::REASON_PROFILE_SHUTDOWN
, unloaded_reason_
);
8131 EXPECT_EQ(1u, registry()->enabled_extensions().size());
8132 EXPECT_EQ(0u, registry()->disabled_extensions().size());
8133 EXPECT_EQ(0u, registry()->terminated_extensions().size());
8134 EXPECT_EQ(0u, registry()->blacklisted_extensions().size());
8136 service()->Observe(chrome::NOTIFICATION_PROFILE_DESTRUCTION_STARTED
,
8137 content::Source
<Profile
>(profile()),
8138 content::NotificationService::NoDetails());
8139 EXPECT_EQ(UnloadedExtensionInfo::REASON_PROFILE_SHUTDOWN
, unloaded_reason_
);
8140 EXPECT_EQ(0u, registry()->enabled_extensions().size());
8141 EXPECT_EQ(0u, registry()->disabled_extensions().size());
8142 EXPECT_EQ(0u, registry()->terminated_extensions().size());
8143 EXPECT_EQ(0u, registry()->blacklisted_extensions().size());