Chromium Code Reviews| Index: chrome/browser/managed_mode/managed_user_shared_settings_update_unittest.cc |
| diff --git a/chrome/browser/managed_mode/managed_user_shared_settings_update_unittest.cc b/chrome/browser/managed_mode/managed_user_shared_settings_update_unittest.cc |
| new file mode 100644 |
| index 0000000000000000000000000000000000000000..a806e94ba4ce5d17eb01f777c5c9be8b5d28179b |
| --- /dev/null |
| +++ b/chrome/browser/managed_mode/managed_user_shared_settings_update_unittest.cc |
| @@ -0,0 +1,85 @@ |
| +// Copyright 2013 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. |
| + |
| +#include "base/bind.h" |
| +#include "base/memory/scoped_ptr.h" |
| +#include "chrome/browser/managed_mode/managed_user_shared_settings_service.h" |
| +#include "chrome/browser/managed_mode/managed_user_shared_settings_update.h" |
| +#include "chrome/test/base/testing_profile.h" |
| +#include "sync/api/sync_change.h" |
| +#include "testing/gtest/include/gtest/gtest.h" |
| + |
| +class ManagedUserSharedSettingsUpdateTest : public testing::Test { |
| + public: |
| + ManagedUserSharedSettingsUpdateTest() : service_(profile_.GetPrefs()) {} |
| + virtual ~ManagedUserSharedSettingsUpdateTest() {} |
| + |
| + void OnSettingUpdated(bool success) { |
| + result_.reset(new bool(success)); |
| + } |
| + |
| + protected: |
| + TestingProfile profile_; |
| + ManagedUserSharedSettingsService service_; |
| + scoped_ptr<bool> result_; |
| +}; |
| + |
| +TEST_F(ManagedUserSharedSettingsUpdateTest, Success) { |
| + ManagedUserSharedSettingsUpdate update( |
| + &service_, |
| + "abcdef", |
| + "name", |
| + scoped_ptr<base::Value>(new base::StringValue("Hans Moleman")), |
| + base::Bind(&ManagedUserSharedSettingsUpdateTest::OnSettingUpdated, |
| + base::Unretained(this))); |
| + syncer::SyncChangeList changes; |
| + changes.push_back(syncer::SyncChange( |
| + FROM_HERE, |
| + syncer::SyncChange::ACTION_UPDATE, |
| + ManagedUserSharedSettingsService::CreateSyncDataForSetting( |
| + "abcdef", "name", base::StringValue("Hans Moleman"), true))); |
| + syncer::SyncError error = service_.ProcessSyncChanges(FROM_HERE, changes); |
| + EXPECT_FALSE(error.IsSet()) << error.ToString(); |
| + ASSERT_TRUE(result_); |
| + EXPECT_TRUE(*result_); |
| +} |
| + |
| +TEST_F(ManagedUserSharedSettingsUpdateTest, Failure) { |
| + ManagedUserSharedSettingsUpdate update( |
| + &service_, |
| + "abcdef", |
| + "name", |
| + scoped_ptr<base::Value>(new base::StringValue("Hans Moleman")), |
| + base::Bind(&ManagedUserSharedSettingsUpdateTest::OnSettingUpdated, |
| + base::Unretained(this))); |
| + |
| + // Syncing down another change will cause the update to fail. |
|
Pam (message me for reviews)
2014/01/08 12:19:28
A different change, right? Because of the differen
Bernhard Bauer
2014/01/08 12:59:42
Right, done.
|
| + syncer::SyncChangeList changes; |
| + changes.push_back(syncer::SyncChange( |
| + FROM_HERE, |
| + syncer::SyncChange::ACTION_UPDATE, |
| + ManagedUserSharedSettingsService::CreateSyncDataForSetting( |
| + "abcdef", |
| + "name", |
| + base::StringValue("Barney Gumble"), |
| + true))); |
| + syncer::SyncError error = service_.ProcessSyncChanges(FROM_HERE, changes); |
| + EXPECT_FALSE(error.IsSet()) << error.ToString(); |
| + ASSERT_TRUE(result_); |
| + EXPECT_FALSE(*result_); |
| +} |
| + |
| +TEST_F(ManagedUserSharedSettingsUpdateTest, Cancel) { |
| + { |
| + ManagedUserSharedSettingsUpdate update( |
| + &service_, |
| + "abcdef", |
| + "name", |
| + scoped_ptr<base::Value>(new base::StringValue("Hans Moleman")), |
| + base::Bind(&ManagedUserSharedSettingsUpdateTest::OnSettingUpdated, |
| + base::Unretained(this))); |
| + ASSERT_FALSE(result_); |
| + } |
| + ASSERT_FALSE(result_); |
| +} |