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

Unified Diff: blimp/helium/lazy_syncable_adapter_unittest.cc

Issue 2522633004: Add LazySyncableAdapter (Closed)
Patch Set: minor cleanup Created 4 years 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
« no previous file with comments | « blimp/helium/lazy_syncable_adapter.h ('k') | no next file » | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: blimp/helium/lazy_syncable_adapter_unittest.cc
diff --git a/blimp/helium/lazy_syncable_adapter_unittest.cc b/blimp/helium/lazy_syncable_adapter_unittest.cc
new file mode 100644
index 0000000000000000000000000000000000000000..20d810bf63bc9b0de84c37318cb88257dbdf2fd1
--- /dev/null
+++ b/blimp/helium/lazy_syncable_adapter_unittest.cc
@@ -0,0 +1,135 @@
+// Copyright 2016 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 "blimp/helium/lazy_syncable_adapter.h"
+
+#include <stdint.h>
+
+#include "base/bind.h"
+#include "blimp/helium/helium_test.h"
+#include "blimp/helium/serializable_struct.h"
+#include "testing/gmock/include/gmock/gmock.h"
+#include "testing/gtest/include/gtest/gtest.h"
+
+using testing::_;
+using testing::DoAll;
+using testing::Return;
+using testing::SaveArg;
+
+namespace blimp {
+namespace helium {
+namespace {
+
+constexpr Revision kRevision = 42;
+
+struct TestSyncableChangeset : public SerializableStruct {
+ TestSyncableChangeset() : value(this) {}
+ ~TestSyncableChangeset() override {}
+
+ TestSyncableChangeset& operator=(const TestSyncableChangeset& other) {
+ value.Set(other.value());
+ return *this;
+ }
+
+ Field<int32_t> value;
+};
+
+class MockSyncable : public LazySyncable<TestSyncableChangeset> {
+ public:
+ MockSyncable() {}
+ ~MockSyncable() = default;
+
+ // LazySyncable implementation.
+ MOCK_CONST_METHOD1(CreateChangesetMock, TestSyncableChangeset*(Revision));
+ MOCK_METHOD1(ApplyChangeset, void(const TestSyncableChangeset&));
+ MOCK_METHOD1(SetLocalUpdateCallback, void(const base::Closure&));
+ MOCK_CONST_METHOD1(ValidateChangeset, bool(const TestSyncableChangeset&));
+ MOCK_METHOD1(ReleaseBefore, void(Revision));
+ MOCK_CONST_METHOD0(GetRevision, Revision());
+ MOCK_METHOD2(PrepareToCreateChangeset, void(Revision, base::Closure));
+
+ std::unique_ptr<TestSyncableChangeset> CreateChangeset(Revision from) const {
+ return base::WrapUnique<TestSyncableChangeset>(CreateChangesetMock(from));
+ }
+
+ private:
+ DISALLOW_COPY_AND_ASSIGN(MockSyncable);
+};
+
+class LazySyncableAdapterTest : public HeliumTest {
+ public:
+ LazySyncableAdapterTest() : adapter_(&syncable_) {}
+ ~LazySyncableAdapterTest() override = default;
+
+ MOCK_METHOD0(CallbackMock, void());
+
+ protected:
+ MockSyncable syncable_;
+ LazySyncableAdapter<TestSyncableChangeset> adapter_;
+
+ private:
+ DISALLOW_COPY_AND_ASSIGN(LazySyncableAdapterTest);
+};
+
+TEST_F(LazySyncableAdapterTest, ForwardsSetLocalCallback) {
+ base::Closure callback_arg;
+
+ EXPECT_CALL(syncable_, SetLocalUpdateCallback(_))
+ .WillOnce(SaveArg<0>(&callback_arg));
+ adapter_.SetLocalUpdateCallback(base::Bind(
+ &LazySyncableAdapterTest::CallbackMock, base::Unretained(this)));
+
+ EXPECT_CALL(*this, CallbackMock());
+ callback_arg.Run();
+}
+
+TEST_F(LazySyncableAdapterTest, ForwardsReleaseBefore) {
+ EXPECT_CALL(syncable_, ReleaseBefore(kRevision));
+ adapter_.ReleaseBefore(kRevision);
+}
+
+TEST_F(LazySyncableAdapterTest, ForwardsGetRevision) {
+ EXPECT_CALL(syncable_, GetRevision()).WillOnce(Return(kRevision));
+ EXPECT_EQ(kRevision, adapter_.GetRevision());
+}
+
+TEST_F(LazySyncableAdapterTest, ForwardsPrepareToCreateChangeset) {
+ base::Closure callback_arg;
+
+ EXPECT_CALL(syncable_, PrepareToCreateChangeset(kRevision, _))
+ .WillOnce(SaveArg<1>(&callback_arg));
+ adapter_.PrepareToCreateChangeset(
+ kRevision, base::Bind(&LazySyncableAdapterTest::CallbackMock,
+ base::Unretained(this)));
+
+ EXPECT_CALL(*this, CallbackMock());
+ callback_arg.Run();
+}
+
+TEST_F(LazySyncableAdapterTest, SerializesParsesForwardsChangesets) {
+ std::unique_ptr<TestSyncableChangeset> changeset =
+ base::MakeUnique<TestSyncableChangeset>();
+ changeset->value.Set(33);
+
+ EXPECT_CALL(syncable_, CreateChangesetMock(kRevision))
+ .WillOnce(Return(changeset.release()));
+ std::unique_ptr<std::string> string_changeset =
+ adapter_.CreateChangeset(kRevision);
+
+ TestSyncableChangeset validate_changeset;
+ EXPECT_CALL(syncable_, ValidateChangeset(_))
+ .WillOnce(DoAll(SaveArg<0>(&validate_changeset), Return(true)));
+ EXPECT_EQ(true, adapter_.ValidateChangeset(*string_changeset));
+ EXPECT_EQ(33, validate_changeset.value());
+
+ TestSyncableChangeset apply_changeset;
+ EXPECT_CALL(syncable_, ApplyChangeset(_))
+ .WillOnce(SaveArg<0>(&apply_changeset));
+ adapter_.ApplyChangeset(*string_changeset);
+ EXPECT_EQ(33, apply_changeset.value());
+}
+
+} // namespace
+} // namespace helium
+} // namespace blimp
« no previous file with comments | « blimp/helium/lazy_syncable_adapter.h ('k') | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698