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

Unified Diff: sync/api/attachments/fake_attachment_store_unittest.cc

Issue 601553004: Refactor FakeAttachmentStore (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Newline Created 6 years, 3 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/attachments/fake_attachment_store_unittest.cc
diff --git a/sync/api/attachments/fake_attachment_store_unittest.cc b/sync/api/attachments/fake_attachment_store_unittest.cc
deleted file mode 100644
index 71b9e50c396b73823b47c1eea1f2a0ec09237e47..0000000000000000000000000000000000000000
--- a/sync/api/attachments/fake_attachment_store_unittest.cc
+++ /dev/null
@@ -1,257 +0,0 @@
-// Copyright 2014 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/api/attachments/fake_attachment_store.h"
-
-#include "base/bind.h"
-#include "base/memory/ref_counted_memory.h"
-#include "base/memory/scoped_ptr.h"
-#include "base/message_loop/message_loop.h"
-#include "base/thread_task_runner_handle.h"
-#include "sync/api/attachments/attachment.h"
-#include "sync/protocol/sync.pb.h"
-#include "testing/gtest/include/gtest/gtest.h"
-
-namespace syncer {
-
-const char kTestData1[] = "test data 1";
-const char kTestData2[] = "test data 2";
-
-class FakeAttachmentStoreTest : public testing::Test {
- protected:
- base::MessageLoop message_loop;
- scoped_refptr<FakeAttachmentStore> store;
- AttachmentStore::Result result;
- scoped_ptr<AttachmentMap> attachments;
- scoped_ptr<AttachmentIdList> failed_attachment_ids;
-
- AttachmentStore::ReadCallback read_callback;
- AttachmentStore::WriteCallback write_callback;
- AttachmentStore::DropCallback drop_callback;
-
- scoped_refptr<base::RefCountedString> some_data1;
- scoped_refptr<base::RefCountedString> some_data2;
-
- FakeAttachmentStoreTest()
- : store(new FakeAttachmentStore(base::ThreadTaskRunnerHandle::Get())) {}
-
- virtual void SetUp() {
- Clear();
- read_callback = base::Bind(&FakeAttachmentStoreTest::CopyResultAttachments,
- base::Unretained(this),
- &result,
- &attachments,
- &failed_attachment_ids);
- write_callback = base::Bind(
- &FakeAttachmentStoreTest::CopyResult, base::Unretained(this), &result);
- drop_callback = write_callback;
-
- some_data1 = new base::RefCountedString;
- some_data1->data() = kTestData1;
-
- some_data2 = new base::RefCountedString;
- some_data2->data() = kTestData2;
- }
-
- virtual void ClearAndPumpLoop() {
- Clear();
- message_loop.RunUntilIdle();
- }
-
- private:
- void Clear() {
- result = AttachmentStore::UNSPECIFIED_ERROR;
- attachments.reset();
- failed_attachment_ids.reset();
- }
-
- void CopyResult(AttachmentStore::Result* destination_result,
- const AttachmentStore::Result& source_result) {
- *destination_result = source_result;
- }
-
- void CopyResultAttachments(
- AttachmentStore::Result* destination_result,
- scoped_ptr<AttachmentMap>* destination_attachments,
- scoped_ptr<AttachmentIdList>* destination_failed_attachment_ids,
- const AttachmentStore::Result& source_result,
- scoped_ptr<AttachmentMap> source_attachments,
- scoped_ptr<AttachmentIdList> source_failed_attachment_ids) {
- CopyResult(destination_result, source_result);
- *destination_attachments = source_attachments.Pass();
- *destination_failed_attachment_ids = source_failed_attachment_ids.Pass();
- }
-};
-
-// Verify that we do not overwrite existing attachments and that we do not treat
-// it as an error.
-TEST_F(FakeAttachmentStoreTest, Write_NoOverwriteNoError) {
- // Create two attachments with the same id but different data.
- Attachment attachment1 = Attachment::Create(some_data1);
- Attachment attachment2 =
- Attachment::CreateWithId(attachment1.GetId(), some_data2);
-
- // Write the first one.
- AttachmentList some_attachments;
- some_attachments.push_back(attachment1);
- store->Write(some_attachments, write_callback);
- ClearAndPumpLoop();
- EXPECT_EQ(result, AttachmentStore::SUCCESS);
-
- // Write the second one.
- some_attachments.clear();
- some_attachments.push_back(attachment2);
- store->Write(some_attachments, write_callback);
- ClearAndPumpLoop();
- EXPECT_EQ(result, AttachmentStore::SUCCESS);
-
- // Read it back and see that it was not overwritten.
- AttachmentIdList some_attachment_ids;
- some_attachment_ids.push_back(attachment1.GetId());
- store->Read(some_attachment_ids, read_callback);
- ClearAndPumpLoop();
- EXPECT_EQ(result, AttachmentStore::SUCCESS);
- EXPECT_EQ(attachments->size(), 1U);
- EXPECT_EQ(failed_attachment_ids->size(), 0U);
- AttachmentMap::const_iterator a1 = attachments->find(attachment1.GetId());
- EXPECT_TRUE(a1 != attachments->end());
- EXPECT_TRUE(attachment1.GetData()->Equals(a1->second.GetData()));
-}
-
-// Verify that we can write some attachments and read them back.
-TEST_F(FakeAttachmentStoreTest, Write_RoundTrip) {
- Attachment attachment1 = Attachment::Create(some_data1);
- Attachment attachment2 = Attachment::Create(some_data2);
- AttachmentList some_attachments;
- some_attachments.push_back(attachment1);
- some_attachments.push_back(attachment2);
-
- store->Write(some_attachments, write_callback);
- ClearAndPumpLoop();
- EXPECT_EQ(result, AttachmentStore::SUCCESS);
-
- AttachmentIdList some_attachment_ids;
- some_attachment_ids.push_back(attachment1.GetId());
- some_attachment_ids.push_back(attachment2.GetId());
- store->Read(some_attachment_ids, read_callback);
- ClearAndPumpLoop();
- EXPECT_EQ(result, AttachmentStore::SUCCESS);
- EXPECT_EQ(attachments->size(), 2U);
- EXPECT_EQ(failed_attachment_ids->size(), 0U);
-
- AttachmentMap::const_iterator a1 = attachments->find(attachment1.GetId());
- EXPECT_TRUE(a1 != attachments->end());
- EXPECT_TRUE(attachment1.GetData()->Equals(a1->second.GetData()));
-
- AttachmentMap::const_iterator a2 = attachments->find(attachment2.GetId());
- EXPECT_TRUE(a2 != attachments->end());
- EXPECT_TRUE(attachment2.GetData()->Equals(a2->second.GetData()));
-}
-
-// Try to read two attachments when only one exists.
-TEST_F(FakeAttachmentStoreTest, Read_OneNotFound) {
- Attachment attachment1 = Attachment::Create(some_data1);
- Attachment attachment2 = Attachment::Create(some_data2);
-
- AttachmentList some_attachments;
- // Write attachment1 only.
- some_attachments.push_back(attachment1);
- store->Write(some_attachments, write_callback);
- ClearAndPumpLoop();
- EXPECT_EQ(result, AttachmentStore::SUCCESS);
-
- // Try to read both attachment1 and attachment2.
- AttachmentIdList ids;
- ids.push_back(attachment1.GetId());
- ids.push_back(attachment2.GetId());
- store->Read(ids, read_callback);
- ClearAndPumpLoop();
-
- // See that only attachment1 was read.
- EXPECT_EQ(result, AttachmentStore::UNSPECIFIED_ERROR);
- EXPECT_EQ(attachments->size(), 1U);
- EXPECT_EQ(failed_attachment_ids->size(), 1U);
-}
-
-// Try to drop two attachments when only one exists. Verify that no error occurs
-// and that the existing attachment was dropped.
-TEST_F(FakeAttachmentStoreTest, Drop_DropTwoButOnlyOneExists) {
- // First, create two attachments.
- Attachment attachment1 = Attachment::Create(some_data1);
- Attachment attachment2 = Attachment::Create(some_data2);
- AttachmentList some_attachments;
- some_attachments.push_back(attachment1);
- some_attachments.push_back(attachment2);
- store->Write(some_attachments, write_callback);
- ClearAndPumpLoop();
- EXPECT_EQ(result, AttachmentStore::SUCCESS);
-
- // Drop attachment1 only.
- AttachmentIdList ids;
- ids.push_back(attachment1.GetId());
- store->Drop(ids, drop_callback);
- ClearAndPumpLoop();
- EXPECT_EQ(result, AttachmentStore::SUCCESS);
-
- // See that attachment1 is gone.
- store->Read(ids, read_callback);
- ClearAndPumpLoop();
- EXPECT_EQ(result, AttachmentStore::UNSPECIFIED_ERROR);
- EXPECT_EQ(attachments->size(), 0U);
- EXPECT_EQ(failed_attachment_ids->size(), 1U);
- EXPECT_EQ((*failed_attachment_ids)[0], attachment1.GetId());
-
- // Drop both attachment1 and attachment2.
- ids.clear();
- ids.push_back(attachment1.GetId());
- ids.push_back(attachment2.GetId());
- store->Drop(ids, drop_callback);
- ClearAndPumpLoop();
- EXPECT_EQ(result, AttachmentStore::SUCCESS);
-
- // See that attachment2 is now gone.
- ids.clear();
- ids.push_back(attachment2.GetId());
- store->Read(ids, read_callback);
- ClearAndPumpLoop();
- EXPECT_EQ(result, AttachmentStore::UNSPECIFIED_ERROR);
- EXPECT_EQ(attachments->size(), 0U);
- EXPECT_EQ(failed_attachment_ids->size(), 1U);
- EXPECT_EQ((*failed_attachment_ids)[0], attachment2.GetId());
-}
-
-// Verify that attempting to drop an attachment that does not exist is not an
-// error.
-TEST_F(FakeAttachmentStoreTest, Drop_DoesNotExist) {
- Attachment attachment1 = Attachment::Create(some_data1);
- AttachmentList some_attachments;
- some_attachments.push_back(attachment1);
- store->Write(some_attachments, write_callback);
- ClearAndPumpLoop();
- EXPECT_EQ(result, AttachmentStore::SUCCESS);
-
- // Drop the attachment.
- AttachmentIdList ids;
- ids.push_back(attachment1.GetId());
- store->Drop(ids, drop_callback);
- ClearAndPumpLoop();
- EXPECT_EQ(result, AttachmentStore::SUCCESS);
-
- // See that it's gone.
- store->Read(ids, read_callback);
- ClearAndPumpLoop();
- EXPECT_EQ(result, AttachmentStore::UNSPECIFIED_ERROR);
- EXPECT_EQ(attachments->size(), 0U);
- EXPECT_EQ(failed_attachment_ids->size(), 1U);
- EXPECT_EQ((*failed_attachment_ids)[0], attachment1.GetId());
-
- // Drop again, see that no error occurs.
- ids.clear();
- ids.push_back(attachment1.GetId());
- store->Drop(ids, drop_callback);
- ClearAndPumpLoop();
- EXPECT_EQ(result, AttachmentStore::SUCCESS);
-}
-
-} // namespace syncer
« no previous file with comments | « sync/api/attachments/fake_attachment_store.cc ('k') | sync/internal_api/attachments/attachment_service_impl.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698