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

Side by Side Diff: chrome/browser/extensions/update_install_delayer_unittest.cc

Issue 1890163004: extensions: Abstract out install delay strategy (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: fix win,mac compile Created 4 years, 8 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
(Empty)
1 // Copyright 2016 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.
4
5 #include "chrome/browser/extensions/update_install_delayer.h"
6
7 #include <memory>
8
9 #include "base/command_line.h"
10 #include "base/memory/ptr_util.h"
11 #include "base/run_loop.h"
12 #include "chrome/browser/extensions/extension_service.h"
13 #include "chrome/browser/extensions/test_extension_system.h"
14 #include "chrome/test/base/testing_browser_process.h"
15 #include "chrome/test/base/testing_profile.h"
16 #include "chrome/test/base/testing_profile_manager.h"
17 #include "content/public/test/test_browser_thread_bundle.h"
18 #include "content/public/test/test_renderer_host.h"
19 #include "extensions/browser/event_router.h"
20 #include "extensions/browser/event_router_factory.h"
21 #include "extensions/browser/extension_host.h"
22 #include "extensions/browser/extension_prefs.h"
23 #include "extensions/browser/extension_registry.h"
24 #include "extensions/common/extension_builder.h"
25 #include "extensions/common/manifest_handlers/background_info.h"
26 #include "extensions/common/value_builder.h"
27 #include "testing/gtest/include/gtest/gtest.h"
28
29 #if defined(OS_CHROMEOS)
30 #include "chrome/browser/chromeos/login/users/fake_chrome_user_manager.h"
31 #include "chrome/browser/chromeos/login/users/scoped_user_manager_enabler.h"
32 #include "chrome/browser/chromeos/settings/cros_settings.h"
33 #include "chrome/browser/chromeos/settings/device_settings_service.h"
34 #endif
35
36 namespace extensions {
37
38 namespace {
39
40 const char kAppId[] = "aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa";
41 const char kPersistentExtensionId[] = "bbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbb";
42 const char kNonPersistentExtensionId[] = "cccccccccccccccccccccccccccccccc";
43
44 std::unique_ptr<KeyedService> BuildEventRouter(
45 content::BrowserContext* profile) {
46 return base::WrapUnique(new extensions::EventRouter(profile, nullptr));
47 }
48
49 scoped_refptr<Extension> CreateApp(const std::string& extension_id,
50 const std::string& version) {
51 scoped_refptr<Extension> app =
52 ExtensionBuilder()
53 .SetManifest(
54 DictionaryBuilder()
55 .Set("name", "Test app")
56 .Set("version", version)
57 .Set("manifest_version", 2)
58 .Set("app",
59 DictionaryBuilder()
60 .Set("background",
61 DictionaryBuilder()
62 .Set("scripts", ListBuilder()
63 .Append("background.js")
64 .Build())
65 .Build())
66 .Build())
67 .Build())
68 .SetID(extension_id)
69 .Build();
70 return app;
71 }
72
73 scoped_refptr<Extension> CreateExtension(
74 const std::string& extension_id,
75 const std::string& version,
76 bool persistent) {
77 scoped_refptr<Extension> extension =
78 ExtensionBuilder()
79 .SetManifest(
80 DictionaryBuilder()
81 .Set("name", "Test extension")
82 .Set("version", version)
83 .Set("manifest_version", 2)
84 .Set("background", DictionaryBuilder()
85 .Set("page", "background.html")
86 .SetBoolean("persistent", persistent)
87 .Build())
88 .Build())
89 .SetID(extension_id)
90 .Build();
91 return extension;
92 }
93
94 ExtensionHost* CreateHost(Profile* profile, const Extension* app) {
95 ProcessManager::Get(profile)->CreateBackgroundHost(
96 app, BackgroundInfo::GetBackgroundURL(app));
97 base::RunLoop().RunUntilIdle();
98
99 return ProcessManager::Get(profile)->GetBackgroundHostForExtension(app->id());
100 }
101
102 } // namespace
103
104 class UpdateInstallDelayerTest : public testing::Test {
105 public:
106 UpdateInstallDelayerTest() {
107 profile_manager_.reset(
108 new TestingProfileManager(TestingBrowserProcess::GetGlobal()));
109 }
110
111 // testing::Test
112 void SetUp() override {
113 // Must be called from ::testing::Test::SetUp.
114 ASSERT_TRUE(profile_manager_->SetUp());
115
116 const char kUserProfile[] = "profile1@example.com";
117 #if defined(OS_CHROMEOS)
118 const AccountId account_id(AccountId::FromUserEmail(kUserProfile));
119 // Needed to allow ChromeProcessManagerDelegate to allow background pages.
120 fake_user_manager_ = new chromeos::FakeChromeUserManager();
121 // Takes ownership of fake_user_manager_.
122 scoped_user_manager_enabler_.reset(
123 new chromeos::ScopedUserManagerEnabler(fake_user_manager_));
124 fake_user_manager_->AddUser(account_id);
125 fake_user_manager_->LoginUser(account_id);
126 #endif
127 profile_ =
128 profile_manager_->CreateTestingProfile(kUserProfile);
129 profile_manager_->SetLoggedIn(true);
130
131 TestExtensionSystem* test_extension_system =
132 static_cast<TestExtensionSystem*>(ExtensionSystem::Get(profile_));
133 service_ = test_extension_system->CreateExtensionService(
134 base::CommandLine::ForCurrentProcess(),
135 base::FilePath() /* install_directory */,
136 false /* autoupdate_enabled */);
137 registry_ = ExtensionRegistry::Get(profile_);
138
139 event_router_ = static_cast<EventRouter*>(
140 EventRouterFactory::GetInstance()->SetTestingFactoryAndUse(
141 profile_, &BuildEventRouter));
142
143 delayer_.reset(new UpdateInstallDelayer(service_));
144
145 new_app_ = CreateApp(kAppId, "2.0");
146 new_persistent_ = CreateExtension(kPersistentExtensionId, "2.0", true);
147 new_none_persistent_ =
148 CreateExtension(kNonPersistentExtensionId, "2.0", false);
149 }
150
151 void TearDown() override {
152 profile_manager_->DeleteAllTestingProfiles();
153 }
154
155 void AddExistingExtensions() {
156 scoped_refptr<Extension> app = CreateApp(kAppId, "1.0");
157 registry_->AddEnabled(app);
158
159 scoped_refptr<Extension> persistent =
160 CreateExtension(kPersistentExtensionId, "1.0", true);
161 registry_->AddEnabled(persistent);
162
163 scoped_refptr<Extension> none_persistent =
164 CreateExtension(kNonPersistentExtensionId, "1.0", false);
165 registry_->AddEnabled(none_persistent);
166 }
167
168 void MakeExtensionInUse(const std::string& extension_id) {
169 const Extension* const extension =
170 registry_->GetInstalledExtension(extension_id);
171 ASSERT_TRUE(!!extension);
172 ASSERT_TRUE(!!CreateHost(profile_, extension));
173 }
174
175 void MakeExtensionListenForOnUpdateAvailable(
176 const std::string& extension_id) {
177 const char kOnUpdateAvailableEvent[] = "runtime.onUpdateAvailable";
178 event_router_->AddEventListener(kOnUpdateAvailableEvent, NULL,
179 extension_id);
180 }
181
182 void Check(const Extension* extension,
183 bool is_in_use,
184 bool has_listener,
185 bool install_immediately,
186 InstallDelayer::Action expected_action) {
187 if (is_in_use)
188 MakeExtensionInUse(extension->id());
189 if (has_listener)
190 MakeExtensionListenForOnUpdateAvailable(extension->id());
191
192 EXPECT_EQ(expected_action, delayer()->GetDelayedInstallAction(
193 extension, install_immediately));
194 }
195
196 UpdateInstallDelayer* delayer() { return delayer_.get(); }
197 ExtensionService* service() { return service_; }
198
199 const Extension* new_app() const { return new_app_.get(); }
200 const Extension* new_persistent() const { return new_persistent_.get(); }
201 const Extension* new_none_persistent() const {
202 return new_none_persistent_.get();
203 }
204
205 private:
206 // Needed by extension system.
207 content::TestBrowserThreadBundle thread_bundle_;
208
209 // Needed to ensure we don't end up creating actual RenderViewHosts
210 // and RenderProcessHosts.
211 content::RenderViewHostTestEnabler render_view_host_test_enabler_;
212
213 TestingProfile* profile_ = nullptr;
214 std::unique_ptr<TestingProfileManager> profile_manager_;
215
216 ExtensionService* service_ = nullptr;
217 ExtensionRegistry* registry_ = nullptr;
218 EventRouter* event_router_ = nullptr;
219
220 #if defined(OS_CHROMEOS)
221 // Needed for creating ExtensionService.
222 chromeos::FakeChromeUserManager* fake_user_manager_ = nullptr;
223 std::unique_ptr<chromeos::ScopedUserManagerEnabler>
224 scoped_user_manager_enabler_;
225 #endif
226
227 std::unique_ptr<UpdateInstallDelayer> delayer_;
228
229 scoped_refptr<Extension> new_app_;
230 scoped_refptr<Extension> new_persistent_;
231 scoped_refptr<Extension> new_none_persistent_;
232
233 DISALLOW_COPY_AND_ASSIGN(UpdateInstallDelayerTest);
234 };
235
236 TEST_F(UpdateInstallDelayerTest, InstallOnServiceNotReady) {
237 ASSERT_FALSE(service()->is_ready());
238 Check(new_app(), false, false, false, InstallDelayer::INSTALL);
239 Check(new_persistent(), false, false, false, InstallDelayer::INSTALL);
240 Check(new_none_persistent(), false, false, false, InstallDelayer::INSTALL);
241 }
242
243 TEST_F(UpdateInstallDelayerTest, InstallOnFirstInstall) {
244 service()->Init();
245 Check(new_app(), false, false, false, InstallDelayer::INSTALL);
246 Check(new_persistent(), false, false, false, InstallDelayer::INSTALL);
247 Check(new_none_persistent(), false, false, false, InstallDelayer::INSTALL);
248 }
249
250 TEST_F(UpdateInstallDelayerTest, InstallOnInstallImmediately) {
251 service()->Init();
252 AddExistingExtensions();
253
254 const bool kInstallImmediately = true;
255 for (bool in_use : {false, true}) {
256 for (bool has_listener: {false, true}) {
257 Check(new_app(), in_use, has_listener, kInstallImmediately,
258 InstallDelayer::INSTALL);
259 Check(new_persistent(), in_use, has_listener, kInstallImmediately,
260 InstallDelayer::INSTALL);
261 Check(new_none_persistent(), in_use, has_listener, kInstallImmediately,
262 InstallDelayer::INSTALL);
263 }
264 }
265 }
266
267 TEST_F(UpdateInstallDelayerTest, DelayInstallWhenInUse) {
268 service()->Init();
269 AddExistingExtensions();
270
271 const bool kInUse = true;
272 const bool kDontInstallImmediately = false;
273 for (bool has_listener: {false, true}) {
274 Check(new_app(), kInUse, has_listener, kDontInstallImmediately,
275 InstallDelayer::DELAY);
276 Check(new_persistent(), kInUse, has_listener, kDontInstallImmediately,
277 has_listener ? InstallDelayer::DELAY : InstallDelayer::INSTALL);
278 Check(new_none_persistent(), kInUse, has_listener, kDontInstallImmediately,
279 InstallDelayer::DELAY);
280 }
281 }
282
283 } // namespace extensions
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698