| OLD | NEW |
| (Empty) | |
| 1 // Copyright 2016 The Chromium Authors. All rights reserved. |
| 2 // Use of this source code is governed by a BSD-style license that can be |
| 3 // found in the LICENSE file. |
| 4 |
| 5 #include "blimp/helium/lww_register.h" |
| 6 |
| 7 #include <string> |
| 8 |
| 9 #include "base/macros.h" |
| 10 #include "blimp/helium/version_vector.h" |
| 11 #include "blimp/helium/version_vector_generator.h" |
| 12 #include "testing/gtest/include/gtest/gtest.h" |
| 13 #include "third_party/protobuf/src/google/protobuf/io/zero_copy_stream_impl_lite
.h" |
| 14 |
| 15 namespace blimp { |
| 16 namespace helium { |
| 17 namespace { |
| 18 |
| 19 class LwwRegisterTest : public testing::Test { |
| 20 public: |
| 21 LwwRegisterTest() {} |
| 22 ~LwwRegisterTest() override = default; |
| 23 |
| 24 protected: |
| 25 void Initialize(Peer bias) { |
| 26 client_ = |
| 27 base::MakeUnique<LwwRegister<int>>(&client_gen_, bias, Peer::CLIENT); |
| 28 engine_ = |
| 29 base::MakeUnique<LwwRegister<int>>(&engine_gen_, bias, Peer::ENGINE); |
| 30 } |
| 31 |
| 32 void SyncFromClient() { |
| 33 Sync(client_.get(), engine_.get(), engine_gen_.current(), |
| 34 client_gen_.current()); |
| 35 } |
| 36 |
| 37 void SyncFromEngine() { |
| 38 Sync(engine_.get(), client_.get(), client_gen_.current(), |
| 39 engine_gen_.current()); |
| 40 } |
| 41 |
| 42 void Sync(LwwRegister<int>* from_lww_register, |
| 43 LwwRegister<int>* to_lww_register, |
| 44 VersionVector from, |
| 45 VersionVector to); |
| 46 |
| 47 VersionVectorGenerator client_gen_; |
| 48 VersionVectorGenerator engine_gen_; |
| 49 |
| 50 std::unique_ptr<LwwRegister<int>> client_; |
| 51 std::unique_ptr<LwwRegister<int>> engine_; |
| 52 |
| 53 private: |
| 54 DISALLOW_COPY_AND_ASSIGN(LwwRegisterTest); |
| 55 }; |
| 56 |
| 57 // Takes a changeset from |from_lww_register| and applies it to |
| 58 // |to_lww_register|. |
| 59 void LwwRegisterTest::Sync(LwwRegister<int>* from_lww_register, |
| 60 LwwRegister<int>* to_lww_register, |
| 61 VersionVector from, |
| 62 VersionVector to) { |
| 63 // Create a changeset from |from_lww_register|. |
| 64 std::string changeset; |
| 65 google::protobuf::io::StringOutputStream raw_output_stream(&changeset); |
| 66 google::protobuf::io::CodedOutputStream output_stream(&raw_output_stream); |
| 67 from_lww_register->CreateChangesetToCurrent(from.remote_revision(), |
| 68 &output_stream); |
| 69 |
| 70 // Apply the changeset to |to_lww_register|. |
| 71 google::protobuf::io::ArrayInputStream raw_input_stream(changeset.data(), |
| 72 changeset.size()); |
| 73 google::protobuf::io::CodedInputStream input_stream(&raw_input_stream); |
| 74 to_lww_register->ApplyChangeset(to.local_revision(), &input_stream); |
| 75 } |
| 76 |
| 77 TEST_F(LwwRegisterTest, SetIncrementsLocalVersion) { |
| 78 Initialize(Peer::CLIENT); |
| 79 |
| 80 VersionVector earlier_version = client_gen_.current(); |
| 81 client_->Set(42); |
| 82 VersionVector current_version = client_gen_.current(); |
| 83 |
| 84 EXPECT_EQ(42, client_->Get()); |
| 85 EXPECT_LT(earlier_version.local_revision(), current_version.local_revision()); |
| 86 } |
| 87 |
| 88 TEST_F(LwwRegisterTest, ApplyLaterChangeset) { |
| 89 Initialize(Peer::CLIENT); |
| 90 |
| 91 client_->Set(123); |
| 92 SyncFromClient(); |
| 93 |
| 94 EXPECT_EQ(123, engine_->Get()); |
| 95 } |
| 96 |
| 97 TEST_F(LwwRegisterTest, ApplyEarlierChangeset) { |
| 98 Initialize(Peer::CLIENT); |
| 99 |
| 100 client_->Set(123); |
| 101 SyncFromClient(); |
| 102 |
| 103 engine_->Set(456); |
| 104 SyncFromClient(); |
| 105 |
| 106 EXPECT_EQ(456, engine_->Get()); |
| 107 } |
| 108 |
| 109 TEST_F(LwwRegisterTest, ClientApplyChangesetConflictClientWins) { |
| 110 Initialize(Peer::CLIENT); |
| 111 |
| 112 client_->Set(123); |
| 113 engine_->Set(456); |
| 114 SyncFromEngine(); |
| 115 |
| 116 EXPECT_EQ(123, client_->Get()); |
| 117 } |
| 118 |
| 119 TEST_F(LwwRegisterTest, EngineApplyChangesetConflictClientWins) { |
| 120 Initialize(Peer::CLIENT); |
| 121 |
| 122 client_->Set(123); |
| 123 engine_->Set(456); |
| 124 SyncFromClient(); |
| 125 |
| 126 EXPECT_EQ(123, engine_->Get()); |
| 127 } |
| 128 |
| 129 TEST_F(LwwRegisterTest, ClientApplyChangesetConflictEngineWins) { |
| 130 Initialize(Peer::ENGINE); |
| 131 |
| 132 client_->Set(123); |
| 133 engine_->Set(456); |
| 134 SyncFromEngine(); |
| 135 |
| 136 EXPECT_EQ(456, client_->Get()); |
| 137 } |
| 138 |
| 139 TEST_F(LwwRegisterTest, EngineApplyChangesetConflictEngineWins) { |
| 140 Initialize(Peer::ENGINE); |
| 141 |
| 142 client_->Set(123); |
| 143 engine_->Set(456); |
| 144 SyncFromClient(); |
| 145 |
| 146 EXPECT_EQ(456, engine_->Get()); |
| 147 } |
| 148 |
| 149 } // namespace |
| 150 } // namespace helium |
| 151 } // namespace blimp |
| OLD | NEW |