OLD | NEW |
1 // Copyright 2013 The Chromium Authors. All rights reserved. | 1 // Copyright 2013 The Chromium Authors. All rights reserved. |
2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
4 | 4 |
5 #include "base/command_line.h" | 5 #include "base/command_line.h" |
6 #include "base/files/file_path.h" | 6 #include "base/files/file_path.h" |
7 #include "base/memory/scoped_ptr.h" | 7 #include "base/memory/scoped_ptr.h" |
8 #include "base/prefs/pref_registry_simple.h" | 8 #include "base/prefs/pref_registry_simple.h" |
9 #include "base/prefs/pref_service.h" | 9 #include "base/prefs/pref_service.h" |
10 #include "base/prefs/pref_service_factory.h" | 10 #include "base/prefs/pref_service_factory.h" |
(...skipping 20 matching lines...) Expand all Loading... |
31 local_state, | 31 local_state, |
32 profile_store.Pass(), | 32 profile_store.Pass(), |
33 keep_alive_service.Pass()), | 33 keep_alive_service.Pass()), |
34 showing_for_profile_(NULL) { | 34 showing_for_profile_(NULL) { |
35 } | 35 } |
36 | 36 |
37 Profile* showing_for_profile() const { | 37 Profile* showing_for_profile() const { |
38 return showing_for_profile_; | 38 return showing_for_profile_; |
39 } | 39 } |
40 | 40 |
41 void PerformStartupChecks(Profile* profile) { | 41 void HandleCommandLineFlags(Profile* profile) { |
42 AppListServiceImpl::PerformStartupChecks(profile); | 42 AppListServiceImpl::HandleCommandLineFlags(profile); |
43 } | 43 } |
44 | 44 |
45 virtual Profile* GetCurrentAppListProfile() OVERRIDE { | 45 virtual Profile* GetCurrentAppListProfile() OVERRIDE { |
46 // We don't return showing_for_profile_ here because that is only defined if | 46 // We don't return showing_for_profile_ here because that is only defined if |
47 // the app list is visible. | 47 // the app list is visible. |
48 return NULL; | 48 return NULL; |
49 } | 49 } |
50 | 50 |
51 virtual void CreateForProfile(Profile* requested_profile) OVERRIDE { | 51 virtual void CreateForProfile(Profile* requested_profile) OVERRIDE { |
52 } | 52 } |
53 | 53 |
54 virtual void ShowForProfile(Profile* requested_profile) OVERRIDE { | 54 virtual void ShowForProfile(Profile* requested_profile) OVERRIDE { |
55 showing_for_profile_ = requested_profile; | 55 showing_for_profile_ = requested_profile; |
56 RecordAppListLaunch(); | |
57 } | 56 } |
58 | 57 |
59 virtual void DismissAppList() OVERRIDE { | 58 virtual void DismissAppList() OVERRIDE { |
60 showing_for_profile_ = NULL; | 59 showing_for_profile_ = NULL; |
61 } | 60 } |
62 | 61 |
63 virtual bool IsAppListVisible() const OVERRIDE { | 62 virtual bool IsAppListVisible() const OVERRIDE { |
64 return !!showing_for_profile_; | 63 return !!showing_for_profile_; |
65 } | 64 } |
66 | 65 |
67 virtual gfx::NativeWindow GetAppListWindow() OVERRIDE { | 66 virtual gfx::NativeWindow GetAppListWindow() OVERRIDE { |
68 return NULL; | 67 return NULL; |
69 } | 68 } |
70 | 69 |
71 virtual AppListControllerDelegate* GetControllerDelegate() OVERRIDE { | 70 virtual AppListControllerDelegate* GetControllerDelegate() OVERRIDE { |
72 return NULL; | 71 return NULL; |
73 } | 72 } |
74 | 73 |
75 private: | 74 private: |
76 Profile* showing_for_profile_; | 75 Profile* showing_for_profile_; |
77 }; | 76 }; |
78 | 77 |
79 class AppListServiceUnitTest : public testing::Test { | 78 class AppListServiceUnitTest : public testing::Test { |
80 public: | 79 public: |
81 AppListServiceUnitTest() {} | |
82 | |
83 virtual void SetUp() OVERRIDE { | 80 virtual void SetUp() OVERRIDE { |
84 SetupWithCommandLine(CommandLine(CommandLine::NO_PROGRAM)); | 81 SetupWithCommandLine(CommandLine(CommandLine::NO_PROGRAM)); |
85 } | 82 } |
86 | 83 |
87 protected: | |
88 void SetupWithCommandLine(const CommandLine& command_line) { | 84 void SetupWithCommandLine(const CommandLine& command_line) { |
89 user_data_dir_ = base::FilePath(FILE_PATH_LITERAL("udd")); | 85 user_data_dir_ = base::FilePath(FILE_PATH_LITERAL("udd")); |
90 profile1_.reset( | 86 profile1_.reset( |
91 new FakeProfile("p1", user_data_dir_.AppendASCII("profile1"))); | 87 new FakeProfile("p1", user_data_dir_.AppendASCII("profile1"))); |
92 profile2_.reset( | 88 profile2_.reset( |
93 new FakeProfile("p2", user_data_dir_.AppendASCII("profile2"))); | 89 new FakeProfile("p2", user_data_dir_.AppendASCII("profile2"))); |
94 PrefRegistrySimple* pref_registry = new PrefRegistrySimple; | 90 PrefRegistrySimple* pref_registry = new PrefRegistrySimple; |
95 | 91 |
96 AppListService::RegisterPrefs(pref_registry); | 92 AppListService::RegisterPrefs(pref_registry); |
97 profiles::RegisterPrefs(pref_registry); | 93 profiles::RegisterPrefs(pref_registry); |
98 | 94 |
99 base::PrefServiceFactory factory; | 95 base::PrefServiceFactory factory; |
100 factory.set_user_prefs(make_scoped_refptr(new TestingPrefStore)); | 96 factory.set_user_prefs(make_scoped_refptr(new TestingPrefStore)); |
101 local_state_ = factory.Create(pref_registry).Pass(); | 97 local_state_ = factory.Create(pref_registry).Pass(); |
102 | 98 |
103 keep_alive_service_ = new FakeKeepAliveService; | 99 keep_alive_service_ = new FakeKeepAliveService; |
104 profile_store_ = new FakeProfileStore(user_data_dir_); | 100 profile_store_ = new FakeProfileStore(user_data_dir_); |
105 service_.reset(new TestingAppListServiceImpl( | 101 service_.reset(new TestingAppListServiceImpl( |
106 command_line, | 102 command_line, |
107 local_state_.get(), | 103 local_state_.get(), |
108 scoped_ptr<ProfileStore>(profile_store_), | 104 scoped_ptr<ProfileStore>(profile_store_), |
109 scoped_ptr<KeepAliveService>(keep_alive_service_))); | 105 scoped_ptr<KeepAliveService>(keep_alive_service_))); |
110 } | 106 } |
111 | 107 |
112 void EnableAppList() { | |
113 service_->EnableAppList(profile1_.get(), | |
114 AppListService::ENABLE_VIA_COMMAND_LINE); | |
115 } | |
116 | |
117 base::FilePath user_data_dir_; | 108 base::FilePath user_data_dir_; |
118 scoped_ptr<PrefService> local_state_; | 109 scoped_ptr<PrefService> local_state_; |
119 FakeProfileStore* profile_store_; | 110 FakeProfileStore* profile_store_; |
120 FakeKeepAliveService* keep_alive_service_; | 111 FakeKeepAliveService* keep_alive_service_; |
121 scoped_ptr<TestingAppListServiceImpl> service_; | 112 scoped_ptr<TestingAppListServiceImpl> service_; |
122 scoped_ptr<FakeProfile> profile1_; | 113 scoped_ptr<FakeProfile> profile1_; |
123 scoped_ptr<FakeProfile> profile2_; | 114 scoped_ptr<FakeProfile> profile2_; |
124 | |
125 DISALLOW_COPY_AND_ASSIGN(AppListServiceUnitTest); | |
126 }; | 115 }; |
127 | 116 |
128 TEST_F(AppListServiceUnitTest, EnablingStateIsPersisted) { | 117 TEST_F(AppListServiceUnitTest, EnablingStateIsPersisted) { |
129 EXPECT_FALSE(local_state_->GetBoolean(prefs::kAppLauncherHasBeenEnabled)); | 118 EXPECT_FALSE(local_state_->GetBoolean(prefs::kAppLauncherHasBeenEnabled)); |
130 EnableAppList(); | 119 service_->EnableAppList(profile1_.get()); |
131 EXPECT_TRUE(local_state_->GetBoolean(prefs::kAppLauncherHasBeenEnabled)); | 120 EXPECT_TRUE(local_state_->GetBoolean(prefs::kAppLauncherHasBeenEnabled)); |
132 EXPECT_EQ(profile1_->GetPath(), user_data_dir_.Append( | 121 EXPECT_EQ(profile1_->GetPath(), user_data_dir_.Append( |
133 local_state_->GetFilePath(prefs::kAppListProfile))); | 122 local_state_->GetFilePath(prefs::kAppListProfile))); |
134 } | 123 } |
135 | 124 |
136 TEST_F(AppListServiceUnitTest, ShowingForProfileLoadsAProfile) { | 125 TEST_F(AppListServiceUnitTest, ShowingForProfileLoadsAProfile) { |
137 profile_store_->LoadProfile(profile1_.get()); | 126 profile_store_->LoadProfile(profile1_.get()); |
138 EnableAppList(); | 127 service_->EnableAppList(profile1_.get()); |
139 service_->Show(); | 128 service_->Show(); |
140 EXPECT_EQ(profile1_.get(), service_->showing_for_profile()); | 129 EXPECT_EQ(profile1_.get(), service_->showing_for_profile()); |
141 EXPECT_TRUE(service_->IsAppListVisible()); | 130 EXPECT_TRUE(service_->IsAppListVisible()); |
142 } | 131 } |
143 | 132 |
144 TEST_F(AppListServiceUnitTest, RemovedProfileResetsToInitialProfile) { | 133 TEST_F(AppListServiceUnitTest, RemovedProfileResetsToInitialProfile) { |
145 EnableAppList(); | 134 service_->EnableAppList(profile1_.get()); |
146 profile_store_->RemoveProfile(profile1_.get()); | 135 profile_store_->RemoveProfile(profile1_.get()); |
147 base::FilePath initial_profile_path = | 136 base::FilePath initial_profile_path = |
148 user_data_dir_.AppendASCII(chrome::kInitialProfile); | 137 user_data_dir_.AppendASCII(chrome::kInitialProfile); |
149 EXPECT_EQ(initial_profile_path, | 138 EXPECT_EQ(initial_profile_path, |
150 service_->GetProfilePath(profile_store_->GetUserDataDir())); | 139 service_->GetProfilePath(profile_store_->GetUserDataDir())); |
151 } | 140 } |
152 | 141 |
153 TEST_F(AppListServiceUnitTest, | 142 TEST_F(AppListServiceUnitTest, |
154 RemovedProfileResetsToLastUsedProfileIfExists) { | 143 RemovedProfileResetsToLastUsedProfileIfExists) { |
155 local_state_->SetString(prefs::kProfileLastUsed, "last-used"); | 144 local_state_->SetString(prefs::kProfileLastUsed, "last-used"); |
156 EnableAppList(); | 145 service_->EnableAppList(profile1_.get()); |
157 profile_store_->RemoveProfile(profile1_.get()); | 146 profile_store_->RemoveProfile(profile1_.get()); |
158 base::FilePath last_used_profile_path = | 147 base::FilePath last_used_profile_path = |
159 user_data_dir_.AppendASCII("last-used"); | 148 user_data_dir_.AppendASCII("last-used"); |
160 EXPECT_EQ(last_used_profile_path, | 149 EXPECT_EQ(last_used_profile_path, |
161 service_->GetProfilePath(profile_store_->GetUserDataDir())); | 150 service_->GetProfilePath(profile_store_->GetUserDataDir())); |
162 } | 151 } |
163 | 152 |
164 TEST_F(AppListServiceUnitTest, SwitchingProfilesPersists) { | 153 TEST_F(AppListServiceUnitTest, SwitchingProfilesPersists) { |
165 profile_store_->LoadProfile(profile1_.get()); | 154 profile_store_->LoadProfile(profile1_.get()); |
166 profile_store_->LoadProfile(profile2_.get()); | 155 profile_store_->LoadProfile(profile2_.get()); |
167 EnableAppList(); | 156 service_->EnableAppList(profile1_.get()); |
168 service_->SetProfilePath(profile2_->GetPath()); | 157 service_->SetProfilePath(profile2_->GetPath()); |
169 service_->Show(); | 158 service_->Show(); |
170 EXPECT_EQ(profile2_.get(), service_->showing_for_profile()); | 159 EXPECT_EQ(profile2_.get(), service_->showing_for_profile()); |
171 EXPECT_EQ(profile2_->GetPath(), | 160 EXPECT_EQ(profile2_->GetPath(), |
172 service_->GetProfilePath(profile_store_->GetUserDataDir())); | 161 service_->GetProfilePath(profile_store_->GetUserDataDir())); |
173 service_->SetProfilePath(profile1_->GetPath()); | 162 service_->SetProfilePath(profile1_->GetPath()); |
174 EXPECT_EQ(profile1_->GetPath(), | 163 EXPECT_EQ(profile1_->GetPath(), |
175 service_->GetProfilePath(profile_store_->GetUserDataDir())); | 164 service_->GetProfilePath(profile_store_->GetUserDataDir())); |
176 } | 165 } |
177 | 166 |
178 TEST_F(AppListServiceUnitTest, EnableViaCommandLineFlag) { | 167 TEST_F(AppListServiceUnitTest, EnableViaCommandLineFlag) { |
179 CommandLine command_line(CommandLine::NO_PROGRAM); | 168 CommandLine command_line(CommandLine::NO_PROGRAM); |
180 command_line.AppendSwitch(switches::kEnableAppList); | 169 command_line.AppendSwitch(switches::kEnableAppList); |
181 SetupWithCommandLine(command_line); | 170 SetupWithCommandLine(command_line); |
182 service_->PerformStartupChecks(profile1_.get()); | 171 service_->HandleCommandLineFlags(profile1_.get()); |
183 EXPECT_TRUE(local_state_->GetBoolean(prefs::kAppLauncherHasBeenEnabled)); | 172 EXPECT_TRUE(local_state_->GetBoolean(prefs::kAppLauncherHasBeenEnabled)); |
184 } | 173 } |
185 | 174 |
186 TEST_F(AppListServiceUnitTest, DisableViaCommandLineFlag) { | 175 TEST_F(AppListServiceUnitTest, DisableViaCommandLineFlag) { |
187 CommandLine command_line(CommandLine::NO_PROGRAM); | 176 CommandLine command_line(CommandLine::NO_PROGRAM); |
188 command_line.AppendSwitch(switches::kResetAppListInstallState); | 177 command_line.AppendSwitch(switches::kResetAppListInstallState); |
189 SetupWithCommandLine(command_line); | 178 SetupWithCommandLine(command_line); |
190 service_->PerformStartupChecks(profile1_.get()); | 179 service_->HandleCommandLineFlags(profile1_.get()); |
191 EXPECT_FALSE(local_state_->GetBoolean(prefs::kAppLauncherHasBeenEnabled)); | 180 EXPECT_FALSE(local_state_->GetBoolean(prefs::kAppLauncherHasBeenEnabled)); |
192 } | 181 } |
193 | |
194 TEST_F(AppListServiceUnitTest, UMAPrefStates) { | |
195 EXPECT_FALSE(local_state_->GetBoolean(prefs::kAppLauncherHasBeenEnabled)); | |
196 EXPECT_EQ(AppListService::ENABLE_NOT_RECORDED, | |
197 local_state_->GetInteger(prefs::kAppListEnableMethod)); | |
198 EXPECT_EQ(0, local_state_->GetInt64(prefs::kAppListEnableTime)); | |
199 | |
200 service_->EnableAppList(profile1_.get(), | |
201 AppListService::ENABLE_FOR_APP_INSTALL); | |
202 | |
203 // After enable, method and time should be recorded. | |
204 EXPECT_TRUE(local_state_->GetBoolean(prefs::kAppLauncherHasBeenEnabled)); | |
205 EXPECT_EQ(AppListService::ENABLE_FOR_APP_INSTALL, | |
206 local_state_->GetInteger(prefs::kAppListEnableMethod)); | |
207 EXPECT_NE(0, local_state_->GetInt64(prefs::kAppListEnableTime)); | |
208 | |
209 service_->ShowForProfile(profile1_.get()); | |
210 | |
211 // After a regular "show", time should be cleared, so UMA is not re-recorded. | |
212 EXPECT_EQ(AppListService::ENABLE_FOR_APP_INSTALL, | |
213 local_state_->GetInteger(prefs::kAppListEnableMethod)); | |
214 EXPECT_EQ(0, local_state_->GetInt64(prefs::kAppListEnableTime)); | |
215 | |
216 // A second enable should be a no-op. | |
217 service_->EnableAppList(profile1_.get(), | |
218 AppListService::ENABLE_FOR_APP_INSTALL); | |
219 EXPECT_EQ(AppListService::ENABLE_FOR_APP_INSTALL, | |
220 local_state_->GetInteger(prefs::kAppListEnableMethod)); | |
221 EXPECT_EQ(0, local_state_->GetInt64(prefs::kAppListEnableTime)); | |
222 | |
223 // An auto-show here should keep the recorded enable method. | |
224 service_->AutoShowForProfile(profile1_.get()); | |
225 EXPECT_EQ(AppListService::ENABLE_FOR_APP_INSTALL, | |
226 local_state_->GetInteger(prefs::kAppListEnableMethod)); | |
227 | |
228 // Clear the enable state, so we can enable again. | |
229 local_state_->SetBoolean(prefs::kAppLauncherHasBeenEnabled, false); | |
230 service_->EnableAppList(profile1_.get(), | |
231 AppListService::ENABLE_FOR_APP_INSTALL); | |
232 | |
233 EXPECT_EQ(AppListService::ENABLE_FOR_APP_INSTALL, | |
234 local_state_->GetInteger(prefs::kAppListEnableMethod)); | |
235 EXPECT_NE(0, local_state_->GetInt64(prefs::kAppListEnableTime)); | |
236 | |
237 // An auto-show here should update the enable method to prevent recording it | |
238 // as ENABLE_FOR_APP_INSTALL. | |
239 service_->AutoShowForProfile(profile1_.get()); | |
240 EXPECT_EQ(AppListService::ENABLE_SHOWN_UNDISCOVERED, | |
241 local_state_->GetInteger(prefs::kAppListEnableMethod)); | |
242 } | |
OLD | NEW |