Added test case growing a larger tree step by step
This commit is contained in:
parent
5133e3d8a0
commit
959b5dcb3b
@ -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)
|
|
||||||
|
@ -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());
|
||||||
|
Loading…
x
Reference in New Issue
Block a user