Added tests looking at the behaviour of XPath when dealing with text nodes. I want XPath the evaluate as if the DOM had been normalised, even if it hasn't. That is, consecutive text nodes should be treated as a single node.

This commit is contained in:
jez 2008-09-13 18:36:46 +01:00
parent b495dc316f
commit fa3f59083c
3 changed files with 108 additions and 0 deletions

View file

@ -24,6 +24,7 @@ test_sources = arithmetic_test.hpp \
parse_test.hpp \
relational_test.hpp \
step_test.hpp \
text_node_test.hpp \
value_test.hpp \
xpath_test_suite.hpp

105
tests/XPath/text_node_test.hpp Executable file
View file

@ -0,0 +1,105 @@
#ifndef TEXT_NODE_TEST_HPP
#define TEXT_NODE_TEST_HPP
#include "../CppUnit/framework/TestCase.h"
#include "../CppUnit/framework/TestSuite.h"
#include "../CppUnit/framework/TestCaller.h"
#include <XPath/XPath.hpp>
#include <DOM/Simple/DOMImplementation.hpp>
template<class string_type, class string_adaptor>
class TextNodeTest : public TestCase
{
typedef string_adaptor SA;
Arabica::DOM::DOMImplementation<string_type, string_adaptor> factory_;
Arabica::DOM::Document<string_type, string_adaptor> document_;
Arabica::DOM::Element<string_type, string_adaptor> root_;
Arabica::DOM::Text<string_type, string_adaptor> text1_;
Arabica::DOM::Text<string_type, string_adaptor> text2_;
Arabica::DOM::Text<string_type, string_adaptor> text3_;
Arabica::XPath::XPath<string_type, string_adaptor> parser_;
typedef Arabica::XPath::XPathExpression<string_type, string_adaptor> XPathExpression_t;
typedef Arabica::XPath::XPathValue<string_type, string_adaptor> XPathValue_t;
typedef Arabica::DOM::Node<string_type, string_adaptor> Node_t;
public:
TextNodeTest(const std::string& name) : TestCase(name)
{
} // TextNodeTest
void setUp()
{
factory_ = Arabica::SimpleDOM::DOMImplementation<string_type, string_adaptor>::getDOMImplementation();
document_ = factory_.createDocument(SA::construct_from_utf8(""), SA::construct_from_utf8("root"), 0);
root_ = document_.getDocumentElement();
text1_ = document_.createTextNode(SA::construct_from_utf8("one"));
text2_ = document_.createTextNode(SA::construct_from_utf8("two"));
text3_ = document_.createTextNode(SA::construct_from_utf8("three"));
root_.appendChild(text1_);
root_.appendChild(text2_);
root_.appendChild(text3_);
} // setUp
void test1()
{
Node_t node = parser_.evaluate(SA::construct_from_utf8("/root"), document_).asNodeSet()[0];
assertTrue(node == root_);
} // test1
void test2()
{
XPathValue_t nodes = parser_.evaluate(SA::construct_from_utf8("/root/text()"), document_);
assertEquals(1, nodes.asNodeSet().size());
} // test2
void test3()
{
string_type value = parser_.evaluate(SA::construct_from_utf8("/root/text()"), document_).asString();
assertEquals("onetwothree", SA::asStdString(value));
} // test3
void test4()
{
string_type value = parser_.evaluate(SA::construct_from_utf8("/root/node()"), document_).asString();
assertEquals("onetwothree", SA::asStdString(value));
} // test4
void test5()
{
string_type value = parser_.evaluate(SA::construct_from_utf8("/root"), document_).asString();
assertEquals("onetwothree", SA::asStdString(value));
} // test5
void test6()
{
XPathValue_t nodes = parser_.evaluate(SA::construct_from_utf8("/root/node()"), document_);
assertEquals(1, nodes.asNodeSet().size());
} // test6
}; // class TextNodeTest
template<class string_type, class string_adaptor>
TestSuite* TextNodeTest_suite()
{
TestSuite* suiteOfTests = new TestSuite;
suiteOfTests->addTest(new TestCaller<TextNodeTest<string_type, string_adaptor> >("test1", &TextNodeTest<string_type, string_adaptor>::test1));
suiteOfTests->addTest(new TestCaller<TextNodeTest<string_type, string_adaptor> >("test2", &TextNodeTest<string_type, string_adaptor>::test2));
suiteOfTests->addTest(new TestCaller<TextNodeTest<string_type, string_adaptor> >("test3", &TextNodeTest<string_type, string_adaptor>::test3));
suiteOfTests->addTest(new TestCaller<TextNodeTest<string_type, string_adaptor> >("test4", &TextNodeTest<string_type, string_adaptor>::test4));
suiteOfTests->addTest(new TestCaller<TextNodeTest<string_type, string_adaptor> >("test5", &TextNodeTest<string_type, string_adaptor>::test5));
suiteOfTests->addTest(new TestCaller<TextNodeTest<string_type, string_adaptor> >("test6", &TextNodeTest<string_type, string_adaptor>::test6));
return suiteOfTests;
} // TextNodeTest
#endif

View file

@ -17,6 +17,7 @@
#include "expression_test.hpp"
#include "match_test.hpp"
#include "attr_value_test.hpp"
#include "text_node_test.hpp"
template<class string_type, class string_adaptor>
bool XPath_test_suite(int argc, const char** argv)
@ -35,6 +36,7 @@ bool XPath_test_suite(int argc, const char** argv)
runner.addTest("ExpressionTest", ExpressionTest_suite<string_type, string_adaptor>());
runner.addTest("MatchTest", MatchTest_suite<string_type, string_adaptor>());
runner.addTest("AttributeValueTest", AttributeValueTest_suite<string_type, string_adaptor>());
runner.addTest("TextNodeTest", TextNodeTest_suite<string_type, string_adaptor>());
return runner.run(argc, argv);
} // XPath_test_suite