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

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

Issue 57423008: Base: Make RegistryOverrideManager support sharded/parallel tests. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
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"
7 #include "base/logging.h" 8 #include "base/logging.h"
9 #include "base/strings/string_number_conversions.h"
10 #include "base/strings/utf_string_conversions.h"
8 #include "testing/gtest/include/gtest/gtest.h" 11 #include "testing/gtest/include/gtest/gtest.h"
9 12
10 namespace registry_util { 13 namespace registry_util {
11 14
15 namespace {
16
17 void DeleteStaleTestKeys(const base::Time& now, const string16& test_key_root) {
18 base::win::RegKey test_root_key;
19 if (ERROR_SUCCESS !=
grt (UTC plus 2) 2013/11/07 02:39:33 the following is more in-line with Chromium style:
tommycli 2013/11/07 18:02:07 Done.
20 test_root_key.Open(HKEY_CURRENT_USER, test_key_root.c_str(),
21 KEY_ALL_ACCESS)) {
22 // This will occur on first-run, but is harmless.
23 return;
24 }
25
26 base::win::RegistryKeyIterator iterator_test_root_key(
27 HKEY_CURRENT_USER, test_key_root.c_str());
28 for (; iterator_test_root_key.Valid(); ++iterator_test_root_key) {
29 string16 key_name = iterator_test_root_key.Name();
30 int64 key_name_as_number = 0;
31 if (!base::StringToInt64(key_name, &key_name_as_number)) {
32 test_root_key.DeleteKey(key_name.c_str());
33 continue;
34 }
35
36 base::Time key_time = base::Time::FromInternalValue(key_name_as_number);
37 base::TimeDelta age = now - key_time;
38
39 if (age > base::TimeDelta::FromHours(24))
40 test_root_key.DeleteKey(key_name.c_str());
41 }
42 }
43
44 } // namespace
45
12 const wchar_t RegistryOverrideManager::kTempTestKeyPath[] = 46 const wchar_t RegistryOverrideManager::kTempTestKeyPath[] =
13 L"Software\\Chromium\\TempTestKeys"; 47 L"Software\\Chromium\\TempTestKeys";
14 48
15 RegistryOverrideManager::ScopedRegistryKeyOverride::ScopedRegistryKeyOverride( 49 RegistryOverrideManager::ScopedRegistryKeyOverride::ScopedRegistryKeyOverride(
16 HKEY override, 50 HKEY override,
17 const std::wstring& temp_name) 51 const string16& key_path)
18 : override_(override), 52 : override_(override) {
19 temp_name_(temp_name) {
20 DCHECK(!temp_name_.empty());
21 std::wstring key_path(RegistryOverrideManager::kTempTestKeyPath);
22 key_path += L"\\" + temp_name_;
23 EXPECT_EQ(ERROR_SUCCESS, 53 EXPECT_EQ(ERROR_SUCCESS,
24 temp_key_.Create(HKEY_CURRENT_USER, key_path.c_str(), KEY_ALL_ACCESS)); 54 temp_key_.Create(HKEY_CURRENT_USER, key_path.c_str(), KEY_ALL_ACCESS));
25 EXPECT_EQ(ERROR_SUCCESS, 55 EXPECT_EQ(ERROR_SUCCESS,
26 ::RegOverridePredefKey(override_, temp_key_.Handle())); 56 ::RegOverridePredefKey(override_, temp_key_.Handle()));
27 } 57 }
28 58
29 RegistryOverrideManager:: 59 RegistryOverrideManager::
30 ScopedRegistryKeyOverride::~ScopedRegistryKeyOverride() { 60 ScopedRegistryKeyOverride::~ScopedRegistryKeyOverride() {
31 ::RegOverridePredefKey(override_, NULL); 61 ::RegOverridePredefKey(override_, NULL);
32 // The temp key will be deleted via a call to DeleteAllTempKeys(). 62 temp_key_.DeleteKey(L"");
33 } 63 }
34 64
35 RegistryOverrideManager::RegistryOverrideManager() { 65 RegistryOverrideManager::RegistryOverrideManager()
36 DeleteAllTempKeys(); 66 : timestamp_(base::Time::Now()),
67 guid_(base::ASCIIToWide(base::GenerateGUID())),
68 test_key_root_(kTempTestKeyPath) {
69 DeleteStaleTestKeys(timestamp_, test_key_root_);
37 } 70 }
38 71
39 RegistryOverrideManager::~RegistryOverrideManager() { 72 RegistryOverrideManager::RegistryOverrideManager(const base::Time& timestamp,
40 RemoveAllOverrides(); 73 const string16& test_key_root)
74 : timestamp_(timestamp),
75 guid_(base::ASCIIToWide(base::GenerateGUID())),
76 test_key_root_(test_key_root) {
77 DeleteStaleTestKeys(timestamp_, test_key_root_);
41 } 78 }
42 79
80
81 RegistryOverrideManager::~RegistryOverrideManager() {}
82
43 void RegistryOverrideManager::OverrideRegistry(HKEY override, 83 void RegistryOverrideManager::OverrideRegistry(HKEY override,
44 const std::wstring& temp_name) { 84 const string16& override_name) {
45 overrides_.push_back(new ScopedRegistryKeyOverride(override, temp_name)); 85 string16 key_path = test_key_root_;
46 } 86 key_path += L"\\" + base::Int64ToString16(timestamp_.ToInternalValue());
87 key_path += L"\\" + guid_;
88 key_path += L"\\" + override_name;
47 89
48 void RegistryOverrideManager::RemoveAllOverrides() { 90 overrides_.push_back(new ScopedRegistryKeyOverride(override, key_path));
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 }
63 } 91 }
64 92
65 } // namespace registry_util 93 } // namespace registry_util
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698