2017-05-17 16:08:57 +08:00
|
|
|
#include <experimental/filesystem>
|
2017-06-07 21:23:08 +08:00
|
|
|
|
|
|
|
#include "gflags/gflags.h"
|
|
|
|
#include "gtest/gtest.h"
|
|
|
|
|
2017-10-30 17:43:25 +08:00
|
|
|
#include "database/graph_db.hpp"
|
|
|
|
#include "database/graph_db_accessor.hpp"
|
2017-05-17 16:08:57 +08:00
|
|
|
#include "durability/snapshooter.hpp"
|
2017-06-07 21:23:08 +08:00
|
|
|
|
2017-09-22 15:58:54 +08:00
|
|
|
DECLARE_bool(snapshot_on_exit);
|
2017-06-09 16:34:47 +08:00
|
|
|
DECLARE_int32(snapshot_cycle_sec);
|
|
|
|
DECLARE_string(snapshot_directory);
|
2017-05-17 16:08:57 +08:00
|
|
|
|
|
|
|
namespace fs = std::experimental::filesystem;
|
|
|
|
|
2017-06-16 15:34:46 +08:00
|
|
|
char tmp[] = "XXXXXX";
|
2017-10-30 17:43:25 +08:00
|
|
|
const fs::path SNAPSHOTS_DIR = mkdtemp(tmp);
|
2017-05-17 16:08:57 +08:00
|
|
|
|
2017-06-16 15:34:46 +08:00
|
|
|
// Other functionality is tested in recovery tests.
|
2017-05-17 16:08:57 +08:00
|
|
|
|
|
|
|
std::vector<fs::path> GetFilesFromDir(
|
2017-06-16 15:34:46 +08:00
|
|
|
const fs::path &snapshots_default_db_dir) {
|
2017-05-17 16:08:57 +08:00
|
|
|
std::vector<fs::path> files;
|
|
|
|
for (auto &file : fs::directory_iterator(snapshots_default_db_dir))
|
|
|
|
files.push_back(file.path());
|
|
|
|
return files;
|
|
|
|
}
|
|
|
|
|
|
|
|
void CleanDbDir() {
|
2017-10-30 17:43:25 +08:00
|
|
|
if (!fs::exists(SNAPSHOTS_DIR)) return;
|
|
|
|
std::vector<fs::path> files = GetFilesFromDir(SNAPSHOTS_DIR);
|
2017-05-17 16:08:57 +08:00
|
|
|
for (auto file : files) {
|
|
|
|
fs::remove(file);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
class SnapshotTest : public ::testing::Test {
|
|
|
|
protected:
|
2017-06-07 21:23:08 +08:00
|
|
|
virtual void TearDown() { CleanDbDir(); }
|
2017-05-17 16:08:57 +08:00
|
|
|
|
|
|
|
virtual void SetUp() {
|
|
|
|
CleanDbDir();
|
2017-06-09 16:34:47 +08:00
|
|
|
FLAGS_snapshot_cycle_sec = -1;
|
2017-05-17 16:08:57 +08:00
|
|
|
}
|
|
|
|
std::string snapshot_cycle_sec_setup_;
|
|
|
|
};
|
|
|
|
|
|
|
|
TEST_F(SnapshotTest, CreateLessThanMaxRetainedSnapshotsTests) {
|
2017-09-22 15:58:54 +08:00
|
|
|
const int snapshot_max_retained = 10;
|
2017-10-30 17:43:25 +08:00
|
|
|
GraphDb db;
|
2017-05-17 16:08:57 +08:00
|
|
|
|
|
|
|
for (int i = 0; i < 3; ++i) {
|
2017-10-30 17:43:25 +08:00
|
|
|
GraphDbAccessor dba(db);
|
2017-05-17 16:08:57 +08:00
|
|
|
Snapshooter snapshooter;
|
2017-10-30 17:43:25 +08:00
|
|
|
snapshooter.MakeSnapshot(dba, SNAPSHOTS_DIR,
|
2017-09-22 15:58:54 +08:00
|
|
|
snapshot_max_retained);
|
2017-05-17 16:08:57 +08:00
|
|
|
}
|
|
|
|
|
2017-10-30 17:43:25 +08:00
|
|
|
std::vector<fs::path> files = GetFilesFromDir(SNAPSHOTS_DIR);
|
2017-05-17 16:08:57 +08:00
|
|
|
EXPECT_EQ(files.size(), 3);
|
|
|
|
}
|
|
|
|
|
|
|
|
TEST_F(SnapshotTest, CreateMoreThanMaxRetainedSnapshotsTests) {
|
2017-09-22 15:58:54 +08:00
|
|
|
const int snapshot_max_retained = 2;
|
2017-10-30 17:43:25 +08:00
|
|
|
GraphDb db;
|
2017-05-17 16:08:57 +08:00
|
|
|
|
|
|
|
fs::path first_snapshot;
|
|
|
|
for (int i = 0; i < 3; ++i) {
|
2017-10-30 17:43:25 +08:00
|
|
|
GraphDbAccessor dba(db);
|
2017-05-17 16:08:57 +08:00
|
|
|
Snapshooter snapshooter;
|
2017-10-30 17:43:25 +08:00
|
|
|
snapshooter.MakeSnapshot(dba, SNAPSHOTS_DIR,
|
2017-09-22 15:58:54 +08:00
|
|
|
snapshot_max_retained);
|
2017-05-17 16:08:57 +08:00
|
|
|
if (i == 0) {
|
|
|
|
std::vector<fs::path> files_begin =
|
2017-10-30 17:43:25 +08:00
|
|
|
GetFilesFromDir(SNAPSHOTS_DIR);
|
2017-05-17 16:08:57 +08:00
|
|
|
EXPECT_EQ(files_begin.size(), 1);
|
|
|
|
first_snapshot = files_begin[0];
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
std::vector<fs::path> files_end =
|
2017-10-30 17:43:25 +08:00
|
|
|
GetFilesFromDir(SNAPSHOTS_DIR);
|
2017-05-17 16:08:57 +08:00
|
|
|
EXPECT_EQ(files_end.size(), 2);
|
|
|
|
EXPECT_EQ(fs::exists(first_snapshot), false);
|
|
|
|
}
|
|
|
|
|
|
|
|
TEST_F(SnapshotTest, CreateSnapshotWithUnlimitedMaxRetainedSnapshots) {
|
2017-09-22 15:58:54 +08:00
|
|
|
const int snapshot_max_retained = -1;
|
2017-10-30 17:43:25 +08:00
|
|
|
GraphDb db;
|
2017-05-17 16:08:57 +08:00
|
|
|
|
|
|
|
for (int i = 0; i < 10; ++i) {
|
2017-10-30 17:43:25 +08:00
|
|
|
GraphDbAccessor dba(db);
|
2017-05-17 16:08:57 +08:00
|
|
|
Snapshooter snapshooter;
|
2017-10-30 17:43:25 +08:00
|
|
|
snapshooter.MakeSnapshot(dba, SNAPSHOTS_DIR,
|
2017-09-22 15:58:54 +08:00
|
|
|
snapshot_max_retained);
|
2017-05-17 16:08:57 +08:00
|
|
|
}
|
|
|
|
|
2017-10-30 17:43:25 +08:00
|
|
|
std::vector<fs::path> files = GetFilesFromDir(SNAPSHOTS_DIR);
|
2017-05-17 16:08:57 +08:00
|
|
|
EXPECT_EQ(files.size(), 10);
|
|
|
|
}
|
|
|
|
|
2017-06-06 23:04:49 +08:00
|
|
|
TEST_F(SnapshotTest, TestSnapshotFileOnDbDestruct) {
|
|
|
|
{
|
2017-10-30 17:43:25 +08:00
|
|
|
FLAGS_snapshot_directory = SNAPSHOTS_DIR;
|
2017-09-22 15:58:54 +08:00
|
|
|
FLAGS_snapshot_on_exit = true;
|
2017-10-30 17:43:25 +08:00
|
|
|
GraphDb db;
|
|
|
|
GraphDbAccessor dba(db);
|
2017-06-06 23:04:49 +08:00
|
|
|
}
|
2017-10-30 17:43:25 +08:00
|
|
|
std::vector<fs::path> files = GetFilesFromDir(SNAPSHOTS_DIR);
|
2017-06-06 23:04:49 +08:00
|
|
|
// snapshot is created on dbms destruction
|
|
|
|
EXPECT_EQ(files.size(), 1);
|
|
|
|
}
|
|
|
|
|
2017-05-17 16:08:57 +08:00
|
|
|
int main(int argc, char **argv) {
|
|
|
|
::testing::InitGoogleTest(&argc, argv);
|
|
|
|
return RUN_ALL_TESTS();
|
|
|
|
}
|