2014-12-09 18:53:11 +01:00
|
|
|
#include <gtest/gtest.h>
|
|
|
|
|
|
|
|
#include "blockstore/implementations/inmemory/InMemoryBlockStore.h"
|
|
|
|
#include "blockstore/implementations/inmemory/InMemoryBlock.h"
|
|
|
|
#include "blobstore/implementations/onblocks/BlobStoreOnBlocks.h"
|
|
|
|
#include "blobstore/implementations/onblocks/impl/DataNode.h"
|
|
|
|
#include "blobstore/implementations/onblocks/impl/DataLeafNode.h"
|
|
|
|
#include "blobstore/implementations/onblocks/impl/DataInnerNode.h"
|
|
|
|
|
|
|
|
using ::testing::Test;
|
|
|
|
using std::unique_ptr;
|
|
|
|
using std::make_unique;
|
|
|
|
using std::string;
|
|
|
|
|
|
|
|
using blockstore::BlockStore;
|
|
|
|
using blockstore::inmemory::InMemoryBlockStore;
|
|
|
|
using namespace blobstore;
|
|
|
|
using namespace blobstore::onblocks;
|
|
|
|
|
|
|
|
class DataNodeTest: public Test {
|
|
|
|
public:
|
|
|
|
unique_ptr<BlockStore> blockStore = make_unique<InMemoryBlockStore>();
|
|
|
|
};
|
|
|
|
|
|
|
|
#define EXPECT_IS_PTR_TYPE(Type, ptr) EXPECT_NE(nullptr, dynamic_cast<Type*>(ptr)) << "Given pointer cannot be cast to the given type"
|
|
|
|
|
2014-12-10 22:55:02 +01:00
|
|
|
TEST_F(DataNodeTest, CreateLeafNodeCreatesLeafNode) {
|
|
|
|
auto block = blockStore->create(BlobStoreOnBlocks::BLOCKSIZE);
|
|
|
|
auto node = DataNode::createNewLeafNode(std::move(block.block));
|
|
|
|
EXPECT_IS_PTR_TYPE(DataLeafNode, node.get());
|
|
|
|
}
|
|
|
|
|
|
|
|
TEST_F(DataNodeTest, CreateInnerNodeCreatesInnerNode) {
|
|
|
|
auto block = blockStore->create(BlobStoreOnBlocks::BLOCKSIZE);
|
|
|
|
auto node = DataNode::createNewInnerNode(std::move(block.block));
|
|
|
|
EXPECT_IS_PTR_TYPE(DataInnerNode, node.get());
|
|
|
|
}
|
|
|
|
|
2014-12-09 18:53:11 +01:00
|
|
|
TEST_F(DataNodeTest, LeafNodeIsRecognizedAfterStoreAndLoad) {
|
|
|
|
auto block = blockStore->create(BlobStoreOnBlocks::BLOCKSIZE);
|
2014-12-09 20:36:32 +01:00
|
|
|
Key key = block.key;
|
2014-12-10 16:48:00 +01:00
|
|
|
{
|
2014-12-10 22:55:02 +01:00
|
|
|
DataNode::createNewLeafNode(std::move(block.block));
|
2014-12-10 16:48:00 +01:00
|
|
|
}
|
2014-12-09 18:53:11 +01:00
|
|
|
|
|
|
|
auto loaded_node = DataNode::load(blockStore->load(key));
|
|
|
|
|
|
|
|
EXPECT_IS_PTR_TYPE(DataLeafNode, loaded_node.get());
|
|
|
|
}
|
|
|
|
|
|
|
|
TEST_F(DataNodeTest, InnerNodeIsRecognizedAfterStoreAndLoad) {
|
|
|
|
auto block = blockStore->create(BlobStoreOnBlocks::BLOCKSIZE);
|
2014-12-09 20:36:32 +01:00
|
|
|
Key key = block.key;
|
2014-12-10 16:48:00 +01:00
|
|
|
{
|
2014-12-10 22:55:02 +01:00
|
|
|
DataNode::createNewInnerNode(std::move(block.block));
|
2014-12-10 16:48:00 +01:00
|
|
|
}
|
2014-12-09 18:53:11 +01:00
|
|
|
|
|
|
|
auto loaded_node = DataNode::load(blockStore->load(key));
|
|
|
|
|
|
|
|
EXPECT_IS_PTR_TYPE(DataInnerNode, loaded_node.get());
|
|
|
|
}
|
2014-12-09 18:56:45 +01:00
|
|
|
|
|
|
|
TEST_F(DataNodeTest, DataNodeCrashesOnLoadIfMagicNumberIsWrong) {
|
|
|
|
auto block = blockStore->create(BlobStoreOnBlocks::BLOCKSIZE);
|
2014-12-09 20:36:32 +01:00
|
|
|
Key key = block.key;
|
2014-12-10 16:48:00 +01:00
|
|
|
{
|
|
|
|
DataNodeView view(std::move(block.block));
|
|
|
|
*view.MagicNumber() = 0xFF; // this is an invalid magic number
|
|
|
|
}
|
2014-12-09 18:56:45 +01:00
|
|
|
|
2014-12-10 16:48:00 +01:00
|
|
|
auto loaded_block = blockStore->load(key);
|
2014-12-09 18:56:45 +01:00
|
|
|
EXPECT_ANY_THROW(
|
2014-12-10 16:48:00 +01:00
|
|
|
DataNode::load(std::move(loaded_block))
|
2014-12-09 18:56:45 +01:00
|
|
|
);
|
|
|
|
}
|