2018-04-16 16:43:16 +08:00
|
|
|
#include <experimental/optional>
|
2017-10-25 21:28:10 +08:00
|
|
|
#include <string>
|
|
|
|
|
2018-10-04 21:23:07 +08:00
|
|
|
#include <gflags/gflags.h>
|
|
|
|
#include <gtest/gtest.h>
|
2017-10-25 21:28:10 +08:00
|
|
|
|
2017-10-30 17:43:25 +08:00
|
|
|
#include "database/graph_db.hpp"
|
2017-11-20 18:58:05 +08:00
|
|
|
#include "database/graph_db_accessor.hpp"
|
2018-10-04 21:23:07 +08:00
|
|
|
#include "durability/single_node/recovery.hpp"
|
2017-10-25 21:28:10 +08:00
|
|
|
#include "query/typed_value.hpp"
|
|
|
|
|
|
|
|
static const char *usage =
|
2017-11-20 18:58:05 +08:00
|
|
|
"--durability-dir DURABILITY_DIR\n"
|
|
|
|
"Check that Memgraph can recover the snapshot. This tool should be "
|
2017-10-25 21:28:10 +08:00
|
|
|
"invoked through 'test_mg_import' wrapper, so as to check that 'mg_import' "
|
|
|
|
"tools work correctly.\n";
|
|
|
|
|
2017-11-20 18:58:05 +08:00
|
|
|
DEFINE_string(durability_dir, "", "Path to where the durability directory");
|
2017-10-25 21:28:10 +08:00
|
|
|
|
|
|
|
class RecoveryTest : public ::testing::Test {
|
|
|
|
protected:
|
|
|
|
void SetUp() override {
|
2017-11-20 18:58:05 +08:00
|
|
|
std::string durability_dir(FLAGS_durability_dir);
|
2018-07-17 17:03:03 +08:00
|
|
|
durability::RecoveryData recovery_data;
|
|
|
|
durability::RecoverOnlySnapshot(durability_dir, &db_, &recovery_data,
|
2018-08-01 15:48:38 +08:00
|
|
|
std::experimental::nullopt, 0);
|
|
|
|
database::SingleNodeRecoveryTransanctions recovery_transactions(&db_);
|
2018-09-07 21:59:10 +08:00
|
|
|
durability::RecoverWal(durability_dir, &db_, &recovery_data,
|
|
|
|
&recovery_transactions);
|
|
|
|
durability::RecoverIndexes(&db_, recovery_data.indexes);
|
2017-10-25 21:28:10 +08:00
|
|
|
}
|
|
|
|
|
2018-01-12 22:17:04 +08:00
|
|
|
database::SingleNode db_;
|
2017-10-25 21:28:10 +08:00
|
|
|
};
|
|
|
|
|
|
|
|
TEST_F(RecoveryTest, TestVerticesRecovered) {
|
2018-07-26 15:08:21 +08:00
|
|
|
auto dba = db_.Access();
|
|
|
|
EXPECT_EQ(dba->VerticesCount(), 10);
|
|
|
|
EXPECT_EQ(dba->VerticesCount(dba->Label("Comment")), 5);
|
|
|
|
for (const auto &vertex : dba->Vertices(dba->Label("Comment"), false)) {
|
|
|
|
EXPECT_TRUE(vertex.has_label(dba->Label("Message")));
|
2017-10-25 21:28:10 +08:00
|
|
|
}
|
2018-07-26 15:08:21 +08:00
|
|
|
EXPECT_EQ(dba->VerticesCount(dba->Label("Forum")), 5);
|
2017-10-25 21:28:10 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
TEST_F(RecoveryTest, TestPropertyNull) {
|
2018-07-26 15:08:21 +08:00
|
|
|
auto dba = db_.Access();
|
2017-10-25 21:28:10 +08:00
|
|
|
bool found = false;
|
2018-07-26 15:08:21 +08:00
|
|
|
for (const auto &vertex : dba->Vertices(dba->Label("Comment"), false)) {
|
|
|
|
auto id_prop = query::TypedValue(vertex.PropsAt(dba->Property("id")));
|
|
|
|
auto browser = query::TypedValue(vertex.PropsAt(dba->Property("browser")));
|
2017-10-25 21:28:10 +08:00
|
|
|
if (id_prop.IsString() && id_prop.Value<std::string>() == "2") {
|
|
|
|
EXPECT_FALSE(found);
|
|
|
|
found = true;
|
|
|
|
EXPECT_TRUE(browser.IsNull());
|
|
|
|
} else {
|
|
|
|
EXPECT_FALSE(browser.IsNull());
|
|
|
|
}
|
|
|
|
}
|
|
|
|
ASSERT_TRUE(found);
|
|
|
|
}
|
|
|
|
|
|
|
|
TEST_F(RecoveryTest, TestEdgesRecovered) {
|
2018-07-26 15:08:21 +08:00
|
|
|
auto dba = db_.Access();
|
|
|
|
EXPECT_EQ(dba->EdgesCount(), 5);
|
|
|
|
for (const auto &edge : dba->Edges(false)) {
|
|
|
|
EXPECT_TRUE(edge.EdgeType() == dba->EdgeType("POSTED_ON"));
|
2017-10-25 21:28:10 +08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2018-07-31 16:45:15 +08:00
|
|
|
TEST_F(RecoveryTest, TestQuote) {
|
|
|
|
auto dba = db_.Access();
|
|
|
|
for (const auto &vertex : dba->Vertices(dba->Label("Comment"), false)) {
|
|
|
|
auto id_prop = query::TypedValue(vertex.PropsAt(dba->Property("id")));
|
|
|
|
auto country = query::TypedValue(vertex.PropsAt(dba->Property("country")));
|
|
|
|
if (id_prop.IsString() && id_prop.Value<std::string>() == "1") {
|
|
|
|
EXPECT_TRUE(country.IsString());
|
|
|
|
EXPECT_EQ(country.Value<std::string>(), "United Kingdom");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
TEST_F(RecoveryTest, TestNodeLabelFlag) {
|
|
|
|
auto dba = db_.Access();
|
|
|
|
for (const auto &vertex : dba->Vertices(false)) {
|
|
|
|
EXPECT_TRUE(vertex.has_label(dba->Label("First")));
|
|
|
|
EXPECT_TRUE(vertex.has_label(dba->Label("Second")));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
TEST_F(RecoveryTest, TestRelationshipType) {
|
|
|
|
auto dba = db_.Access();
|
|
|
|
EXPECT_EQ(dba->EdgesCount(), 5);
|
|
|
|
for (const auto &edge : dba->Edges(false)) {
|
|
|
|
EXPECT_TRUE(edge.EdgeType() == dba->EdgeType("TYPE"));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2017-10-25 21:28:10 +08:00
|
|
|
int main(int argc, char *argv[]) {
|
|
|
|
::testing::InitGoogleTest(&argc, argv);
|
|
|
|
gflags::SetUsageMessage(usage);
|
|
|
|
gflags::ParseCommandLineFlags(&argc, &argv, true);
|
|
|
|
return RUN_ALL_TESTS();
|
|
|
|
}
|