Chromium Code Reviews| Index: chrome/browser/managed_mode/managed_user_settings_service_unittest.cc |
| diff --git a/chrome/browser/managed_mode/managed_user_settings_service_unittest.cc b/chrome/browser/managed_mode/managed_user_settings_service_unittest.cc |
| new file mode 100644 |
| index 0000000000000000000000000000000000000000..2674bd126949a86183e5a8f7a09a3736f3e8820f |
| --- /dev/null |
| +++ b/chrome/browser/managed_mode/managed_user_settings_service_unittest.cc |
| @@ -0,0 +1,64 @@ |
| +// Copyright (c) 2012 The Chromium Authors. All rights reserved. |
|
Pam (message me for reviews)
2013/09/04 10:21:47
2013
Bernhard Bauer
2013/09/04 11:56:19
Done (although I think the commit queue fixes that
|
| +// Use of this source code is governed by a BSD-style license that can be |
| +// found in the LICENSE file. |
| + |
| +#include "base/bind.h" |
| +#include "base/callback.h" |
| +#include "base/prefs/testing_pref_store.h" |
| +#include "chrome/browser/managed_mode/managed_user_settings_service.h" |
| +#include "testing/gtest/include/gtest/gtest.h" |
| + |
| +const char kAtomicItemName[] = "X-Wombat"; |
| +const char kSettingsName[] = "TestingSetting"; |
| +const char kSettingsValue[] = "SettingsValue"; |
| +const char kSplitItemName[] = "X-SuperMoosePowers"; |
| + |
| +class ManagedUserSettingsServiceTest : public ::testing::Test { |
| + protected: |
| + ManagedUserSettingsServiceTest() {} |
| + virtual ~ManagedUserSettingsServiceTest() {} |
| + |
| + void OnNewSettingsAvailable(const base::DictionaryValue* settings) { |
| + if (!settings) |
| + settings_.reset(); |
| + else |
| + settings_.reset(settings->DeepCopy()); |
| + } |
| + |
| + // testing::Test overrides: |
| + virtual void SetUp() OVERRIDE { |
| + TestingPrefStore* pref_store = new TestingPrefStore; |
| + settings_service_.Init(pref_store); |
| + settings_service_.Subscribe( |
| + base::Bind(&ManagedUserSettingsServiceTest::OnNewSettingsAvailable, |
| + base::Unretained(this))); |
| + pref_store->SetInitializationCompleted(); |
| + ASSERT_FALSE(settings_); |
| + settings_service_.Activate(); |
| + ASSERT_TRUE(settings_); |
| + } |
| + |
| + virtual void TearDown() OVERRIDE { |
| + settings_service_.Shutdown(); |
| + } |
| + |
| + base::DictionaryValue split_items_; |
| + scoped_ptr<base::Value> atomic_setting_value_; |
| + ManagedUserSettingsService settings_service_; |
| + scoped_ptr<base::DictionaryValue> settings_; |
| +}; |
| + |
| +TEST_F(ManagedUserSettingsServiceTest, SetLocalSetting) { |
| + const base::Value* value = NULL; |
| + EXPECT_FALSE(settings_->GetWithoutPathExpansion(kSettingsName, &value)); |
| + |
| + settings_.reset(); |
| + settings_service_.SetLocalSettingForTesting( |
| + kSettingsName, |
| + scoped_ptr<base::Value>(new base::StringValue(kSettingsValue))); |
| + ASSERT_TRUE(settings_); |
| + ASSERT_TRUE(settings_->GetWithoutPathExpansion(kSettingsName, &value)); |
| + std::string string_value; |
| + EXPECT_TRUE(value->GetAsString(&string_value)); |
| + EXPECT_EQ(kSettingsValue, string_value); |
| +} |