diff options
author | mnissler@chromium.org <mnissler@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2010-05-14 13:17:40 +0000 |
---|---|---|
committer | mnissler@chromium.org <mnissler@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2010-05-14 13:17:40 +0000 |
commit | c378cca3b4c7f2c48184283f3ab2ac5818233037 (patch) | |
tree | ae94b40eb8fb1432307a80818f6ee04437e149cf /base/values_unittest.cc | |
parent | 70c19a930beddde0e382777cb8799e7c8ebb1625 (diff) | |
download | chromium_src-c378cca3b4c7f2c48184283f3ab2ac5818233037.zip chromium_src-c378cca3b4c7f2c48184283f3ab2ac5818233037.tar.gz chromium_src-c378cca3b4c7f2c48184283f3ab2ac5818233037.tar.bz2 |
Preference provider implementation backed by JSON files in a directory.
BUG=42412
TEST=Unit tests in chrome/browser/value_tree_policy_decoder.cc and base/values_unittest.cc
Review URL: http://codereview.chromium.org/2027010
git-svn-id: svn://svn.chromium.org/chrome/trunk/src@47269 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'base/values_unittest.cc')
-rw-r--r-- | base/values_unittest.cc | 47 |
1 files changed, 46 insertions, 1 deletions
diff --git a/base/values_unittest.cc b/base/values_unittest.cc index a0ab47f..8aa8359 100644 --- a/base/values_unittest.cc +++ b/base/values_unittest.cc @@ -1,4 +1,4 @@ -// Copyright (c) 2009 The Chromium Authors. All rights reserved. +// Copyright (c) 2010 The Chromium Authors. All rights reserved. // Use of this source code is governed by a BSD-style license that can be // found in the LICENSE file. @@ -592,3 +592,48 @@ TEST(ValuesTest, RemoveEmptyChildren) { EXPECT_EQ(1U, inner2->GetSize()); } } + +TEST(ValuesTest, MergeDictionary) { + scoped_ptr<DictionaryValue> base(new DictionaryValue); + base->SetString(L"base_key", "base_key_value_base"); + base->SetString(L"collide_key", "collide_key_value_base"); + DictionaryValue* base_sub_dict = new DictionaryValue; + base_sub_dict->SetString(L"sub_base_key", "sub_base_key_value_base"); + base_sub_dict->SetString(L"sub_collide_key", "sub_collide_key_value_base"); + base->Set(L"sub_dict_key", base_sub_dict); + + scoped_ptr<DictionaryValue> merge(new DictionaryValue); + merge->SetString(L"merge_key", "merge_key_value_merge"); + merge->SetString(L"collide_key", "collide_key_value_merge"); + DictionaryValue* merge_sub_dict = new DictionaryValue; + merge_sub_dict->SetString(L"sub_merge_key", "sub_merge_key_value_merge"); + merge_sub_dict->SetString(L"sub_collide_key", "sub_collide_key_value_merge"); + merge->Set(L"sub_dict_key", merge_sub_dict); + + base->MergeDictionary(merge.get()); + + EXPECT_EQ(4U, base->size()); + std::string base_key_value; + EXPECT_TRUE(base->GetString(L"base_key", &base_key_value)); + EXPECT_EQ("base_key_value_base", base_key_value); // Base value preserved. + std::string collide_key_value; + EXPECT_TRUE(base->GetString(L"collide_key", &collide_key_value)); + EXPECT_EQ("collide_key_value_merge", collide_key_value); // Replaced. + std::string merge_key_value; + EXPECT_TRUE(base->GetString(L"merge_key", &merge_key_value)); + EXPECT_EQ("merge_key_value_merge", merge_key_value); // Merged in. + + DictionaryValue* res_sub_dict; + EXPECT_TRUE(base->GetDictionary(L"sub_dict_key", &res_sub_dict)); + EXPECT_EQ(3U, res_sub_dict->size()); + std::string sub_base_key_value; + EXPECT_TRUE(res_sub_dict->GetString(L"sub_base_key", &sub_base_key_value)); + EXPECT_EQ("sub_base_key_value_base", sub_base_key_value); // Preserved. + std::string sub_collide_key_value; + EXPECT_TRUE(res_sub_dict->GetString(L"sub_collide_key", + &sub_collide_key_value)); + EXPECT_EQ("sub_collide_key_value_merge", sub_collide_key_value); // Replaced. + std::string sub_merge_key_value; + EXPECT_TRUE(res_sub_dict->GetString(L"sub_merge_key", &sub_merge_key_value)); + EXPECT_EQ("sub_merge_key_value_merge", sub_merge_key_value); // Merged in. +} |