| Index: sync/internal_api/public/change_record_unittest.cc
|
| diff --git a/sync/internal_api/public/change_record_unittest.cc b/sync/internal_api/public/change_record_unittest.cc
|
| deleted file mode 100644
|
| index 2a5fa550d9ced58fbd857c33a62b357052e56b9f..0000000000000000000000000000000000000000
|
| --- a/sync/internal_api/public/change_record_unittest.cc
|
| +++ /dev/null
|
| @@ -1,166 +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 "sync/internal_api/public/change_record.h"
|
| -
|
| -#include <stddef.h>
|
| -#include <stdint.h>
|
| -
|
| -#include <memory>
|
| -#include <string>
|
| -#include <utility>
|
| -
|
| -#include "base/strings/string_number_conversions.h"
|
| -#include "base/test/values_test_util.h"
|
| -#include "base/values.h"
|
| -#include "sync/protocol/extension_specifics.pb.h"
|
| -#include "sync/protocol/proto_value_conversions.h"
|
| -#include "sync/protocol/sync.pb.h"
|
| -#include "testing/gmock/include/gmock/gmock.h"
|
| -#include "testing/gtest/include/gtest/gtest.h"
|
| -
|
| -namespace syncer {
|
| -namespace {
|
| -
|
| -using base::ExpectDictDictionaryValue;
|
| -using base::ExpectDictStringValue;
|
| -using testing::Invoke;
|
| -using testing::StrictMock;
|
| -
|
| -class ChangeRecordTest : public testing::Test {};
|
| -
|
| -void ExpectChangeRecordActionValue(ChangeRecord::Action expected_value,
|
| - const base::DictionaryValue& value,
|
| - const std::string& key) {
|
| - std::string str_value;
|
| - EXPECT_TRUE(value.GetString(key, &str_value));
|
| - switch (expected_value) {
|
| - case ChangeRecord::ACTION_ADD:
|
| - EXPECT_EQ("Add", str_value);
|
| - break;
|
| - case ChangeRecord::ACTION_UPDATE:
|
| - EXPECT_EQ("Update", str_value);
|
| - break;
|
| - case ChangeRecord::ACTION_DELETE:
|
| - EXPECT_EQ("Delete", str_value);
|
| - break;
|
| - default:
|
| - NOTREACHED();
|
| - break;
|
| - }
|
| -}
|
| -
|
| -void CheckChangeRecordValue(
|
| - const ChangeRecord& record,
|
| - const base::DictionaryValue& value) {
|
| - ExpectChangeRecordActionValue(record.action, value, "action");
|
| - ExpectDictStringValue(base::Int64ToString(record.id), value, "id");
|
| - if (record.action == ChangeRecord::ACTION_DELETE) {
|
| - std::unique_ptr<base::DictionaryValue> expected_extra_value;
|
| - if (record.extra.get()) {
|
| - expected_extra_value = record.extra->ToValue();
|
| - }
|
| - const base::Value* extra_value = NULL;
|
| - EXPECT_EQ(record.extra.get() != NULL,
|
| - value.Get("extra", &extra_value));
|
| - EXPECT_TRUE(base::Value::Equals(extra_value, expected_extra_value.get()));
|
| -
|
| - std::unique_ptr<base::DictionaryValue> expected_specifics_value(
|
| - EntitySpecificsToValue(record.specifics));
|
| - ExpectDictDictionaryValue(*expected_specifics_value,
|
| - value, "specifics");
|
| - }
|
| -}
|
| -
|
| -class TestExtraChangeRecordData : public ExtraPasswordChangeRecordData {
|
| - public:
|
| - TestExtraChangeRecordData()
|
| - : to_value_calls_(0), expected_to_value_calls_(0) {}
|
| -
|
| - ~TestExtraChangeRecordData() override {
|
| - EXPECT_EQ(expected_to_value_calls_, to_value_calls_);
|
| - }
|
| -
|
| - std::unique_ptr<base::DictionaryValue> ToValue() const override {
|
| - const_cast<TestExtraChangeRecordData*>(this)->to_value_calls_++;
|
| - return dict_->CreateDeepCopy();
|
| - }
|
| -
|
| - void set_dictionary_value(std::unique_ptr<base::DictionaryValue> dict) {
|
| - dict_ = std::move(dict);
|
| - }
|
| -
|
| - void set_expected_to_value_calls(size_t expectation) {
|
| - expected_to_value_calls_ = expectation;
|
| - }
|
| -
|
| - private:
|
| - std::unique_ptr<base::DictionaryValue> dict_;
|
| - size_t to_value_calls_;
|
| - size_t expected_to_value_calls_;
|
| -};
|
| -
|
| -TEST_F(ChangeRecordTest, ChangeRecordToValue) {
|
| - sync_pb::EntitySpecifics old_specifics;
|
| - old_specifics.mutable_extension()->set_id("old");
|
| - sync_pb::EntitySpecifics new_specifics;
|
| - old_specifics.mutable_extension()->set_id("new");
|
| -
|
| - const int64_t kTestId = 5;
|
| -
|
| - // Add
|
| - {
|
| - ChangeRecord record;
|
| - record.action = ChangeRecord::ACTION_ADD;
|
| - record.id = kTestId;
|
| - record.specifics = old_specifics;
|
| - record.extra.reset(new TestExtraChangeRecordData());
|
| - std::unique_ptr<base::DictionaryValue> value(record.ToValue());
|
| - CheckChangeRecordValue(record, *value);
|
| - }
|
| -
|
| - // Update
|
| - {
|
| - ChangeRecord record;
|
| - record.action = ChangeRecord::ACTION_UPDATE;
|
| - record.id = kTestId;
|
| - record.specifics = old_specifics;
|
| - record.extra.reset(new TestExtraChangeRecordData());
|
| - std::unique_ptr<base::DictionaryValue> value(record.ToValue());
|
| - CheckChangeRecordValue(record, *value);
|
| - }
|
| -
|
| - // Delete (no extra)
|
| - {
|
| - ChangeRecord record;
|
| - record.action = ChangeRecord::ACTION_DELETE;
|
| - record.id = kTestId;
|
| - record.specifics = old_specifics;
|
| - std::unique_ptr<base::DictionaryValue> value(record.ToValue());
|
| - CheckChangeRecordValue(record, *value);
|
| - }
|
| -
|
| - // Delete (with extra)
|
| - {
|
| - ChangeRecord record;
|
| - record.action = ChangeRecord::ACTION_DELETE;
|
| - record.id = kTestId;
|
| - record.specifics = old_specifics;
|
| -
|
| - std::unique_ptr<base::DictionaryValue> extra_value(
|
| - new base::DictionaryValue());
|
| - extra_value->SetString("foo", "bar");
|
| - std::unique_ptr<TestExtraChangeRecordData> extra(
|
| - new TestExtraChangeRecordData());
|
| - extra->set_dictionary_value(std::move(extra_value));
|
| - extra->set_expected_to_value_calls(2U);
|
| -
|
| - record.extra.reset(extra.release());
|
| - std::unique_ptr<base::DictionaryValue> value(record.ToValue());
|
| - CheckChangeRecordValue(record, *value);
|
| - }
|
| -}
|
| -
|
| -} // namespace
|
| -} // namespace syncer
|
|
|