Added test cases shrinking down full trees to one-leaf trees

This commit is contained in:
Sebastian Messmer 2015-02-23 21:06:45 +01:00
parent 0d26692048
commit 6127a9d6a8
4 changed files with 26 additions and 1 deletions

View File

@ -75,6 +75,10 @@ void DataNodeStore::remove(unique_ptr<DataNode> node) {
_blockstore->remove(std::move(block)); _blockstore->remove(std::move(block));
} }
uint64_t DataNodeStore::numNodes() const {
return _blockstore->numBlocks();
}
} }
} }
} }

View File

@ -36,6 +36,9 @@ public:
void remove(std::unique_ptr<DataNode> node); void remove(std::unique_ptr<DataNode> node);
uint64_t numNodes() const;
//TODO Test remove(), overwriteNodeWith(), createNodeAsCopyFrom(), numNodes()
private: private:
std::unique_ptr<DataNode> load(std::unique_ptr<blockstore::Block> block); std::unique_ptr<DataNode> load(std::unique_ptr<blockstore::Block> block);

View File

@ -48,5 +48,4 @@ TEST_F(DataTreeShrinkingTest, ShrinkATwoLeafTree_IntermediateBlocksAreDeleted) {
EXPECT_EQ(nullptr, nodeStore.load(firstChildKey)); EXPECT_EQ(nullptr, nodeStore.load(firstChildKey));
} }
//TODO Test Shrinking full trees down to 1-leaf-tree
//TODO Test DepthFlags stay intact //TODO Test DepthFlags stay intact

View File

@ -1,6 +1,7 @@
#include "testutils/DataTreeShrinkingTest.h" #include "testutils/DataTreeShrinkingTest.h"
using blobstore::onblocks::datatreestore::DataTree; using blobstore::onblocks::datatreestore::DataTree;
using blobstore::onblocks::datanodestore::DataInnerNode;
using blockstore::Key; using blockstore::Key;
class DataTreeShrinkingTest_Structure: public DataTreeShrinkingTest { class DataTreeShrinkingTest_Structure: public DataTreeShrinkingTest {
@ -127,3 +128,21 @@ TEST_F(DataTreeShrinkingTest_Structure, ShrinkAThreeLevelTreeWithThreeChildrenOf
Shrink(key); Shrink(key);
EXPECT_IS_THREELEVEL_TREE_WITH_TWO_FULL_TWOLEVEL_TREES(key); EXPECT_IS_THREELEVEL_TREE_WITH_TWO_FULL_TWOLEVEL_TREES(key);
} }
TEST_F(DataTreeShrinkingTest_Structure, ShrinkAFullTwoLevelTreeDownToOneLeaf) {
auto key = CreateFullTwoLevel()->key();
for (int i = 0; i < DataInnerNode::MAX_STORED_CHILDREN-1; ++i) {
Shrink(key);
}
EXPECT_IS_LEAF_NODE(key);
EXPECT_EQ(1, nodeStore.numNodes());
}
TEST_F(DataTreeShrinkingTest_Structure, ShrinkAFullThreeLevelTreeDownToOneLeaf) {
auto key = CreateFullThreeLevel()->key();
for (int i = 0; i < DataInnerNode::MAX_STORED_CHILDREN*DataInnerNode::MAX_STORED_CHILDREN-1; ++i) {
Shrink(key);
}
EXPECT_IS_LEAF_NODE(key);
EXPECT_EQ(1, nodeStore.numNodes());
}