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

Side by Side Diff: chrome/installer/util/installer_state_unittest.cc

Issue 6288009: More installer refactoring in the interest of fixing some bugs and cleaning t... (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src/
Patch Set: '' Created 9 years, 11 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 | Annotate | Revision Log
OLDNEW
1 // Copyright (c) 2006-2008 The Chromium Authors. All rights reserved. 1 // Copyright (c) 2011 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be 2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file. 3 // found in the LICENSE file.
4 4
5 #include <windows.h> 5 #include <windows.h>
6 6
7 #include <fstream> 7 #include <fstream>
8 8
9 #include "base/base_paths.h" 9 #include "base/base_paths.h"
10 #include "base/command_line.h"
10 #include "base/file_util.h" 11 #include "base/file_util.h"
11 #include "base/path_service.h" 12 #include "base/path_service.h"
12 #include "base/process_util.h" 13 #include "base/process_util.h"
13 #include "base/string_util.h" 14 #include "base/string_util.h"
15 #include "base/utf_string_conversions.h"
14 #include "base/version.h" 16 #include "base/version.h"
17 #include "base/win/registry.h"
18 #include "base/win/scoped_handle.h"
19 #include "chrome/installer/util/google_update_constants.h"
15 #include "chrome/installer/util/helper.h" 20 #include "chrome/installer/util/helper.h"
16 #include "chrome/installer/util/package.h" 21 #include "chrome/installer/util/installation_state.h"
17 #include "chrome/installer/util/package_properties.h" 22 #include "chrome/installer/util/installer_state.h"
23 #include "chrome/installer/util/master_preferences.h"
24 #include "chrome/installer/util/product_unittest.h"
18 #include "chrome/installer/util/work_item.h" 25 #include "chrome/installer/util/work_item.h"
19 #include "testing/gtest/include/gtest/gtest.h" 26 #include "testing/gtest/include/gtest/gtest.h"
20 27
21 using installer::ChromePackageProperties; 28 class InstallerStateTest : public TestWithTempDirAndDeleteTempOverrideKeys {
22 using installer::Package; 29 protected:
30 };
23 31
24 namespace { 32 // An installer state on which we can tweak the target path.
25 class SetupHelperTest : public testing::Test { 33 class MockInstallerState : public installer::InstallerState {
26 protected: 34 public:
27 virtual void SetUp() { 35 MockInstallerState() : InstallerState() { }
28 // Name a subdirectory of the user temp directory. 36 void set_target_path(const FilePath& target_path) {
29 ASSERT_TRUE(PathService::Get(base::DIR_TEMP, &test_dir_)); 37 target_path_ = target_path;
30 test_dir_ = test_dir_.AppendASCII("SetupHelperTest"); 38 }
39 };
31 40
32 // Create a fresh, empty copy of this test directory. 41 // Simple function to dump some text into a new file.
33 file_util::Delete(test_dir_, true); 42 void CreateTextFile(const std::wstring& filename,
34 file_util::CreateDirectoryW(test_dir_); 43 const std::wstring& contents) {
35 ASSERT_TRUE(file_util::PathExists(test_dir_)); 44 std::ofstream file;
36 } 45 file.open(filename.c_str());
46 ASSERT_TRUE(file.is_open());
47 file << contents;
48 file.close();
49 }
37 50
38 virtual void TearDown() { 51 wchar_t text_content_1[] = L"delete me";
39 logging::CloseLogFile(); 52 wchar_t text_content_2[] = L"delete me as well";
40 // Clean up test directory
41 ASSERT_TRUE(file_util::Delete(test_dir_, true));
42 ASSERT_FALSE(file_util::PathExists(test_dir_));
43 }
44
45 // the path to temporary directory used to contain the test operations
46 FilePath test_dir_;
47 };
48
49 // Simple function to dump some text into a new file.
50 void CreateTextFile(const std::wstring& filename,
51 const std::wstring& contents) {
52 std::ofstream file;
53 file.open(filename.c_str());
54 ASSERT_TRUE(file.is_open());
55 file << contents;
56 file.close();
57 }
58
59 wchar_t text_content_1[] = L"delete me";
60 wchar_t text_content_2[] = L"delete me as well";
61 };
62 53
63 // Delete version directories. Everything lower than the given version 54 // Delete version directories. Everything lower than the given version
64 // should be deleted. 55 // should be deleted.
65 TEST_F(SetupHelperTest, Delete) { 56 TEST_F(InstallerStateTest, Delete) {
66 // Create a Chrome dir 57 // Create a Chrome dir
67 FilePath chrome_dir(test_dir_); 58 FilePath chrome_dir(test_dir_.path());
68 chrome_dir = chrome_dir.AppendASCII("chrome"); 59 chrome_dir = chrome_dir.AppendASCII("chrome");
69 file_util::CreateDirectory(chrome_dir); 60 file_util::CreateDirectory(chrome_dir);
70 ASSERT_TRUE(file_util::PathExists(chrome_dir)); 61 ASSERT_TRUE(file_util::PathExists(chrome_dir));
71 62
72 FilePath chrome_dir_1(chrome_dir); 63 FilePath chrome_dir_1(chrome_dir);
73 chrome_dir_1 = chrome_dir_1.AppendASCII("1.0.1.0"); 64 chrome_dir_1 = chrome_dir_1.AppendASCII("1.0.1.0");
74 file_util::CreateDirectory(chrome_dir_1); 65 file_util::CreateDirectory(chrome_dir_1);
75 ASSERT_TRUE(file_util::PathExists(chrome_dir_1)); 66 ASSERT_TRUE(file_util::PathExists(chrome_dir_1));
76 67
77 FilePath chrome_dir_2(chrome_dir); 68 FilePath chrome_dir_2(chrome_dir);
(...skipping 22 matching lines...) Expand all
100 ASSERT_TRUE(file_util::PathExists(chrome_dll_2)); 91 ASSERT_TRUE(file_util::PathExists(chrome_dll_2));
101 92
102 FilePath chrome_dll_3(chrome_dir_3); 93 FilePath chrome_dll_3(chrome_dir_3);
103 chrome_dll_3 = chrome_dll_3.AppendASCII("chrome.dll"); 94 chrome_dll_3 = chrome_dll_3.AppendASCII("chrome.dll");
104 CreateTextFile(chrome_dll_3.value(), text_content_1); 95 CreateTextFile(chrome_dll_3.value(), text_content_1);
105 ASSERT_TRUE(file_util::PathExists(chrome_dll_3)); 96 ASSERT_TRUE(file_util::PathExists(chrome_dll_3));
106 97
107 FilePath chrome_dll_4(chrome_dir_4); 98 FilePath chrome_dll_4(chrome_dir_4);
108 chrome_dll_4 = chrome_dll_4.AppendASCII("chrome.dll"); 99 chrome_dll_4 = chrome_dll_4.AppendASCII("chrome.dll");
109 CreateTextFile(chrome_dll_4.value(), text_content_1); 100 CreateTextFile(chrome_dll_4.value(), text_content_1);
110 ASSERT_TRUE(file_util::PathExists(chrome_dll_4)); 101 ASSERT_TRUE(file_util::PathExists(chrome_dll_4));
robertshield 2011/01/21 19:37:47 This setup code above looks like it should be in t
grt (UTC plus 2) 2011/01/24 16:07:02 Adding TODO to clean this up since it pre-dates th
111 102
103 CommandLine cmd_line = CommandLine::FromString(L"setup.exe");
104 installer::MasterPreferences prefs(cmd_line);
105 installer::InstallationState machine_state;
106 machine_state.Initialize();
107 MockInstallerState installer_state;
108 installer_state.Initialize(cmd_line, prefs, machine_state);
109 installer_state.set_target_path(chrome_dir);
110 EXPECT_TRUE(installer_state.FindProduct(BrowserDistribution::CHROME_BROWSER)
111 != NULL);
robertshield 2011/01/21 19:37:47 Add expectations that CHROME_FRAME is not present?
grt (UTC plus 2) 2011/01/24 16:07:02 That would be testing something unrelated to what
112 scoped_ptr<Version> latest_version(Version::GetVersionFromString("1.0.4.0")); 112 scoped_ptr<Version> latest_version(Version::GetVersionFromString("1.0.4.0"));
113 ChromePackageProperties properties; 113 installer_state.RemoveOldVersionDirectories(*latest_version.get());
114 scoped_refptr<Package> package(new Package(false, true, chrome_dir,
115 &properties));
116 package->RemoveOldVersionDirectories(*latest_version.get());
117 114
118 // old versions should be gone 115 // old versions should be gone
119 EXPECT_FALSE(file_util::PathExists(chrome_dir_1)); 116 EXPECT_FALSE(file_util::PathExists(chrome_dir_1));
120 EXPECT_FALSE(file_util::PathExists(chrome_dir_2)); 117 EXPECT_FALSE(file_util::PathExists(chrome_dir_2));
121 EXPECT_FALSE(file_util::PathExists(chrome_dir_3)); 118 EXPECT_FALSE(file_util::PathExists(chrome_dir_3));
122 // the latest version should stay 119 // the latest version should stay
123 EXPECT_TRUE(file_util::PathExists(chrome_dll_4)); 120 EXPECT_TRUE(file_util::PathExists(chrome_dll_4));
124 } 121 }
125 122
126 // Delete older version directories, keeping the one in used intact. 123 // Delete older version directories, keeping the one in used intact.
127 TEST_F(SetupHelperTest, DeleteInUsed) { 124 TEST_F(InstallerStateTest, DeleteInUsed) {
128 // Create a Chrome dir 125 // Create a Chrome dir
129 FilePath chrome_dir(test_dir_); 126 FilePath chrome_dir(test_dir_.path());
130 chrome_dir = chrome_dir.AppendASCII("chrome"); 127 chrome_dir = chrome_dir.AppendASCII("chrome");
131 file_util::CreateDirectory(chrome_dir); 128 file_util::CreateDirectory(chrome_dir);
132 ASSERT_TRUE(file_util::PathExists(chrome_dir)); 129 ASSERT_TRUE(file_util::PathExists(chrome_dir));
133 130
134 FilePath chrome_dir_1(chrome_dir); 131 FilePath chrome_dir_1(chrome_dir);
135 chrome_dir_1 = chrome_dir_1.AppendASCII("1.0.1.0"); 132 chrome_dir_1 = chrome_dir_1.AppendASCII("1.0.1.0");
136 file_util::CreateDirectory(chrome_dir_1); 133 file_util::CreateDirectory(chrome_dir_1);
137 ASSERT_TRUE(file_util::PathExists(chrome_dir_1)); 134 ASSERT_TRUE(file_util::PathExists(chrome_dir_1));
138 135
139 FilePath chrome_dir_2(chrome_dir); 136 FilePath chrome_dir_2(chrome_dir);
(...skipping 38 matching lines...) Expand 10 before | Expand all | Expand 10 after
178 FilePath chrome_dll_3(chrome_dir_3); 175 FilePath chrome_dll_3(chrome_dir_3);
179 chrome_dll_3 = chrome_dll_3.AppendASCII("chrome.dll"); 176 chrome_dll_3 = chrome_dll_3.AppendASCII("chrome.dll");
180 CreateTextFile(chrome_dll_3.value(), text_content_1); 177 CreateTextFile(chrome_dll_3.value(), text_content_1);
181 ASSERT_TRUE(file_util::PathExists(chrome_dll_3)); 178 ASSERT_TRUE(file_util::PathExists(chrome_dll_3));
182 179
183 FilePath chrome_dll_4(chrome_dir_4); 180 FilePath chrome_dll_4(chrome_dir_4);
184 chrome_dll_4 = chrome_dll_4.AppendASCII("chrome.dll"); 181 chrome_dll_4 = chrome_dll_4.AppendASCII("chrome.dll");
185 CreateTextFile(chrome_dll_4.value(), text_content_1); 182 CreateTextFile(chrome_dll_4.value(), text_content_1);
186 ASSERT_TRUE(file_util::PathExists(chrome_dll_4)); 183 ASSERT_TRUE(file_util::PathExists(chrome_dll_4));
187 184
185 CommandLine cmd_line = CommandLine::FromString(L"setup.exe");
186 installer::MasterPreferences prefs(cmd_line);
187 installer::InstallationState machine_state;
188 machine_state.Initialize();
189 MockInstallerState installer_state;
190 installer_state.Initialize(cmd_line, prefs, machine_state);
191 installer_state.set_target_path(chrome_dir);
192 EXPECT_TRUE(installer_state.FindProduct(BrowserDistribution::CHROME_BROWSER)
193 != NULL);
robertshield 2011/01/21 19:37:47 This looks copy/pasted. Stick it in a method?
grt (UTC plus 2) 2011/01/24 16:07:02 Done.
188 scoped_ptr<Version> latest_version(Version::GetVersionFromString("1.0.4.0")); 194 scoped_ptr<Version> latest_version(Version::GetVersionFromString("1.0.4.0"));
189 ChromePackageProperties properties; 195 installer_state.RemoveOldVersionDirectories(*latest_version.get());
190 scoped_refptr<Package> install_path(new Package(false, true, chrome_dir,
191 &properties));
192 install_path->RemoveOldVersionDirectories(*latest_version.get());
193 196
194 // old versions not in used should be gone 197 // old versions not in used should be gone
195 EXPECT_FALSE(file_util::PathExists(chrome_dir_1)); 198 EXPECT_FALSE(file_util::PathExists(chrome_dir_1));
196 EXPECT_FALSE(file_util::PathExists(chrome_dir_3)); 199 EXPECT_FALSE(file_util::PathExists(chrome_dir_3));
197 // every thing under in used version should stay 200 // every thing under in used version should stay
198 EXPECT_TRUE(file_util::PathExists(chrome_dir_2)); 201 EXPECT_TRUE(file_util::PathExists(chrome_dir_2));
199 EXPECT_TRUE(file_util::PathExists(chrome_dll_2)); 202 EXPECT_TRUE(file_util::PathExists(chrome_dll_2));
200 EXPECT_TRUE(file_util::PathExists(chrome_othera_2)); 203 EXPECT_TRUE(file_util::PathExists(chrome_othera_2));
201 EXPECT_TRUE(file_util::PathExists(chrome_otherb_2)); 204 EXPECT_TRUE(file_util::PathExists(chrome_otherb_2));
202 // the latest version should stay 205 // the latest version should stay
203 EXPECT_TRUE(file_util::PathExists(chrome_dll_4)); 206 EXPECT_TRUE(file_util::PathExists(chrome_dll_4));
204 } 207 }
208
209 // Tests a few basic things of the Package class. Makes sure that the path
210 // operations are correct
211 TEST_F(InstallerStateTest, Basic) {
212 const bool multi_install = false;
213 const bool system_level = true;
214 CommandLine cmd_line = CommandLine::FromString(
215 std::wstring(L"setup.exe") +
216 (multi_install ? L" --multi-install --chrome" : L"") +
217 (system_level ? L" --system-level" : L""));
218 installer::MasterPreferences prefs(cmd_line);
219 installer::InstallationState machine_state;
220 machine_state.Initialize();
221 MockInstallerState installer_state;
222 installer_state.Initialize(cmd_line, prefs, machine_state);
223 installer_state.set_target_path(test_dir_.path());
224 EXPECT_EQ(test_dir_.path().value(), installer_state.target_path().value());
225 EXPECT_EQ(1U, installer_state.products().size());
226
227 const char kOldVersion[] = "1.2.3.4";
228 const char kNewVersion[] = "2.3.4.5";
229
230 scoped_ptr<Version> new_version(Version::GetVersionFromString(kNewVersion));
231 scoped_ptr<Version> old_version(Version::GetVersionFromString(kOldVersion));
232 ASSERT_TRUE(new_version.get() != NULL);
233 ASSERT_TRUE(old_version.get() != NULL);
234
235 FilePath installer_dir(
236 installer_state.GetInstallerDirectory(*new_version.get()));
237 EXPECT_FALSE(installer_dir.empty());
238
239 FilePath new_version_dir(installer_state.target_path().Append(
240 UTF8ToWide(new_version->GetString())));
241 FilePath old_version_dir(installer_state.target_path().Append(
242 UTF8ToWide(old_version->GetString())));
243
244 EXPECT_FALSE(file_util::PathExists(new_version_dir));
245 EXPECT_FALSE(file_util::PathExists(old_version_dir));
246
247 EXPECT_FALSE(file_util::PathExists(installer_dir));
248 file_util::CreateDirectory(installer_dir);
249 EXPECT_TRUE(file_util::PathExists(new_version_dir));
250
251 file_util::CreateDirectory(old_version_dir);
252 EXPECT_TRUE(file_util::PathExists(old_version_dir));
253
254 // Create a fake chrome.dll key file in the old version directory. This
255 // should prevent the old version directory from getting deleted.
256 FilePath old_chrome_dll(old_version_dir.Append(installer::kChromeDll));
257 EXPECT_FALSE(file_util::PathExists(old_chrome_dll));
258
259 // Hold on to the file exclusively to prevent the directory from
260 // being deleted.
261 base::win::ScopedHandle file(
262 ::CreateFile(old_chrome_dll.value().c_str(), GENERIC_READ,
263 0, NULL, OPEN_ALWAYS, 0, NULL));
264 EXPECT_TRUE(file.IsValid());
265 EXPECT_TRUE(file_util::PathExists(old_chrome_dll));
266
267 installer_state.RemoveOldVersionDirectories(*new_version.get());
268 // The old directory should still exist.
269 EXPECT_TRUE(file_util::PathExists(old_version_dir));
270 EXPECT_TRUE(file_util::PathExists(new_version_dir));
271
272 // Now close the file handle to make it possible to delete our key file.
273 file.Close();
274
275 installer_state.RemoveOldVersionDirectories(*new_version.get());
276 // The new directory should still exist.
277 EXPECT_TRUE(file_util::PathExists(new_version_dir));
278
279 // Now, the old directory and key file should be gone.
280 EXPECT_FALSE(file_util::PathExists(old_chrome_dll));
281 EXPECT_FALSE(file_util::PathExists(old_version_dir));
282 }
283
284 TEST_F(InstallerStateTest, WithProduct) {
285 const bool multi_install = false;
286 const bool system_level = true;
287 CommandLine cmd_line = CommandLine::FromString(
288 std::wstring(L"setup.exe") +
289 (multi_install ? L" --multi-install --chrome" : L"") +
290 (system_level ? L" --system-level" : L""));
291 installer::MasterPreferences prefs(cmd_line);
292 installer::InstallationState machine_state;
293 machine_state.Initialize();
294 MockInstallerState installer_state;
295 installer_state.Initialize(cmd_line, prefs, machine_state);
296 installer_state.set_target_path(test_dir_.path());
297 EXPECT_EQ(1U, installer_state.products().size());
298 EXPECT_EQ(system_level, installer_state.system_install());
299
300 const char kCurrentVersion[] = "1.2.3.4";
301 scoped_ptr<Version> current_version(
302 Version::GetVersionFromString(kCurrentVersion));
303
304 HKEY root = system_level ? HKEY_LOCAL_MACHINE : HKEY_CURRENT_USER;
305 EXPECT_EQ(root, installer_state.root_key());
306 {
307 TempRegKeyOverride override(root, L"root_pit");
308 BrowserDistribution* dist = BrowserDistribution::GetSpecificDistribution(
309 BrowserDistribution::CHROME_BROWSER);
310 base::win::RegKey chrome_key(root, dist->GetVersionKey().c_str(),
311 KEY_ALL_ACCESS);
312 EXPECT_TRUE(chrome_key.Valid());
313 if (chrome_key.Valid()) {
314 chrome_key.WriteValue(google_update::kRegVersionField,
315 UTF8ToWide(current_version->GetString()).c_str());
316 machine_state.Initialize();
317 // TODO(tommi): Also test for when there exists a new_chrome.exe.
318 scoped_ptr<Version> found_version(installer_state.GetCurrentVersion(
319 machine_state));
320 EXPECT_TRUE(found_version.get() != NULL);
321 if (found_version.get()) {
322 EXPECT_TRUE(current_version->Equals(*found_version));
323 }
324 }
325 }
326 }
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698