| Index: chrome/installer/util/set_reg_value_work_item_unittest.cc
|
| diff --git a/chrome/installer/util/set_reg_value_work_item_unittest.cc b/chrome/installer/util/set_reg_value_work_item_unittest.cc
|
| index 163f8882c3769bc7398f76415057def89f50d7c7..3916a34f21a4e544444fe9c5a0be3219e330ec0a 100644
|
| --- a/chrome/installer/util/set_reg_value_work_item_unittest.cc
|
| +++ b/chrome/installer/util/set_reg_value_work_item_unittest.cc
|
| @@ -4,307 +4,382 @@
|
|
|
| #include <windows.h>
|
|
|
| +#include <string>
|
| +
|
| +#include "base/bind.h"
|
| #include "base/files/file_path.h"
|
| +#include "base/macros.h"
|
| #include "base/memory/scoped_ptr.h"
|
| #include "base/strings/string_util.h"
|
| +#include "base/test/test_reg_util_win.h"
|
| #include "base/win/registry.h"
|
| #include "chrome/installer/util/set_reg_value_work_item.h"
|
| #include "chrome/installer/util/work_item.h"
|
| #include "testing/gtest/include/gtest/gtest.h"
|
|
|
| -using base::win::RegKey;
|
| -
|
| namespace {
|
|
|
| -const wchar_t kTestRoot[] = L"TempTemp";
|
| +const wchar_t kTestKey[] = L"TempTemp";
|
| const wchar_t kDataStr1[] = L"data_111";
|
| const wchar_t kDataStr2[] = L"data_222";
|
| const wchar_t kNameStr[] = L"name_str";
|
| const wchar_t kNameDword[] = L"name_dword";
|
|
|
| -const DWORD dword1 = 0;
|
| -const DWORD dword2 = 1;
|
| +const DWORD kDword1 = 12345;
|
| +const DWORD kDword2 = 6789;
|
|
|
| class SetRegValueWorkItemTest : public testing::Test {
|
| protected:
|
| + SetRegValueWorkItemTest() {}
|
| +
|
| void SetUp() override {
|
| - // Create a temporary key for testing
|
| - RegKey key(HKEY_CURRENT_USER, L"", KEY_ALL_ACCESS);
|
| - key.DeleteKey(kTestRoot);
|
| - ASSERT_NE(ERROR_SUCCESS, key.Open(HKEY_CURRENT_USER, kTestRoot, KEY_READ));
|
| - ASSERT_EQ(ERROR_SUCCESS,
|
| - key.Create(HKEY_CURRENT_USER, kTestRoot, KEY_READ));
|
| - }
|
| - void TearDown() override {
|
| - logging::CloseLogFile();
|
| - // Clean up the temporary key
|
| - RegKey key(HKEY_CURRENT_USER, L"", KEY_ALL_ACCESS);
|
| - ASSERT_EQ(ERROR_SUCCESS, key.DeleteKey(kTestRoot));
|
| + registry_override_manager_.OverrideRegistry(HKEY_CURRENT_USER);
|
| +
|
| + // Create a temporary key for testing.
|
| + ASSERT_NE(ERROR_SUCCESS,
|
| + test_key_.Open(HKEY_CURRENT_USER, kTestKey, KEY_READ));
|
| + ASSERT_EQ(ERROR_SUCCESS, test_key_.Create(HKEY_CURRENT_USER, kTestKey,
|
| + KEY_READ | KEY_SET_VALUE));
|
| }
|
| +
|
| + base::win::RegKey test_key_;
|
| +
|
| + private:
|
| + registry_util::RegistryOverrideManager registry_override_manager_;
|
| +
|
| + DISALLOW_COPY_AND_ASSIGN(SetRegValueWorkItemTest);
|
| };
|
|
|
| } // namespace
|
|
|
| // Write a new value without overwrite flag. The value should be set.
|
| TEST_F(SetRegValueWorkItemTest, WriteNewNonOverwrite) {
|
| - RegKey key;
|
| -
|
| - std::wstring parent_key(kTestRoot);
|
| - parent_key.append(&base::FilePath::kSeparators[0], 1);
|
| - parent_key.append(L"WriteNewNonOverwrite");
|
| - ASSERT_EQ(ERROR_SUCCESS,
|
| - key.Create(HKEY_CURRENT_USER, parent_key.c_str(), KEY_READ));
|
| -
|
| - std::wstring name_str(kNameStr);
|
| - std::wstring data_str(kDataStr1);
|
| scoped_ptr<SetRegValueWorkItem> work_item1(
|
| WorkItem::CreateSetRegValueWorkItem(HKEY_CURRENT_USER,
|
| - parent_key,
|
| + kTestKey,
|
| WorkItem::kWow64Default,
|
| - name_str,
|
| - data_str,
|
| + kNameStr,
|
| + kDataStr1,
|
| false));
|
|
|
| - std::wstring name_dword(kNameDword);
|
| scoped_ptr<SetRegValueWorkItem> work_item2(
|
| WorkItem::CreateSetRegValueWorkItem(HKEY_CURRENT_USER,
|
| - parent_key,
|
| + kTestKey,
|
| WorkItem::kWow64Default,
|
| - name_dword,
|
| - dword1,
|
| + kNameDword,
|
| + kDword1,
|
| false));
|
|
|
| - EXPECT_TRUE(work_item1->Do());
|
| - EXPECT_TRUE(work_item2->Do());
|
| + ASSERT_TRUE(work_item1->Do());
|
| + ASSERT_TRUE(work_item2->Do());
|
|
|
| std::wstring read_out;
|
| DWORD read_dword;
|
| - EXPECT_EQ(ERROR_SUCCESS, key.ReadValue(name_str.c_str(), &read_out));
|
| - EXPECT_EQ(ERROR_SUCCESS, key.ReadValueDW(name_dword.c_str(), &read_dword));
|
| + EXPECT_EQ(ERROR_SUCCESS, test_key_.ReadValue(kNameStr, &read_out));
|
| + EXPECT_EQ(ERROR_SUCCESS, test_key_.ReadValueDW(kNameDword, &read_dword));
|
| EXPECT_EQ(read_out, kDataStr1);
|
| - EXPECT_EQ(read_dword, dword1);
|
| + EXPECT_EQ(read_dword, kDword1);
|
|
|
| work_item1->Rollback();
|
| work_item2->Rollback();
|
|
|
| // Rollback should delete the value.
|
| - EXPECT_FALSE(key.HasValue(name_str.c_str()));
|
| - EXPECT_FALSE(key.HasValue(name_dword.c_str()));
|
| + EXPECT_FALSE(test_key_.HasValue(kNameStr));
|
| + EXPECT_FALSE(test_key_.HasValue(kNameDword));
|
| }
|
|
|
| // Write a new value with overwrite flag. The value should be set.
|
| TEST_F(SetRegValueWorkItemTest, WriteNewOverwrite) {
|
| - RegKey key;
|
| -
|
| - std::wstring parent_key(kTestRoot);
|
| - parent_key.append(&base::FilePath::kSeparators[0], 1);
|
| - parent_key.append(L"WriteNewOverwrite");
|
| - ASSERT_EQ(ERROR_SUCCESS,
|
| - key.Create(HKEY_CURRENT_USER, parent_key.c_str(), KEY_READ));
|
| -
|
| - std::wstring name_str(kNameStr);
|
| - std::wstring data_str(kDataStr1);
|
| scoped_ptr<SetRegValueWorkItem> work_item1(
|
| WorkItem::CreateSetRegValueWorkItem(HKEY_CURRENT_USER,
|
| - parent_key,
|
| + kTestKey,
|
| WorkItem::kWow64Default,
|
| - name_str,
|
| - data_str,
|
| + kNameStr,
|
| + kDataStr1,
|
| true));
|
|
|
| - std::wstring name_dword(kNameDword);
|
| scoped_ptr<SetRegValueWorkItem> work_item2(
|
| WorkItem::CreateSetRegValueWorkItem(HKEY_CURRENT_USER,
|
| - parent_key,
|
| + kTestKey,
|
| WorkItem::kWow64Default,
|
| - name_dword,
|
| - dword1,
|
| + kNameDword,
|
| + kDword1,
|
| true));
|
|
|
| - EXPECT_TRUE(work_item1->Do());
|
| - EXPECT_TRUE(work_item2->Do());
|
| + ASSERT_TRUE(work_item1->Do());
|
| + ASSERT_TRUE(work_item2->Do());
|
|
|
| std::wstring read_out;
|
| DWORD read_dword;
|
| - EXPECT_EQ(ERROR_SUCCESS, key.ReadValue(name_str.c_str(), &read_out));
|
| - EXPECT_EQ(ERROR_SUCCESS, key.ReadValueDW(name_dword.c_str(), &read_dword));
|
| + EXPECT_EQ(ERROR_SUCCESS, test_key_.ReadValue(kNameStr, &read_out));
|
| + EXPECT_EQ(ERROR_SUCCESS, test_key_.ReadValueDW(kNameDword, &read_dword));
|
| EXPECT_EQ(read_out, kDataStr1);
|
| - EXPECT_EQ(read_dword, dword1);
|
| + EXPECT_EQ(read_dword, kDword1);
|
|
|
| work_item1->Rollback();
|
| work_item2->Rollback();
|
|
|
| // Rollback should delete the value.
|
| - EXPECT_FALSE(key.HasValue(name_str.c_str()));
|
| - EXPECT_FALSE(key.HasValue(name_dword.c_str()));
|
| + EXPECT_FALSE(test_key_.HasValue(kNameStr));
|
| + EXPECT_FALSE(test_key_.HasValue(kNameDword));
|
| }
|
|
|
| // Write to an existing value without overwrite flag. There should be
|
| // no change.
|
| TEST_F(SetRegValueWorkItemTest, WriteExistingNonOverwrite) {
|
| - RegKey key;
|
| -
|
| - std::wstring parent_key(kTestRoot);
|
| - parent_key.append(&base::FilePath::kSeparators[0], 1);
|
| - parent_key.append(L"WriteExistingNonOverwrite");
|
| - ASSERT_EQ(ERROR_SUCCESS,
|
| - key.Create(HKEY_CURRENT_USER, parent_key.c_str(),
|
| - KEY_READ | KEY_SET_VALUE));
|
| -
|
| // First test REG_SZ value.
|
| // Write data to the value we are going to set.
|
| - std::wstring name(kNameStr);
|
| - ASSERT_EQ(ERROR_SUCCESS, key.WriteValue(name.c_str(), kDataStr1));
|
| + ASSERT_EQ(ERROR_SUCCESS, test_key_.WriteValue(kNameStr, kDataStr1));
|
|
|
| - std::wstring data(kDataStr2);
|
| scoped_ptr<SetRegValueWorkItem> work_item(
|
| WorkItem::CreateSetRegValueWorkItem(HKEY_CURRENT_USER,
|
| - parent_key,
|
| + kTestKey,
|
| WorkItem::kWow64Default,
|
| - name,
|
| - data,
|
| + kNameStr,
|
| + kDataStr2,
|
| false));
|
| - EXPECT_TRUE(work_item->Do());
|
| + ASSERT_TRUE(work_item->Do());
|
|
|
| std::wstring read_out;
|
| - EXPECT_EQ(ERROR_SUCCESS, key.ReadValue(name.c_str(), &read_out));
|
| - EXPECT_EQ(0, read_out.compare(kDataStr1));
|
| + EXPECT_EQ(ERROR_SUCCESS, test_key_.ReadValue(kNameStr, &read_out));
|
| + EXPECT_EQ(read_out, kDataStr1);
|
|
|
| work_item->Rollback();
|
| - EXPECT_TRUE(key.HasValue(name.c_str()));
|
| - EXPECT_EQ(ERROR_SUCCESS, key.ReadValue(name.c_str(), &read_out));
|
| + EXPECT_TRUE(test_key_.HasValue(kNameStr));
|
| + EXPECT_EQ(ERROR_SUCCESS, test_key_.ReadValue(kNameStr, &read_out));
|
| EXPECT_EQ(read_out, kDataStr1);
|
|
|
| // Now test REG_DWORD value.
|
| // Write data to the value we are going to set.
|
| - name.assign(kNameDword);
|
| - ASSERT_EQ(ERROR_SUCCESS, key.WriteValue(name.c_str(), dword1));
|
| + ASSERT_EQ(ERROR_SUCCESS, test_key_.WriteValue(kNameDword, kDword1));
|
| work_item.reset(WorkItem::CreateSetRegValueWorkItem(HKEY_CURRENT_USER,
|
| - parent_key,
|
| + kTestKey,
|
| WorkItem::kWow64Default,
|
| - name,
|
| - dword2,
|
| + kNameDword,
|
| + kDword2,
|
| false));
|
| - EXPECT_TRUE(work_item->Do());
|
| + ASSERT_TRUE(work_item->Do());
|
|
|
| DWORD read_dword;
|
| - EXPECT_EQ(ERROR_SUCCESS, key.ReadValueDW(name.c_str(), &read_dword));
|
| - EXPECT_EQ(read_dword, dword1);
|
| + EXPECT_EQ(ERROR_SUCCESS, test_key_.ReadValueDW(kNameDword, &read_dword));
|
| + EXPECT_EQ(read_dword, kDword1);
|
|
|
| work_item->Rollback();
|
| - EXPECT_TRUE(key.HasValue(name.c_str()));
|
| - EXPECT_EQ(ERROR_SUCCESS, key.ReadValueDW(name.c_str(), &read_dword));
|
| - EXPECT_EQ(read_dword, dword1);
|
| + EXPECT_TRUE(test_key_.HasValue(kNameDword));
|
| + EXPECT_EQ(ERROR_SUCCESS, test_key_.ReadValueDW(kNameDword, &read_dword));
|
| + EXPECT_EQ(read_dword, kDword1);
|
| }
|
|
|
| // Write to an existing value with overwrite flag. The value should be
|
| // overwritten.
|
| TEST_F(SetRegValueWorkItemTest, WriteExistingOverwrite) {
|
| - RegKey key;
|
| -
|
| - std::wstring parent_key(kTestRoot);
|
| - parent_key.append(&base::FilePath::kSeparators[0], 1);
|
| - parent_key.append(L"WriteExistingOverwrite");
|
| - ASSERT_EQ(ERROR_SUCCESS,
|
| - key.Create(HKEY_CURRENT_USER, parent_key.c_str(),
|
| - KEY_READ | KEY_SET_VALUE));
|
| -
|
| // First test REG_SZ value.
|
| // Write data to the value we are going to set.
|
| - std::wstring name(kNameStr);
|
| - ASSERT_EQ(ERROR_SUCCESS, key.WriteValue(name.c_str(), kDataStr1));
|
| + ASSERT_EQ(ERROR_SUCCESS, test_key_.WriteValue(kNameStr, kDataStr1));
|
|
|
| - std::wstring name_empty(L"name_empty");
|
| - ASSERT_EQ(ERROR_SUCCESS, RegSetValueEx(key.Handle(), name_empty.c_str(), NULL,
|
| + const wchar_t kNameEmpty[] = L"name_empty";
|
| + ASSERT_EQ(ERROR_SUCCESS, RegSetValueEx(test_key_.Handle(), kNameEmpty, NULL,
|
| REG_SZ, NULL, 0));
|
|
|
| - std::wstring data(kDataStr2);
|
| scoped_ptr<SetRegValueWorkItem> work_item1(
|
| WorkItem::CreateSetRegValueWorkItem(HKEY_CURRENT_USER,
|
| - parent_key,
|
| + kTestKey,
|
| WorkItem::kWow64Default,
|
| - name,
|
| - data,
|
| + kNameStr,
|
| + kDataStr2,
|
| true));
|
| scoped_ptr<SetRegValueWorkItem> work_item2(
|
| WorkItem::CreateSetRegValueWorkItem(HKEY_CURRENT_USER,
|
| - parent_key,
|
| + kTestKey,
|
| WorkItem::kWow64Default,
|
| - name_empty,
|
| - data,
|
| + kNameEmpty,
|
| + kDataStr2,
|
| true));
|
|
|
| - EXPECT_TRUE(work_item1->Do());
|
| - EXPECT_TRUE(work_item2->Do());
|
| + ASSERT_TRUE(work_item1->Do());
|
| + ASSERT_TRUE(work_item2->Do());
|
|
|
| std::wstring read_out;
|
| - EXPECT_EQ(ERROR_SUCCESS, key.ReadValue(name.c_str(), &read_out));
|
| - EXPECT_EQ(0, read_out.compare(kDataStr2));
|
| + EXPECT_EQ(ERROR_SUCCESS, test_key_.ReadValue(kNameStr, &read_out));
|
| + EXPECT_EQ(read_out, kDataStr2);
|
|
|
| - EXPECT_EQ(ERROR_SUCCESS, key.ReadValue(name_empty.c_str(), &read_out));
|
| - EXPECT_EQ(0, read_out.compare(kDataStr2));
|
| + EXPECT_EQ(ERROR_SUCCESS, test_key_.ReadValue(kNameEmpty, &read_out));
|
| + EXPECT_EQ(read_out, kDataStr2);
|
|
|
| work_item1->Rollback();
|
| work_item2->Rollback();
|
|
|
| - EXPECT_TRUE(key.HasValue(name.c_str()));
|
| - EXPECT_EQ(ERROR_SUCCESS, key.ReadValue(name.c_str(), &read_out));
|
| + EXPECT_TRUE(test_key_.HasValue(kNameStr));
|
| + EXPECT_EQ(ERROR_SUCCESS, test_key_.ReadValue(kNameStr, &read_out));
|
| EXPECT_EQ(read_out, kDataStr1);
|
|
|
| DWORD type = 0;
|
| DWORD size = 0;
|
| - EXPECT_EQ(ERROR_SUCCESS, key.ReadValue(name_empty.c_str(), NULL, &size,
|
| - &type));
|
| + EXPECT_EQ(ERROR_SUCCESS, test_key_.ReadValue(kNameEmpty, NULL, &size, &type));
|
| EXPECT_EQ(REG_SZ, type);
|
| EXPECT_EQ(0, size);
|
|
|
| // Now test REG_DWORD value.
|
| // Write data to the value we are going to set.
|
| - name.assign(kNameDword);
|
| - ASSERT_EQ(ERROR_SUCCESS, key.WriteValue(name.c_str(), dword1));
|
| + ASSERT_EQ(ERROR_SUCCESS, test_key_.WriteValue(kNameDword, kDword1));
|
| scoped_ptr<SetRegValueWorkItem> work_item3(
|
| WorkItem::CreateSetRegValueWorkItem(HKEY_CURRENT_USER,
|
| - parent_key,
|
| + kTestKey,
|
| WorkItem::kWow64Default,
|
| - name,
|
| - dword2,
|
| + kNameDword,
|
| + kDword2,
|
| true));
|
| - EXPECT_TRUE(work_item3->Do());
|
| + ASSERT_TRUE(work_item3->Do());
|
|
|
| DWORD read_dword;
|
| - EXPECT_EQ(ERROR_SUCCESS, key.ReadValueDW(name.c_str(), &read_dword));
|
| - EXPECT_EQ(read_dword, dword2);
|
| + EXPECT_EQ(ERROR_SUCCESS, test_key_.ReadValueDW(kNameDword, &read_dword));
|
| + EXPECT_EQ(read_dword, kDword2);
|
|
|
| work_item3->Rollback();
|
| - EXPECT_TRUE(key.HasValue(name.c_str()));
|
| - EXPECT_EQ(ERROR_SUCCESS, key.ReadValueDW(name.c_str(), &read_dword));
|
| - EXPECT_EQ(read_dword, dword1);
|
| + EXPECT_TRUE(test_key_.HasValue(kNameDword));
|
| + EXPECT_EQ(ERROR_SUCCESS, test_key_.ReadValueDW(kNameDword, &read_dword));
|
| + EXPECT_EQ(read_dword, kDword1);
|
| }
|
|
|
| // Write a value to a non-existing key. This should fail.
|
| TEST_F(SetRegValueWorkItemTest, WriteNonExistingKey) {
|
| - RegKey key;
|
| -
|
| - std::wstring parent_key(kTestRoot);
|
| - parent_key.append(&base::FilePath::kSeparators[0], 1);
|
| - parent_key.append(L"WriteNonExistingKey");
|
| + std::wstring non_existing(kTestKey);
|
| + non_existing.append(&base::FilePath::kSeparators[0], 1);
|
| + non_existing.append(L"NonExistingKey");
|
|
|
| - std::wstring name(L"name");
|
| - std::wstring data(kDataStr1);
|
| scoped_ptr<SetRegValueWorkItem> work_item(
|
| WorkItem::CreateSetRegValueWorkItem(HKEY_CURRENT_USER,
|
| - parent_key,
|
| + non_existing.c_str(),
|
| WorkItem::kWow64Default,
|
| - name,
|
| - data,
|
| + kNameStr,
|
| + kDataStr1,
|
| false));
|
| EXPECT_FALSE(work_item->Do());
|
|
|
| work_item.reset(WorkItem::CreateSetRegValueWorkItem(HKEY_CURRENT_USER,
|
| - parent_key,
|
| + non_existing.c_str(),
|
| WorkItem::kWow64Default,
|
| - name,
|
| - dword1,
|
| + kNameStr,
|
| + kDword1,
|
| false));
|
| EXPECT_FALSE(work_item->Do());
|
| }
|
| +
|
| +// Verifies that |actual_previous_value| is |expected_previous_value| and
|
| +// returns |desired_new_value| to replace it. Unconditionally increments
|
| +// |invocation_count| to allow tests to assert correctness of the callee's
|
| +// behaviour.
|
| +std::wstring VerifyPreviousValueAndReplace(
|
| + int* invocation_count,
|
| + const std::wstring& expected_previous_value,
|
| + const std::wstring& desired_new_value,
|
| + const std::wstring& actual_previous_value) {
|
| + ++(*invocation_count);
|
| + EXPECT_EQ(expected_previous_value, actual_previous_value);
|
| + return desired_new_value;
|
| +}
|
| +
|
| +// Modify an existing value with the callback API.
|
| +TEST_F(SetRegValueWorkItemTest, ModifyExistingWithCallback) {
|
| + // Write |kDataStr1| to the value we are going to modify.
|
| + ASSERT_EQ(ERROR_SUCCESS, test_key_.WriteValue(kNameStr, kDataStr1));
|
| +
|
| + int callback_invocation_count = 0;
|
| +
|
| + scoped_ptr<SetRegValueWorkItem> work_item(
|
| + WorkItem::CreateSetRegValueWorkItem(
|
| + HKEY_CURRENT_USER,
|
| + kTestKey,
|
| + WorkItem::kWow64Default,
|
| + kNameStr,
|
| + base::Bind(&VerifyPreviousValueAndReplace, &callback_invocation_count,
|
| + kDataStr1, kDataStr2)));
|
| +
|
| + // The callback should not be used until the item is executed.
|
| + EXPECT_EQ(0, callback_invocation_count);
|
| +
|
| + ASSERT_TRUE(work_item->Do());
|
| +
|
| + std::wstring read_out;
|
| + EXPECT_EQ(ERROR_SUCCESS, test_key_.ReadValue(kNameStr, &read_out));
|
| + EXPECT_EQ(read_out, kDataStr2);
|
| +
|
| + // The callback should have been used only once to achieve this result.
|
| + EXPECT_EQ(1, callback_invocation_count);
|
| +
|
| + work_item->Rollback();
|
| +
|
| + EXPECT_TRUE(test_key_.HasValue(kNameStr));
|
| + EXPECT_EQ(ERROR_SUCCESS, test_key_.ReadValue(kNameStr, &read_out));
|
| + EXPECT_EQ(read_out, kDataStr1);
|
| +
|
| + // The callback should not have been used again for the rollback.
|
| + EXPECT_EQ(1, callback_invocation_count);
|
| +}
|
| +
|
| +// Modify a non-existing value with the callback API.
|
| +TEST_F(SetRegValueWorkItemTest, ModifyNonExistingWithCallback) {
|
| + int callback_invocation_count = 0;
|
| +
|
| + scoped_ptr<SetRegValueWorkItem> work_item(
|
| + WorkItem::CreateSetRegValueWorkItem(
|
| + HKEY_CURRENT_USER,
|
| + kTestKey,
|
| + WorkItem::kWow64Default,
|
| + kNameStr,
|
| + base::Bind(&VerifyPreviousValueAndReplace, &callback_invocation_count,
|
| + L"", kDataStr1)));
|
| +
|
| + EXPECT_EQ(0, callback_invocation_count);
|
| +
|
| + ASSERT_TRUE(work_item->Do());
|
| +
|
| + std::wstring read_out;
|
| + EXPECT_EQ(ERROR_SUCCESS, test_key_.ReadValue(kNameStr, &read_out));
|
| + EXPECT_EQ(read_out, kDataStr1);
|
| +
|
| + EXPECT_EQ(1, callback_invocation_count);
|
| +
|
| + work_item->Rollback();
|
| +
|
| + EXPECT_FALSE(test_key_.HasValue(kNameStr));
|
| +
|
| + EXPECT_EQ(1, callback_invocation_count);
|
| +}
|
| +
|
| +// Modify an existing value which is not a string (REG_SZ) with the string
|
| +// callback API.
|
| +TEST_F(SetRegValueWorkItemTest, ModifyExistingNonStringWithStringCallback) {
|
| + // Write |kDword1| to the value we are going to modify.
|
| + ASSERT_EQ(ERROR_SUCCESS, test_key_.WriteValue(kNameStr, kDword1));
|
| +
|
| + int callback_invocation_count = 0;
|
| +
|
| + scoped_ptr<SetRegValueWorkItem> work_item(
|
| + WorkItem::CreateSetRegValueWorkItem(
|
| + HKEY_CURRENT_USER,
|
| + kTestKey,
|
| + WorkItem::kWow64Default,
|
| + kNameStr,
|
| + base::Bind(&VerifyPreviousValueAndReplace, &callback_invocation_count,
|
| + L"", kDataStr1)));
|
| +
|
| + EXPECT_EQ(0, callback_invocation_count);
|
| +
|
| + ASSERT_TRUE(work_item->Do());
|
| +
|
| + std::wstring read_str_out;
|
| + EXPECT_EQ(ERROR_SUCCESS, test_key_.ReadValue(kNameStr, &read_str_out));
|
| + EXPECT_EQ(read_str_out, kDataStr1);
|
| +
|
| + EXPECT_EQ(1, callback_invocation_count);
|
| +
|
| + work_item->Rollback();
|
| +
|
| + DWORD read_dword_out = 0;
|
| + EXPECT_TRUE(test_key_.HasValue(kNameStr));
|
| + EXPECT_EQ(ERROR_SUCCESS, test_key_.ReadValueDW(kNameStr, &read_dword_out));
|
| + EXPECT_EQ(read_dword_out, kDword1);
|
| +
|
| + EXPECT_EQ(1, callback_invocation_count);
|
| +}
|
|
|