memgraph/tests/unit/storage_address.cpp
florijan 463e86653d Vertex and Edge distributed storage support
Summary: Vertex and Edge now use Address for storing connections to other Edges and Vertices, to support distributed storage.

Reviewers: mislav.bradac, dgleich, buda

Reviewed By: mislav.bradac, dgleich

Subscribers: pullbot

Differential Revision: https://phabricator.memgraph.io/D977
2017-11-14 15:18:06 +01:00

34 lines
729 B
C++

#include "gtest/gtest.h"
#include "storage/address.hpp"
using storage::Address;
TEST(Address, Local) {
std::string a{"bla"};
Address<std::string> address(&a);
EXPECT_TRUE(address.is_local());
EXPECT_FALSE(address.is_remote());
EXPECT_EQ(address.local(), &a);
}
TEST(Address, CopyCompare) {
int a = 12;
int b = 13;
Address<int> addr_a{&a};
EXPECT_EQ(Address<int>{&a}, addr_a);
EXPECT_FALSE(Address<int>{&b} == addr_a);
}
TEST(Address, Global) {
uint64_t shard_id{13};
uint64_t global_id{31};
Address<int> address{shard_id, global_id};
EXPECT_TRUE(address.is_remote());
EXPECT_FALSE(address.is_local());
EXPECT_EQ(address.shard_id(), shard_id);
EXPECT_EQ(address.global_id(), global_id);
}