Added test case growing a larger tree step by step

This commit is contained in:
Sebastian Messmer 2015-02-20 20:16:44 +01:00
parent 5133e3d8a0
commit 959b5dcb3b
2 changed files with 36 additions and 6 deletions

View File

@ -25,5 +25,3 @@ TEST_F(DataTreeGrowingTest, GrowAOneNodeTree_FlushingWorks) {
EXPECT_INNER_NODE_NUMBER_OF_LEAVES_IS(2, tree->key()); EXPECT_INNER_NODE_NUMBER_OF_LEAVES_IS(2, tree->key());
} }
//TODO Build-up test cases (build a leaf tree, add N leaves and check end state. End states for example FullTwoLevelTree, FullThreeLevelTree)

View File

@ -1,5 +1,8 @@
#include "testutils/DataTreeGrowingTest.h" #include "testutils/DataTreeGrowingTest.h"
using blobstore::onblocks::datanodestore::DataInnerNode;
using blockstore::Key;
class DataTreeGrowingTest_Structure: public DataTreeGrowingTest {}; class DataTreeGrowingTest_Structure: public DataTreeGrowingTest {};
TEST_F(DataTreeGrowingTest_Structure, GrowAOneNodeTree) { TEST_F(DataTreeGrowingTest_Structure, GrowAOneNodeTree) {
@ -27,6 +30,14 @@ TEST_F(DataTreeGrowingTest_Structure, GrowAThreeNodeChainedTree) {
EXPECT_INNER_NODE_NUMBER_OF_LEAVES_IS(2, root->getChild(0)->key()); EXPECT_INNER_NODE_NUMBER_OF_LEAVES_IS(2, root->getChild(0)->key());
} }
TEST_F(DataTreeGrowingTest_Structure, GrowAFullTwoLevelTreeFromGroundUp) {
auto key = CreateLeafOnlyTree()->key();
for (int i = 1; i < DataInnerNode::MAX_STORED_CHILDREN; ++i) {
AddLeafTo(key);
}
EXPECT_IS_FULL_TWOLEVEL_TREE(key);
}
TEST_F(DataTreeGrowingTest_Structure, GrowAFullTwoLevelTree) { TEST_F(DataTreeGrowingTest_Structure, GrowAFullTwoLevelTree) {
auto root_key = CreateFullTwoLevelTree(); auto root_key = CreateFullTwoLevelTree();
AddLeafTo(root_key); AddLeafTo(root_key);
@ -49,6 +60,14 @@ TEST_F(DataTreeGrowingTest_Structure, GrowAThreeLevelTreeWithLowerLevelFull) {
EXPECT_IS_TWONODE_CHAIN(root->getChild(1)->key()); EXPECT_IS_TWONODE_CHAIN(root->getChild(1)->key());
} }
TEST_F(DataTreeGrowingTest_Structure, GrowAFullThreeLevelTreeFromGroundUp) {
auto key = CreateLeafOnlyTree()->key();
for (int i = 1; i < DataInnerNode::MAX_STORED_CHILDREN * DataInnerNode::MAX_STORED_CHILDREN; ++i) {
AddLeafTo(key);
}
EXPECT_IS_FULL_THREELEVEL_TREE(key);
}
TEST_F(DataTreeGrowingTest_Structure, GrowAFullThreeLevelTree) { TEST_F(DataTreeGrowingTest_Structure, GrowAFullThreeLevelTree) {
auto root_key = CreateFullThreeLevelTree(); auto root_key = CreateFullThreeLevelTree();
AddLeafTo(root_key); AddLeafTo(root_key);
@ -60,11 +79,24 @@ TEST_F(DataTreeGrowingTest_Structure, GrowAFullThreeLevelTree) {
EXPECT_IS_THREENODE_CHAIN(root->getChild(1)->key()); EXPECT_IS_THREENODE_CHAIN(root->getChild(1)->key());
} }
TEST_F(DataTreeGrowingTest_Structure, GrowAThreeLevelTreeWithTwoFullSubtrees) { TEST_F(DataTreeGrowingTest_Structure, GrowAThreeLevelTreeWithTwoFullSubtreesFromGroundUp) {
auto root_key = CreateThreeLevelTreeWithTwoFullSubtrees(); auto key = CreateLeafOnlyTree()->key();
AddLeafTo(root_key); for (int i = 1; i < 2 * DataInnerNode::MAX_STORED_CHILDREN; ++i) {
AddLeafTo(key);
}
auto root = LoadInnerNode(root_key); auto root = LoadInnerNode(key);
EXPECT_EQ(2u, root->numChildren());
EXPECT_IS_FULL_TWOLEVEL_TREE(root->getChild(0)->key());
EXPECT_IS_FULL_TWOLEVEL_TREE(root->getChild(1)->key());
}
TEST_F(DataTreeGrowingTest_Structure, GrowAThreeLevelTreeWithTwoFullSubtrees) {
auto key = CreateThreeLevelTreeWithTwoFullSubtrees();
AddLeafTo(key);
auto root = LoadInnerNode(key);
EXPECT_EQ(3u, root->numChildren()); EXPECT_EQ(3u, root->numChildren());
EXPECT_IS_FULL_TWOLEVEL_TREE(root->getChild(0)->key()); EXPECT_IS_FULL_TWOLEVEL_TREE(root->getChild(0)->key());