| Index: chrome/browser/protector/composite_settings_change_unittest.cc
 | 
| diff --git a/chrome/browser/protector/composite_settings_change_unittest.cc b/chrome/browser/protector/composite_settings_change_unittest.cc
 | 
| deleted file mode 100644
 | 
| index 56ac4f7223d42af73945ef360b5b494afaeb81bc..0000000000000000000000000000000000000000
 | 
| --- a/chrome/browser/protector/composite_settings_change_unittest.cc
 | 
| +++ /dev/null
 | 
| @@ -1,122 +0,0 @@
 | 
| -// Copyright (c) 2012 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/utf_string_conversions.h"
 | 
| -#include "chrome/browser/protector/composite_settings_change.h"
 | 
| -#include "chrome/browser/protector/mock_setting_change.h"
 | 
| -#include "chrome/test/base/testing_profile.h"
 | 
| -#include "testing/gtest/include/gtest/gtest.h"
 | 
| -#include "grit/generated_resources.h"
 | 
| -#include "ui/base/l10n/l10n_util.h"
 | 
| -
 | 
| -using ::testing::NiceMock;
 | 
| -using ::testing::Return;
 | 
| -
 | 
| -namespace protector {
 | 
| -
 | 
| -namespace {
 | 
| -
 | 
| -string16 kTitle1 = ASCIIToUTF16("A");
 | 
| -string16 kTitle2 = ASCIIToUTF16("B");
 | 
| -string16 kTitle3 = ASCIIToUTF16("C");
 | 
| -
 | 
| -};
 | 
| -
 | 
| -class CompositeSettingsChangeTest : public testing::Test {
 | 
| - protected:
 | 
| -  string16 GetApplyButtonText(const string16& apply_text) {
 | 
| -    return l10n_util::GetStringFUTF16(IDS_CHANGE_SETTING, apply_text);
 | 
| -  }
 | 
| -
 | 
| -  TestingProfile profile_;
 | 
| -};
 | 
| -
 | 
| -// Verify that MergeWith works and Apply/Discard/Timeout call same functions
 | 
| -// of all merged changes.
 | 
| -TEST_F(CompositeSettingsChangeTest, MergeWith) {
 | 
| -  // These instances will be owned by CompositeSettingsChange.
 | 
| -  MockSettingChange* change1 = new NiceMock<MockSettingChange>;
 | 
| -  MockSettingChange* change2 = new NiceMock<MockSettingChange>;
 | 
| -  MockSettingChange* change3 = new NiceMock<MockSettingChange>;
 | 
| -
 | 
| -  EXPECT_CALL(*change1, MockInit(&profile_)).WillOnce(Return(true));
 | 
| -  ASSERT_TRUE(change1->Init(&profile_));
 | 
| -  EXPECT_CALL(*change2, MockInit(&profile_)).WillOnce(Return(true));
 | 
| -  ASSERT_TRUE(change2->Init(&profile_));
 | 
| -  EXPECT_CALL(*change3, MockInit(&profile_)).WillOnce(Return(true));
 | 
| -  ASSERT_TRUE(change3->Init(&profile_));
 | 
| -
 | 
| -  // Compose 1st and 2nd changes together.
 | 
| -  scoped_ptr<CompositeSettingsChange> composite_change(
 | 
| -      change1->MergeWith(change2));
 | 
| -
 | 
| -  EXPECT_TRUE(composite_change->Contains(change1));
 | 
| -  EXPECT_TRUE(composite_change->Contains(change2));
 | 
| -  EXPECT_FALSE(composite_change->Contains(change3));
 | 
| -  EXPECT_TRUE(composite_change->Contains(composite_change.get()));
 | 
| -
 | 
| -  // Add third change.
 | 
| -  EXPECT_EQ(composite_change.get(), composite_change->MergeWith(change3));
 | 
| -
 | 
| -  EXPECT_TRUE(composite_change->Contains(change1));
 | 
| -  EXPECT_TRUE(composite_change->Contains(change2));
 | 
| -  EXPECT_TRUE(composite_change->Contains(change3));
 | 
| -  EXPECT_TRUE(composite_change->Contains(composite_change.get()));
 | 
| -
 | 
| -  // Apply/Discard/Timeout calls should be proxied to inner change instances:
 | 
| -  EXPECT_CALL(*change1, Apply(NULL));
 | 
| -  EXPECT_CALL(*change2, Apply(NULL));
 | 
| -  EXPECT_CALL(*change3, Apply(NULL));
 | 
| -  composite_change->Apply(NULL);
 | 
| -
 | 
| -  EXPECT_CALL(*change1, Discard(NULL));
 | 
| -  EXPECT_CALL(*change2, Discard(NULL));
 | 
| -  EXPECT_CALL(*change3, Discard(NULL));
 | 
| -  composite_change->Discard(NULL);
 | 
| -
 | 
| -  EXPECT_CALL(*change1, Timeout());
 | 
| -  EXPECT_CALL(*change2, Timeout());
 | 
| -  EXPECT_CALL(*change3, Timeout());
 | 
| -  composite_change->Timeout();
 | 
| -}
 | 
| -
 | 
| -TEST_F(CompositeSettingsChangeTest, ApplyButtonText) {
 | 
| -  // These instances will be owned by CompositeSettingsChange.
 | 
| -  MockSettingChange* change1 = new NiceMock<MockSettingChange>;
 | 
| -  MockSettingChange* change2 = new NiceMock<MockSettingChange>;
 | 
| -  MockSettingChange* change3 = new NiceMock<MockSettingChange>;
 | 
| -
 | 
| -  EXPECT_CALL(*change1, MockInit(&profile_)).WillOnce(Return(true));
 | 
| -  ASSERT_TRUE(change1->Init(&profile_));
 | 
| -  EXPECT_CALL(*change2, MockInit(&profile_)).WillOnce(Return(true));
 | 
| -  ASSERT_TRUE(change2->Init(&profile_));
 | 
| -  EXPECT_CALL(*change3, MockInit(&profile_)).WillOnce(Return(true));
 | 
| -  ASSERT_TRUE(change3->Init(&profile_));
 | 
| -
 | 
| -  // |change1| has higher priority.
 | 
| -  EXPECT_CALL(*change1, GetApplyDisplayName()).WillOnce(
 | 
| -      Return(BaseSettingChange::DisplayName(10, kTitle1)));
 | 
| -  EXPECT_CALL(*change2, GetApplyDisplayName()).WillOnce(
 | 
| -      Return(BaseSettingChange::DisplayName(5, kTitle2)));
 | 
| -
 | 
| -  scoped_ptr<CompositeSettingsChange> composite_change(
 | 
| -      change1->MergeWith(change2));
 | 
| -
 | 
| -  EXPECT_EQ(GetApplyButtonText(kTitle1),
 | 
| -            composite_change->GetApplyButtonText());
 | 
| -
 | 
| -  // |change3| has the highest priority now.
 | 
| -  EXPECT_CALL(*change3, GetApplyDisplayName()).WillOnce(
 | 
| -      Return(BaseSettingChange::DisplayName(15, kTitle3)));
 | 
| -  EXPECT_EQ(composite_change.get(), composite_change->MergeWith(change3));
 | 
| -
 | 
| -  EXPECT_EQ(GetApplyButtonText(kTitle3),
 | 
| -            composite_change->GetApplyButtonText());
 | 
| -
 | 
| -  GURL url1("example.com");
 | 
| -  EXPECT_CALL(*change1, GetNewSettingURL()).WillOnce(Return(url1));
 | 
| -  EXPECT_EQ(url1, composite_change->GetNewSettingURL());
 | 
| -}
 | 
| -
 | 
| -}  // namespace protector
 | 
| 
 |