From e91ba1faf25790eea34e7ae743aff06752f1ea8c Mon Sep 17 00:00:00 2001 From: Benjamin Paassen Date: Wed, 3 Dec 2014 17:01:46 +0100 Subject: Convenience versions for SelectorNode::getChildren. --- test/core/CSSTest.cpp | 54 +++++++++++++++++++++++++++++++++++++++++++++------ 1 file changed, 48 insertions(+), 6 deletions(-) (limited to 'test/core/CSSTest.cpp') diff --git a/test/core/CSSTest.cpp b/test/core/CSSTest.cpp index 2c695d9..fdb8238 100644 --- a/test/core/CSSTest.cpp +++ b/test/core/CSSTest.cpp @@ -115,13 +115,55 @@ TEST(Specificity, testOperators) TEST(SelectorNode, testGetChildren) { Manager mgr(1); - Rooted root{new SelectorNode{mgr, "root", {"true", false}}}; - Rooted child{new SelectorNode{mgr, "A", {"true", false}}}; - root->getEdges().push_back( - new SelectorNode::SelectorEdge{mgr, child, SelectionOperator::DESCENDANT}); + // build some children. + Rooted root{new SelectorNode{mgr, "root"}}; + Rooted A{new SelectorNode{mgr, "A"}}; + Rooted AMy_Select{ + new SelectorNode{mgr, "A", {"my_select", {"a", "b"}, false}}}; + Rooted B{new SelectorNode{mgr, "B"}}; + + std::vector> children = {A, AMy_Select, B}; + + for (auto &c : children) { + root->getEdges().push_back(new SelectorNode::SelectorEdge{ + mgr, c, SelectionOperator::DESCENDANT}); + } + root->getEdges().push_back(new SelectorNode::SelectorEdge{ + mgr, B, SelectionOperator::DIRECT_DESCENDANT}); + + // make some checks. + std::vector> expected = {A}; std::vector> actual = root->getChildren(SelectionOperator::DESCENDANT, "A", {"true", false}); - ASSERT_EQ(1,actual.size()); - ASSERT_EQ(child, actual[0]); + ASSERT_EQ(expected, actual); + + expected = {A, AMy_Select}; + actual = root->getChildren(SelectionOperator::DESCENDANT, "A"); + ASSERT_EQ(expected, actual); + actual = root->getChildren("A"); + ASSERT_EQ(expected, actual); + + expected = {A, AMy_Select, B}; + actual = root->getChildren(SelectionOperator::DESCENDANT); + ASSERT_EQ(expected, actual); + + expected = {B}; + actual = root->getChildren(SelectionOperator::DIRECT_DESCENDANT); + ASSERT_EQ(expected, actual); + + expected = {B, B}; + actual = root->getChildren("B"); + ASSERT_EQ(expected, actual); + + { + expected = {A, B, B}; + PseudoSelector select = {"true", false}; + actual = root->getChildren(select); + ASSERT_EQ(expected, actual); + } + + expected = {A, AMy_Select, B, B}; + actual = root->getChildren(); + ASSERT_EQ(expected, actual); } } -- cgit v1.2.3