Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(332)

Unified Diff: sync/api/sync_data_unittest.cc

Issue 187303006: Update sync API to support attachments. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@attachmentapi
Patch Set: Pull in upstream changes. Created 6 years, 9 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
Index: sync/api/sync_data_unittest.cc
diff --git a/sync/api/sync_data_unittest.cc b/sync/api/sync_data_unittest.cc
index 19d88d43053732bbe6789ea057b5449bf56ee5ed..a73ee7c6cbc79b93e2bf54e69282ef79ef0e1ab8 100644
--- a/sync/api/sync_data_unittest.cc
+++ b/sync/api/sync_data_unittest.cc
@@ -6,7 +6,10 @@
#include <string>
+#include "base/memory/ref_counted_memory.h"
#include "base/time/time.h"
+#include "sync/api/attachments/attachment_service.h"
+#include "sync/api/attachments/fake_attachment_service.h"
#include "sync/protocol/sync.pb.h"
#include "testing/gtest/include/gtest/gtest.h"
@@ -22,7 +25,21 @@ const string kNonUniqueTitle = "my preference";
const int64 kId = 439829;
const base::Time kLastModifiedTime = base::Time();
-typedef testing::Test SyncDataTest;
+class SyncDataTest : public testing::Test {
+ protected:
+ SyncDataTest()
+ : attachment_service(FakeAttachmentService::CreateForTest()),
+ attachment_service_weak_ptr_factory(attachment_service.get()),
+ attachment_service_weak_handle(
+ MakeWeakHandle(attachment_service_weak_ptr_factory.GetWeakPtr())) {}
+
+ sync_pb::EntitySpecifics specifics;
+
+ scoped_ptr<AttachmentService> attachment_service;
+ base::WeakPtrFactory<syncer::AttachmentService>
+ attachment_service_weak_ptr_factory;
+ WeakHandle<syncer::AttachmentService> attachment_service_weak_handle;
+};
TEST_F(SyncDataTest, NoArgCtor) {
SyncData data;
@@ -38,7 +55,6 @@ TEST_F(SyncDataTest, CreateLocalDelete) {
}
TEST_F(SyncDataTest, CreateLocalData) {
- sync_pb::EntitySpecifics specifics;
specifics.mutable_preference();
SyncData data =
SyncData::CreateLocalData(kSyncTag, kNonUniqueTitle, specifics);
@@ -50,8 +66,56 @@ TEST_F(SyncDataTest, CreateLocalData) {
EXPECT_TRUE(data.GetSpecifics().has_preference());
}
+TEST_F(SyncDataTest, CreateLocalDataWithAttachments) {
+ specifics.mutable_preference();
+ scoped_refptr<base::RefCountedMemory> bytes(new base::RefCountedString);
+ AttachmentList attachments;
+ attachments.push_back(Attachment::Create(bytes));
+ attachments.push_back(Attachment::Create(bytes));
+ attachments.push_back(Attachment::Create(bytes));
+
+ SyncData data = SyncData::CreateLocalDataWithAttachments(
+ kSyncTag, kNonUniqueTitle, specifics, attachments);
+ EXPECT_TRUE(data.IsValid());
+ EXPECT_TRUE(data.IsLocal());
+ EXPECT_EQ(kSyncTag, data.GetTag());
+ EXPECT_EQ(kDatatype, data.GetDataType());
+ EXPECT_EQ(kNonUniqueTitle, data.GetTitle());
+ EXPECT_TRUE(data.GetSpecifics().has_preference());
+ AttachmentIdList attachment_ids = data.GetAttachmentIds();
+ EXPECT_EQ(3U, attachment_ids.size());
+}
+
+TEST_F(SyncDataTest, CreateLocalDataWithAttachments_EmptyListOfAttachments) {
+ specifics.mutable_preference();
+ AttachmentList attachments;
+ SyncData data = SyncData::CreateLocalDataWithAttachments(
+ kSyncTag, kNonUniqueTitle, specifics, attachments);
+ EXPECT_TRUE(data.IsValid());
+ EXPECT_TRUE(data.IsLocal());
+ EXPECT_EQ(kSyncTag, data.GetTag());
+ EXPECT_EQ(kDatatype, data.GetDataType());
+ EXPECT_EQ(kNonUniqueTitle, data.GetTitle());
+ EXPECT_TRUE(data.GetSpecifics().has_preference());
+ EXPECT_TRUE(data.GetAttachmentIds().empty());
+}
+
TEST_F(SyncDataTest, CreateRemoteData) {
- sync_pb::EntitySpecifics specifics;
+ specifics.mutable_preference();
+ SyncData data = SyncData::CreateRemoteData(kId,
+ specifics,
+ kLastModifiedTime,
+ attachment_service_weak_handle,
+ AttachmentIdList());
+ EXPECT_TRUE(data.IsValid());
+ EXPECT_FALSE(data.IsLocal());
+ EXPECT_EQ(kId, data.GetRemoteId());
+ EXPECT_EQ(kLastModifiedTime, data.GetRemoteModifiedTime());
+ EXPECT_TRUE(data.GetSpecifics().has_preference());
+ EXPECT_TRUE(data.GetAttachmentIds().empty());
+}
+
+TEST_F(SyncDataTest, CreateRemoteData_WithoutAttachmentService) {
specifics.mutable_preference();
SyncData data = SyncData::CreateRemoteData(kId, specifics, kLastModifiedTime);
EXPECT_TRUE(data.IsValid());
@@ -61,6 +125,9 @@ TEST_F(SyncDataTest, CreateRemoteData) {
EXPECT_TRUE(data.GetSpecifics().has_preference());
}
+// TODO(maniscalco): Add test cases that verify GetAttachments and
+// DropAttachments calls are passed through to the underlying AttachmentService.
+
} // namespace
} // namespace syncer
« sync/api/sync_data.cc ('K') | « sync/api/sync_data.cc ('k') | sync/protocol/sync.proto » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698