214 lines
9.4 KiB
C++
214 lines
9.4 KiB
C++
// Copyright 2024 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 <gtest/gtest.h>
|
|
#include <rocksdb/options.h>
|
|
#include <limits>
|
|
|
|
#include "disk_test_utils.hpp"
|
|
#include "spdlog/spdlog.h"
|
|
#include "storage/v2/disk/rocksdb_storage.hpp"
|
|
#include "storage/v2/disk/storage.hpp"
|
|
#include "storage/v2/property_value.hpp"
|
|
#include "storage/v2/view.hpp"
|
|
|
|
using memgraph::replication_coordination_glue::ReplicationRole;
|
|
|
|
class ClearingOldDiskDataTest : public ::testing::Test {
|
|
public:
|
|
const std::string testSuite = "clearing_old_disk_data";
|
|
std::unique_ptr<memgraph::storage::DiskStorage> disk_storage =
|
|
std::make_unique<memgraph::storage::DiskStorage>(disk_test_utils::GenerateOnDiskConfig(testSuite));
|
|
|
|
void TearDown() override { disk_test_utils::RemoveRocksDbDirs(testSuite); }
|
|
};
|
|
|
|
TEST_F(ClearingOldDiskDataTest, TestNumOfEntriesWithVertexTimestampUpdate) {
|
|
auto *tx_db = disk_storage->GetRocksDBStorage()->db_;
|
|
ASSERT_EQ(disk_test_utils::GetRealNumberOfEntriesInRocksDB(tx_db), 0);
|
|
|
|
auto acc1 = disk_storage->Access(ReplicationRole::MAIN);
|
|
auto vertex1 = acc1->CreateVertex();
|
|
auto label1 = acc1->NameToLabel("DiskLabel");
|
|
auto property1 = acc1->NameToProperty("DiskProperty");
|
|
ASSERT_TRUE(vertex1.AddLabel(label1).HasValue());
|
|
ASSERT_TRUE(vertex1.SetProperty(property1, memgraph::storage::PropertyValue(10)).HasValue());
|
|
ASSERT_FALSE(acc1->Commit().HasError());
|
|
|
|
ASSERT_EQ(disk_test_utils::GetRealNumberOfEntriesInRocksDB(tx_db), 1);
|
|
|
|
auto acc2 = disk_storage->Access(ReplicationRole::MAIN);
|
|
auto vertex2 = acc2->FindVertex(vertex1.Gid(), memgraph::storage::View::NEW).value();
|
|
/// This is the same property as in the first transaction, we just want to test
|
|
/// the number of entries inside RocksDB when the timestamp changes
|
|
auto property2 = acc2->NameToProperty("DiskProperty");
|
|
ASSERT_TRUE(vertex2.SetProperty(property2, memgraph::storage::PropertyValue(10)).HasValue());
|
|
ASSERT_FALSE(acc2->Commit().HasError());
|
|
|
|
ASSERT_EQ(disk_test_utils::GetRealNumberOfEntriesInRocksDB(tx_db), 1);
|
|
}
|
|
|
|
TEST_F(ClearingOldDiskDataTest, TestNumOfEntriesWithVertexValueUpdate) {
|
|
auto *tx_db = disk_storage->GetRocksDBStorage()->db_;
|
|
ASSERT_EQ(disk_test_utils::GetRealNumberOfEntriesInRocksDB(tx_db), 0);
|
|
|
|
auto acc1 = disk_storage->Access(ReplicationRole::MAIN);
|
|
auto vertex1 = acc1->CreateVertex();
|
|
auto label1 = acc1->NameToLabel("DiskLabel");
|
|
auto property1 = acc1->NameToProperty("DiskProperty");
|
|
ASSERT_TRUE(vertex1.AddLabel(label1).HasValue());
|
|
ASSERT_TRUE(vertex1.SetProperty(property1, memgraph::storage::PropertyValue(10)).HasValue());
|
|
ASSERT_FALSE(acc1->Commit().HasError());
|
|
|
|
ASSERT_EQ(disk_test_utils::GetRealNumberOfEntriesInRocksDB(tx_db), 1);
|
|
|
|
auto acc2 = disk_storage->Access(ReplicationRole::MAIN);
|
|
auto vertex2 = acc2->FindVertex(vertex1.Gid(), memgraph::storage::View::NEW).value();
|
|
/// This is the same property as in the first transaction, we just want to test
|
|
/// the number of entries inside RocksDB when the timestamp changes
|
|
auto property2 = acc2->NameToProperty("DiskProperty");
|
|
ASSERT_TRUE(vertex2.SetProperty(property2, memgraph::storage::PropertyValue(15)).HasValue());
|
|
ASSERT_FALSE(acc2->Commit().HasError());
|
|
|
|
ASSERT_EQ(disk_test_utils::GetRealNumberOfEntriesInRocksDB(tx_db), 1);
|
|
}
|
|
|
|
TEST_F(ClearingOldDiskDataTest, TestNumOfEntriesWithVertexKeyUpdate) {
|
|
auto *tx_db = disk_storage->GetRocksDBStorage()->db_;
|
|
ASSERT_EQ(disk_test_utils::GetRealNumberOfEntriesInRocksDB(tx_db), 0);
|
|
|
|
auto acc1 = disk_storage->Access(ReplicationRole::MAIN);
|
|
auto vertex1 = acc1->CreateVertex();
|
|
auto label1 = acc1->NameToLabel("DiskLabel");
|
|
auto property1 = acc1->NameToProperty("DiskProperty");
|
|
ASSERT_TRUE(vertex1.AddLabel(label1).HasValue());
|
|
ASSERT_TRUE(vertex1.SetProperty(property1, memgraph::storage::PropertyValue(10)).HasValue());
|
|
ASSERT_FALSE(acc1->Commit().HasError());
|
|
|
|
ASSERT_EQ(disk_test_utils::GetRealNumberOfEntriesInRocksDB(tx_db), 1);
|
|
|
|
auto acc2 = disk_storage->Access(ReplicationRole::MAIN);
|
|
auto vertex2 = acc2->FindVertex(vertex1.Gid(), memgraph::storage::View::NEW).value();
|
|
auto label2 = acc2->NameToLabel("DiskLabel2");
|
|
ASSERT_TRUE(vertex2.AddLabel(label2).HasValue());
|
|
ASSERT_FALSE(acc2->Commit().HasError());
|
|
|
|
ASSERT_EQ(disk_test_utils::GetRealNumberOfEntriesInRocksDB(tx_db), 1);
|
|
}
|
|
|
|
TEST_F(ClearingOldDiskDataTest, TestNumOfEntriesWithEdgeTimestampUpdate) {
|
|
auto *tx_db = disk_storage->GetRocksDBStorage()->db_;
|
|
ASSERT_EQ(disk_test_utils::GetRealNumberOfEntriesInRocksDB(tx_db), 0);
|
|
|
|
auto acc1 = disk_storage->Access(ReplicationRole::MAIN);
|
|
|
|
auto label1 = acc1->NameToLabel("DiskLabel");
|
|
auto property1 = acc1->NameToProperty("DiskProperty");
|
|
auto edge_type = acc1->NameToEdgeType("test");
|
|
|
|
auto from = acc1->CreateVertex();
|
|
auto to = acc1->CreateVertex();
|
|
auto edge = acc1->CreateEdge(&from, &to, edge_type);
|
|
MG_ASSERT(edge.HasValue());
|
|
|
|
ASSERT_TRUE(from.AddLabel(label1).HasValue());
|
|
ASSERT_TRUE(to.AddLabel(label1).HasValue());
|
|
ASSERT_TRUE(from.SetProperty(property1, memgraph::storage::PropertyValue(10)).HasValue());
|
|
ASSERT_TRUE(to.SetProperty(property1, memgraph::storage::PropertyValue(10)).HasValue());
|
|
ASSERT_TRUE(edge->SetProperty(property1, memgraph::storage::PropertyValue(10)).HasValue());
|
|
ASSERT_FALSE(acc1->Commit().HasError());
|
|
|
|
ASSERT_EQ(disk_test_utils::GetRealNumberOfEntriesInRocksDB(tx_db), 5);
|
|
|
|
auto acc2 = disk_storage->Access(ReplicationRole::MAIN);
|
|
auto from_vertex = acc2->FindVertex(from.Gid(), memgraph::storage::View::NEW).value();
|
|
|
|
auto ret = from_vertex.OutEdges(memgraph::storage::View::NEW);
|
|
auto fetched_edge = ret.GetValue().edges[0];
|
|
|
|
/// This is the same property as in the first transaction, we just want to test
|
|
/// the number of entries inside RocksDB when the timestamp changes
|
|
auto property2 = acc2->NameToProperty("DiskProperty");
|
|
ASSERT_TRUE(fetched_edge.SetProperty(property2, memgraph::storage::PropertyValue(10)).HasValue());
|
|
ASSERT_FALSE(acc2->Commit().HasError());
|
|
|
|
ASSERT_EQ(disk_test_utils::GetRealNumberOfEntriesInRocksDB(tx_db), 5);
|
|
}
|
|
|
|
TEST_F(ClearingOldDiskDataTest, TestNumOfEntriesWithEdgeValueUpdate) {
|
|
auto *tx_db = disk_storage->GetRocksDBStorage()->db_;
|
|
ASSERT_EQ(disk_test_utils::GetRealNumberOfEntriesInRocksDB(tx_db), 0);
|
|
|
|
auto acc1 = disk_storage->Access(ReplicationRole::MAIN);
|
|
|
|
auto label1 = acc1->NameToLabel("DiskLabel");
|
|
auto property1 = acc1->NameToProperty("DiskProperty");
|
|
auto edge_type = acc1->NameToEdgeType("test");
|
|
|
|
auto from = acc1->CreateVertex();
|
|
auto to = acc1->CreateVertex();
|
|
auto edge = acc1->CreateEdge(&from, &to, edge_type);
|
|
MG_ASSERT(edge.HasValue());
|
|
|
|
ASSERT_TRUE(from.AddLabel(label1).HasValue());
|
|
ASSERT_TRUE(to.AddLabel(label1).HasValue());
|
|
ASSERT_TRUE(from.SetProperty(property1, memgraph::storage::PropertyValue(10)).HasValue());
|
|
ASSERT_TRUE(to.SetProperty(property1, memgraph::storage::PropertyValue(10)).HasValue());
|
|
ASSERT_TRUE(edge->SetProperty(property1, memgraph::storage::PropertyValue(10)).HasValue());
|
|
ASSERT_FALSE(acc1->Commit().HasError());
|
|
|
|
ASSERT_EQ(disk_test_utils::GetRealNumberOfEntriesInRocksDB(tx_db), 5);
|
|
|
|
auto acc2 = disk_storage->Access(ReplicationRole::MAIN);
|
|
auto from_vertex = acc2->FindVertex(from.Gid(), memgraph::storage::View::NEW).value();
|
|
|
|
auto ret = from_vertex.OutEdges(memgraph::storage::View::NEW);
|
|
auto fetched_edge = ret.GetValue().edges[0];
|
|
|
|
auto property2 = acc2->NameToProperty("DiskProperty");
|
|
ASSERT_TRUE(fetched_edge.SetProperty(property2, memgraph::storage::PropertyValue(15)).HasValue());
|
|
ASSERT_FALSE(acc2->Commit().HasError());
|
|
|
|
ASSERT_EQ(disk_test_utils::GetRealNumberOfEntriesInRocksDB(tx_db), 5);
|
|
}
|
|
|
|
TEST_F(ClearingOldDiskDataTest, TestTimestampAfterCommit) {
|
|
auto *tx_db = disk_storage->GetRocksDBStorage()->db_;
|
|
ASSERT_EQ(disk_test_utils::GetRealNumberOfEntriesInRocksDB(tx_db), 0);
|
|
|
|
auto acc1 = disk_storage->Access(ReplicationRole::MAIN);
|
|
auto vertex1 = acc1->CreateVertex();
|
|
auto label1 = acc1->NameToLabel("DiskLabel");
|
|
auto property1 = acc1->NameToProperty("DiskProperty");
|
|
ASSERT_TRUE(vertex1.AddLabel(label1).HasValue());
|
|
ASSERT_TRUE(vertex1.SetProperty(property1, memgraph::storage::PropertyValue(10)).HasValue());
|
|
ASSERT_FALSE(acc1->Commit().HasError());
|
|
ASSERT_EQ(disk_test_utils::GetRealNumberOfEntriesInRocksDB(tx_db), 1);
|
|
|
|
auto saved_timestamp = disk_storage->GetDurableMetadata()->LoadTimestampIfExists();
|
|
ASSERT_EQ(saved_timestamp.has_value(), true);
|
|
ASSERT_EQ(disk_storage->timestamp_, saved_timestamp);
|
|
|
|
auto acc2 = disk_storage->Access(ReplicationRole::MAIN);
|
|
auto vertex2 = acc2->CreateVertex();
|
|
auto label2 = acc2->NameToLabel("DiskLabel2");
|
|
auto property2 = acc2->NameToProperty("DiskProperty2");
|
|
|
|
ASSERT_TRUE(vertex2.AddLabel(label2).HasValue());
|
|
ASSERT_TRUE(vertex2.SetProperty(property2, memgraph::storage::PropertyValue(10)).HasValue());
|
|
ASSERT_FALSE(acc2->Commit().HasError());
|
|
ASSERT_EQ(disk_test_utils::GetRealNumberOfEntriesInRocksDB(tx_db), 2);
|
|
|
|
saved_timestamp = disk_storage->GetDurableMetadata()->LoadTimestampIfExists();
|
|
ASSERT_EQ(saved_timestamp.has_value(), true);
|
|
ASSERT_EQ(disk_storage->timestamp_, saved_timestamp);
|
|
}
|