OLD | NEW |
---|---|
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2012 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/command_line.h" |
11 #include "base/files/file_enumerator.h" | 11 #include "base/files/file_enumerator.h" |
12 #include "base/files/file_path.h" | 12 #include "base/files/file_path.h" |
13 #include "base/files/file_util.h" | 13 #include "base/files/file_util.h" |
14 #include "base/files/scoped_temp_dir.h" | 14 #include "base/files/scoped_temp_dir.h" |
15 #include "base/path_service.h" | 15 #include "base/path_service.h" |
16 #include "base/strings/string_util.h" | 16 #include "base/strings/string_util.h" |
17 #include "base/strings/utf_string_conversions.h" | 17 #include "base/strings/utf_string_conversions.h" |
18 #include "base/test/scoped_path_override.h" | |
18 #include "base/test/test_reg_util_win.h" | 19 #include "base/test/test_reg_util_win.h" |
19 #include "base/version.h" | 20 #include "base/version.h" |
20 #include "base/win/registry.h" | 21 #include "base/win/registry.h" |
21 #include "base/win/scoped_handle.h" | 22 #include "base/win/scoped_handle.h" |
22 #include "chrome/common/chrome_constants.h" | 23 #include "chrome/common/chrome_constants.h" |
23 #include "chrome/installer/test/alternate_version_generator.h" | 24 #include "chrome/installer/test/alternate_version_generator.h" |
24 #include "chrome/installer/util/fake_installation_state.h" | 25 #include "chrome/installer/util/fake_installation_state.h" |
25 #include "chrome/installer/util/fake_product_state.h" | 26 #include "chrome/installer/util/fake_product_state.h" |
26 #include "chrome/installer/util/google_update_constants.h" | 27 #include "chrome/installer/util/google_update_constants.h" |
27 #include "chrome/installer/util/helper.h" | 28 #include "chrome/installer/util/helper.h" |
(...skipping 568 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
596 } | 597 } |
597 } | 598 } |
598 | 599 |
599 std::set<std::string>::const_iterator iter( | 600 std::set<std::string>::const_iterator iter( |
600 expected_remaining_dirs.begin()); | 601 expected_remaining_dirs.begin()); |
601 for (; iter != expected_remaining_dirs.end(); ++iter) | 602 for (; iter != expected_remaining_dirs.end(); ++iter) |
602 ADD_FAILURE() << "Expected to find version dir for " << *iter; | 603 ADD_FAILURE() << "Expected to find version dir for " << *iter; |
603 } | 604 } |
604 | 605 |
605 TEST_F(InstallerStateTest, InitializeTwice) { | 606 TEST_F(InstallerStateTest, InitializeTwice) { |
607 // Override these paths so that they can be found after the registry override | |
608 // manager is in place. | |
609 base::ScopedPathOverride program_files_override( | |
610 base::DIR_PROGRAM_FILES, | |
611 base::FilePath(FILE_PATH_LITERAL("C:\\Program Files (x86)"))); | |
robertshield
2014/08/29 19:08:40
Should this path not contain the (x86) bit?
Also,
grt (UTC plus 2)
2014/08/29 19:13:07
Ultimately, it doesn't matter what the strings are
| |
612 base::ScopedPathOverride program_filesx86_override( | |
613 base::DIR_PROGRAM_FILESX86, | |
614 base::FilePath(FILE_PATH_LITERAL("C:\\Program Files (x86)"))); | |
615 registry_util::RegistryOverrideManager override_manager; | |
616 override_manager.OverrideRegistry(HKEY_CURRENT_USER, base::string16()); | |
617 override_manager.OverrideRegistry(HKEY_LOCAL_MACHINE, base::string16()); | |
618 | |
606 InstallationState machine_state; | 619 InstallationState machine_state; |
607 machine_state.Initialize(); | 620 machine_state.Initialize(); |
608 | 621 |
609 InstallerState installer_state; | 622 InstallerState installer_state; |
610 | 623 |
611 // Initialize the instance to install multi Chrome. | 624 // Initialize the instance to install multi Chrome. |
612 { | 625 { |
613 CommandLine cmd_line( | 626 CommandLine cmd_line( |
614 CommandLine::FromString(L"setup.exe --multi-install --chrome")); | 627 CommandLine::FromString(L"setup.exe --multi-install --chrome")); |
615 MasterPreferences prefs(cmd_line); | 628 MasterPreferences prefs(cmd_line); |
(...skipping 185 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
801 // Critical update newer than the new version. | 814 // Critical update newer than the new version. |
802 EXPECT_FALSE( | 815 EXPECT_FALSE( |
803 installer_state.DetermineCriticalVersion(NULL, *pv_version_).IsValid()); | 816 installer_state.DetermineCriticalVersion(NULL, *pv_version_).IsValid()); |
804 EXPECT_FALSE( | 817 EXPECT_FALSE( |
805 installer_state.DetermineCriticalVersion(opv_version_, *pv_version_) | 818 installer_state.DetermineCriticalVersion(opv_version_, *pv_version_) |
806 .IsValid()); | 819 .IsValid()); |
807 EXPECT_FALSE( | 820 EXPECT_FALSE( |
808 installer_state.DetermineCriticalVersion(pv_version_, *pv_version_) | 821 installer_state.DetermineCriticalVersion(pv_version_, *pv_version_) |
809 .IsValid()); | 822 .IsValid()); |
810 } | 823 } |
OLD | NEW |