2018-04-06 15:59:54 +08:00
|
|
|
#include "distributed_common.hpp"
|
|
|
|
|
|
|
|
#include "database/graph_db_accessor.hpp"
|
2018-04-16 16:43:16 +08:00
|
|
|
#include "durability/snapshooter.hpp"
|
2018-04-06 15:59:54 +08:00
|
|
|
|
|
|
|
class DistributedDurability : public DistributedGraphDbTest {
|
|
|
|
public:
|
2018-04-16 16:43:16 +08:00
|
|
|
void AddVertices() {
|
|
|
|
AddVertex(master(), "master");
|
|
|
|
AddVertex(worker(1), "worker1");
|
|
|
|
AddVertex(worker(2), "worker2");
|
2018-04-06 15:59:54 +08:00
|
|
|
}
|
2018-04-16 16:43:16 +08:00
|
|
|
void CheckVertices(int expected_count) {
|
|
|
|
CheckVertex(master(), expected_count, "master");
|
|
|
|
CheckVertex(worker(1), expected_count, "worker1");
|
|
|
|
CheckVertex(worker(2), expected_count, "worker2");
|
|
|
|
}
|
|
|
|
void RestartWithRecovery() {
|
|
|
|
ShutDown();
|
|
|
|
Initialize([](database::Config config) {
|
|
|
|
config.db_recover_on_startup = true;
|
|
|
|
return config;
|
|
|
|
});
|
2018-04-06 15:59:54 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
private:
|
2018-04-16 16:43:16 +08:00
|
|
|
void AddVertex(database::GraphDb &db, const std::string &label) {
|
2018-04-06 15:59:54 +08:00
|
|
|
database::GraphDbAccessor dba(db);
|
|
|
|
auto vertex = dba.InsertVertex();
|
|
|
|
vertex.add_label(dba.Label(label));
|
|
|
|
dba.Commit();
|
|
|
|
}
|
|
|
|
|
2018-04-16 16:43:16 +08:00
|
|
|
void CheckVertex(database::GraphDb &db, int expected_count,
|
|
|
|
const std::string &label) {
|
2018-04-06 15:59:54 +08:00
|
|
|
database::GraphDbAccessor dba(db);
|
|
|
|
auto it = dba.Vertices(false);
|
2018-04-16 16:43:16 +08:00
|
|
|
std::vector<VertexAccessor> vertices{it.begin(), it.end()};
|
|
|
|
EXPECT_EQ(vertices.size(), expected_count);
|
|
|
|
for (auto &vertex : vertices) {
|
|
|
|
ASSERT_EQ(vertex.labels().size(), 1);
|
|
|
|
EXPECT_EQ(vertex.labels()[0], dba.Label(label));
|
|
|
|
}
|
2018-04-06 15:59:54 +08:00
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
TEST_F(DistributedDurability, MakeSnapshot) {
|
|
|
|
// Create a graph with 3 nodes with 3 labels, one on each and make a snapshot
|
|
|
|
// of it
|
|
|
|
{
|
2018-04-16 16:43:16 +08:00
|
|
|
AddVertices();
|
2018-04-06 15:59:54 +08:00
|
|
|
database::GraphDbAccessor dba(master());
|
|
|
|
master().MakeSnapshot(dba);
|
|
|
|
}
|
|
|
|
// Recover the graph and check if it's the same as before
|
|
|
|
{
|
2018-04-16 16:43:16 +08:00
|
|
|
RestartWithRecovery();
|
|
|
|
CheckVertices(1);
|
2018-04-06 15:59:54 +08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
TEST_F(DistributedDurability, SnapshotOnExit) {
|
|
|
|
{
|
|
|
|
TearDown();
|
|
|
|
Initialize([](database::Config config) {
|
|
|
|
config.snapshot_on_exit = true;
|
|
|
|
return config;
|
|
|
|
});
|
2018-04-16 16:43:16 +08:00
|
|
|
AddVertices();
|
2018-04-06 15:59:54 +08:00
|
|
|
}
|
|
|
|
// Recover the graph and check if it's the same as before
|
|
|
|
{
|
2018-04-16 16:43:16 +08:00
|
|
|
RestartWithRecovery();
|
|
|
|
CheckVertices(1);
|
|
|
|
}
|
|
|
|
}
|
2018-04-06 15:59:54 +08:00
|
|
|
|
2018-04-16 16:43:16 +08:00
|
|
|
TEST_F(DistributedDurability, RecoveryFromSameSnapshot) {
|
|
|
|
{
|
|
|
|
AddVertices();
|
|
|
|
// Make snapshot on one worker, expect it won't recover from that.
|
|
|
|
database::GraphDbAccessor dba(worker(1));
|
|
|
|
worker(1).MakeSnapshot(dba);
|
|
|
|
}
|
|
|
|
{
|
|
|
|
RestartWithRecovery();
|
|
|
|
CheckVertices(0);
|
|
|
|
AddVertices();
|
|
|
|
database::GraphDbAccessor dba(master());
|
|
|
|
master().MakeSnapshot(dba);
|
|
|
|
}
|
|
|
|
{
|
|
|
|
RestartWithRecovery();
|
|
|
|
CheckVertices(1);
|
|
|
|
AddVertices();
|
|
|
|
CheckVertices(2);
|
|
|
|
// Make snapshot on one worker, expect it won't recover from that.
|
|
|
|
database::GraphDbAccessor dba(worker(1));
|
|
|
|
worker(1).MakeSnapshot(dba);
|
|
|
|
}
|
|
|
|
{
|
|
|
|
RestartWithRecovery();
|
|
|
|
CheckVertices(1);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
TEST_F(DistributedDurability, RecoveryFailure) {
|
|
|
|
{
|
|
|
|
AddVertices();
|
|
|
|
// Make a snapshot on the master without the right snapshots on workers.
|
|
|
|
database::GraphDbAccessor dba(master());
|
|
|
|
bool status = durability::MakeSnapshot(master(), dba, tmp_dir_, 100);
|
|
|
|
ASSERT_TRUE(status);
|
2018-04-06 15:59:54 +08:00
|
|
|
}
|
2018-04-16 16:43:16 +08:00
|
|
|
::testing::FLAGS_gtest_death_test_style = "threadsafe";
|
|
|
|
EXPECT_DEATH(RestartWithRecovery(), "worker failed to recover");
|
2018-04-06 15:59:54 +08:00
|
|
|
}
|