memgraph/tests/unit/distributed_lamport_clock.cpp
Gareth Andrew Lloyd 3cc2bc2791
Refactor interpreter to support multiple distributed clocks (Part 1) ()
* Interpreter transaction ID decoupled from storage transaction ID
* Transactional scope for indices, statistics and constraints
* Storage::Accessor now has 2 modes (unique and shared)
* Introduced ResourceLock to fix pthread mutex problems
* Split InfoQuery in two: non-transactional SystemInfoQuery and transactional DatabaseInfoQuery
* Replicable and durable statistics
* Bumped WAL/Snapshot versions
* Initial implementation of the Lamport clock

---------

Co-authored-by: Andreja Tonev <andreja.tonev@memgraph.io>
2023-10-05 16:58:39 +02:00

51 lines
1.6 KiB
C++

// Copyright 2023 Memgraph Ltd.
//
// Use of this software is governed by the Business Source License
// included in the file licenses/BSL.txt; by using this file, you agree to be bound by the terms of the Business Source
// License, and you may not use this file except in compliance with the Business Source License.
//
// As of the Change Date specified in that file, in accordance with
// the Business Source License, use of this software will be governed
// by the Apache License, Version 2.0, included in the file
// licenses/APL.txt.
#include "distributed/lamport_clock.hpp"
#include <gtest/gtest.h>
using namespace memgraph::distributed;
// Define a test fixture for the LamportClock class
class LamportClockTest : public testing::Test {
public:
LamportClock<struct TestTag> clock1;
LamportClock<struct TestTag> clock2;
void SetUp() override {
// Setup code, if any
}
void TearDown() override {
// Tear down code, if any
}
};
TEST_F(LamportClockTest, GetTimestampInternal) {
auto ts1_1 = clock1.get_timestamp(internal);
auto ts1_2 = clock1.get_timestamp(internal);
ASSERT_GT(ts1_2, ts1_1); // internal always increments
}
TEST_F(LamportClockTest, GetTimestampSend) {
auto ts1_1 = clock1.get_timestamp(internal);
auto ts1_2 = clock1.get_timestamp(send);
ASSERT_GT(ts1_2, ts1_1); // send always increments
}
TEST_F(LamportClockTest, GetTimestampReceive) {
auto ts1_1 = clock1.get_timestamp(send);
auto ts2_1 = clock2.get_timestamp(internal);
auto ts2_2 = clock2.get_timestamp(receive, ts1_1);
ASSERT_GE(ts2_1, ts1_1); // receive is at least send +1
ASSERT_GE(ts2_2, ts2_1); // receive is at least internal +1
}