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

Side by Side Diff: trunk/src/base/test/test_reg_util_win.cc

Issue 69793004: Revert 234367 "Base: Make RegistryOverrideManager support sharde..." (Closed) Base URL: svn://svn.chromium.org/chrome/
Patch Set: Created 7 years, 1 month 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) 2011 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 "base/test/test_reg_util_win.h" 5 #include "base/test/test_reg_util_win.h"
6 6
7 #include "base/guid.h"
8 #include "base/logging.h" 7 #include "base/logging.h"
9 #include "base/strings/string_number_conversions.h"
10 #include "base/strings/string_util.h"
11 #include "base/strings/utf_string_conversions.h"
12 #include "testing/gtest/include/gtest/gtest.h" 8 #include "testing/gtest/include/gtest/gtest.h"
13 9
14 namespace registry_util { 10 namespace registry_util {
15 11
16 namespace { 12 const wchar_t RegistryOverrideManager::kTempTestKeyPath[] =
17 13 L"Software\\Chromium\\TempTestKeys";
18 const wchar_t kTimestampDelimiter[] = L"$";
19 const wchar_t kTempTestKeyPath[] = L"Software\\Chromium\\TempTestKeys";
20
21 void DeleteStaleTestKeys(const base::Time& now, const string16& test_key_root) {
22 base::win::RegKey test_root_key;
23 if (test_root_key.Open(HKEY_CURRENT_USER,
24 test_key_root.c_str(),
25 KEY_ALL_ACCESS) != ERROR_SUCCESS) {
26 // This will occur on first-run, but is harmless.
27 return;
28 }
29
30 base::win::RegistryKeyIterator iterator_test_root_key(HKEY_CURRENT_USER,
31 test_key_root.c_str());
32 for (; iterator_test_root_key.Valid(); ++iterator_test_root_key) {
33 string16 key_name = iterator_test_root_key.Name();
34 std::vector<string16> tokens;
35 Tokenize(key_name, string16(kTimestampDelimiter), &tokens);
36 int64 key_name_as_number = 0;
37
38 if (!base::StringToInt64(tokens[0], &key_name_as_number)) {
39 test_root_key.DeleteKey(key_name.c_str());
40 continue;
41 }
42
43 base::Time key_time = base::Time::FromInternalValue(key_name_as_number);
44 base::TimeDelta age = now - key_time;
45
46 if (age > base::TimeDelta::FromHours(24))
47 test_root_key.DeleteKey(key_name.c_str());
48 }
49 }
50
51 string16 GenerateTempKeyPath(const string16& test_key_root,
52 const base::Time& timestamp) {
53 string16 key_path = test_key_root;
54 key_path += L"\\" + base::Int64ToString16(timestamp.ToInternalValue());
55 key_path += kTimestampDelimiter + base::ASCIIToWide(base::GenerateGUID());
56
57 return key_path;
58 }
59
60 } // namespace
61 14
62 RegistryOverrideManager::ScopedRegistryKeyOverride::ScopedRegistryKeyOverride( 15 RegistryOverrideManager::ScopedRegistryKeyOverride::ScopedRegistryKeyOverride(
63 HKEY override, 16 HKEY override,
64 const string16& key_path) 17 const std::wstring& temp_name)
65 : override_(override) { 18 : override_(override),
66 EXPECT_EQ( 19 temp_name_(temp_name) {
67 ERROR_SUCCESS, 20 DCHECK(!temp_name_.empty());
21 std::wstring key_path(RegistryOverrideManager::kTempTestKeyPath);
22 key_path += L"\\" + temp_name_;
23 EXPECT_EQ(ERROR_SUCCESS,
68 temp_key_.Create(HKEY_CURRENT_USER, key_path.c_str(), KEY_ALL_ACCESS)); 24 temp_key_.Create(HKEY_CURRENT_USER, key_path.c_str(), KEY_ALL_ACCESS));
69 EXPECT_EQ(ERROR_SUCCESS, 25 EXPECT_EQ(ERROR_SUCCESS,
70 ::RegOverridePredefKey(override_, temp_key_.Handle())); 26 ::RegOverridePredefKey(override_, temp_key_.Handle()));
71 } 27 }
72 28
73 RegistryOverrideManager:: 29 RegistryOverrideManager::
74 ScopedRegistryKeyOverride::~ScopedRegistryKeyOverride() { 30 ScopedRegistryKeyOverride::~ScopedRegistryKeyOverride() {
75 ::RegOverridePredefKey(override_, NULL); 31 ::RegOverridePredefKey(override_, NULL);
76 temp_key_.DeleteKey(L""); 32 // The temp key will be deleted via a call to DeleteAllTempKeys().
77 } 33 }
78 34
79 RegistryOverrideManager::RegistryOverrideManager() 35 RegistryOverrideManager::RegistryOverrideManager() {
80 : timestamp_(base::Time::Now()), test_key_root_(kTempTestKeyPath) { 36 DeleteAllTempKeys();
81 DeleteStaleTestKeys(timestamp_, test_key_root_);
82 } 37 }
83 38
84 RegistryOverrideManager::RegistryOverrideManager(const base::Time& timestamp, 39 RegistryOverrideManager::~RegistryOverrideManager() {
85 const string16& test_key_root) 40 RemoveAllOverrides();
86 : timestamp_(timestamp), test_key_root_(test_key_root) {
87 DeleteStaleTestKeys(timestamp_, test_key_root_);
88 } 41 }
89 42
90 RegistryOverrideManager::~RegistryOverrideManager() {}
91
92 void RegistryOverrideManager::OverrideRegistry(HKEY override, 43 void RegistryOverrideManager::OverrideRegistry(HKEY override,
93 const string16& override_name) { 44 const std::wstring& temp_name) {
94 string16 key_path = GenerateTempKeyPath(test_key_root_, timestamp_); 45 overrides_.push_back(new ScopedRegistryKeyOverride(override, temp_name));
95 overrides_.push_back(new ScopedRegistryKeyOverride(override, key_path));
96 } 46 }
97 47
98 string16 GenerateTempKeyPath() { 48 void RegistryOverrideManager::RemoveAllOverrides() {
99 return GenerateTempKeyPath(string16(kTempTestKeyPath), base::Time::Now()); 49 while (!overrides_.empty()) {
50 delete overrides_.back();
51 overrides_.pop_back();
52 }
53
54 DeleteAllTempKeys();
55 }
56
57 // static
58 void RegistryOverrideManager::DeleteAllTempKeys() {
59 base::win::RegKey key;
60 if (key.Open(HKEY_CURRENT_USER, L"", KEY_ALL_ACCESS) == ERROR_SUCCESS) {
61 key.DeleteKey(kTempTestKeyPath);
62 }
100 } 63 }
101 64
102 } // namespace registry_util 65 } // namespace registry_util
OLDNEW
« no previous file with comments | « trunk/src/base/test/test_reg_util_win.h ('k') | trunk/src/base/test/test_reg_util_win_unittest.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698