mirror of
https://github.com/jezhiggins/arabica
synced 2025-01-07 05:24:22 +01:00
195 lines
6.8 KiB
C++
195 lines
6.8 KiB
C++
#ifndef test_Siblings_H
|
|
#define test_Siblings_H
|
|
|
|
#include "../CppUnit/framework/TestCase.h"
|
|
#include "../CppUnit/framework/TestSuite.h"
|
|
#include "../CppUnit/framework/TestCaller.h"
|
|
|
|
#include <DOM/Simple/DOMImplementation.h>
|
|
|
|
template<class string_type, class string_adaptor>
|
|
class SiblingsTest : public TestCase
|
|
{
|
|
DOM::DOMImplementation<string_type> factory;
|
|
typedef string_adaptor SA;
|
|
|
|
public:
|
|
SiblingsTest(std::string name) :
|
|
TestCase(name)
|
|
{
|
|
} // SiblingsTest
|
|
|
|
void setUp()
|
|
{
|
|
factory = SimpleDOM::DOMImplementation<string_type, string_adaptor>::getDOMImplementation();
|
|
} // setUp
|
|
|
|
void test1()
|
|
{
|
|
DOM::Document<string_type> d = factory.createDocument(SA::construct_from_utf8(""), SA::construct_from_utf8(""), 0);
|
|
DOM::Element<string_type> root = d.createElement(SA::construct_from_utf8("root"));
|
|
d.appendChild(root);
|
|
|
|
assert(root.getPreviousSibling() == 0);
|
|
assert(root.getNextSibling() == 0);
|
|
|
|
DOM::ProcessingInstruction<string_type> p = d.createProcessingInstruction(SA::construct_from_utf8("target"), SA::construct_from_utf8("data"));
|
|
d.insertBefore(p, root);
|
|
assert(d.getFirstChild() == p);
|
|
assert(d.getLastChild() == root);
|
|
assert(p.getPreviousSibling() == 0);
|
|
assert(p.getNextSibling() == root);
|
|
assert(root.getPreviousSibling() == p);
|
|
assert(root.getNextSibling() == 0);
|
|
|
|
DOM::ProcessingInstruction<string_type> p2 = d.createProcessingInstruction(SA::construct_from_utf8("target"), SA::construct_from_utf8("data"));
|
|
d.insertBefore(p2, root);
|
|
assert(d.getFirstChild() == p);
|
|
assert(d.getLastChild() == root);
|
|
assert(p.getPreviousSibling() == 0);
|
|
assert(p.getNextSibling() == p2);
|
|
assert(p2.getPreviousSibling() == p);
|
|
assert(p2.getNextSibling() == root);
|
|
assert(root.getPreviousSibling() == p2);
|
|
assert(root.getNextSibling() == 0);
|
|
|
|
d.removeChild(p2);
|
|
assert(d.getFirstChild() == p);
|
|
assert(d.getLastChild() == root);
|
|
assert(p.getPreviousSibling() == 0);
|
|
assert(p.getNextSibling() == root);
|
|
assert(p2.getPreviousSibling() == 0);
|
|
assert(p2.getNextSibling() == 0);
|
|
assert(root.getPreviousSibling() == p);
|
|
assert(root.getNextSibling() == 0);
|
|
|
|
d.insertBefore(p2, root);
|
|
assert(d.getFirstChild() == p);
|
|
assert(d.getLastChild() == root);
|
|
assert(p.getPreviousSibling() == 0);
|
|
assert(p.getNextSibling() == p2);
|
|
assert(p2.getPreviousSibling() == p);
|
|
assert(p2.getNextSibling() == root);
|
|
assert(root.getPreviousSibling() == p2);
|
|
assert(root.getNextSibling() == 0);
|
|
|
|
d.removeChild(p);
|
|
assert(d.getFirstChild() == p2);
|
|
assert(d.getLastChild() == root);
|
|
assert(p.getPreviousSibling() == 0);
|
|
assert(p.getNextSibling() == 0);
|
|
assert(p2.getPreviousSibling() == 0);
|
|
assert(p2.getNextSibling() == root);
|
|
assert(root.getPreviousSibling() == p2);
|
|
assert(root.getNextSibling() == 0);
|
|
|
|
d.replaceChild(p, p2);
|
|
assert(d.getFirstChild() == p);
|
|
assert(d.getLastChild() == root);
|
|
assert(p.getPreviousSibling() == 0);
|
|
assert(p.getNextSibling() == root);
|
|
assert(p2.getPreviousSibling() == 0);
|
|
assert(p2.getNextSibling() == 0);
|
|
assert(root.getPreviousSibling() == p);
|
|
assert(root.getNextSibling() == 0);
|
|
|
|
d.appendChild(p2);
|
|
assert(d.getFirstChild() == p);
|
|
assert(d.getLastChild() == p2);
|
|
assert(p.getPreviousSibling() == 0);
|
|
assert(p.getNextSibling() == root);
|
|
assert(root.getPreviousSibling() == p);
|
|
assert(root.getNextSibling() == p2);
|
|
assert(p2.getPreviousSibling() == root);
|
|
assert(p2.getNextSibling() == 0);
|
|
} // test1
|
|
|
|
void test2()
|
|
{
|
|
DOM::Element<string_type> root;
|
|
{
|
|
DOM::Document<string_type> d = factory.createDocument(SA::construct_from_utf8(""), SA::construct_from_utf8(""), 0);
|
|
root = d.createElement(SA::construct_from_utf8("root"));
|
|
d.appendChild(root);
|
|
|
|
assert(root.getPreviousSibling() == 0);
|
|
assert(root.getNextSibling() == 0);
|
|
|
|
DOM::ProcessingInstruction<string_type> p = d.createProcessingInstruction(SA::construct_from_utf8("target"), SA::construct_from_utf8("data"));
|
|
d.insertBefore(p, root);
|
|
}
|
|
|
|
DOM::Node<string_type> n = root.getPreviousSibling();
|
|
DOM::ProcessingInstruction<string_type> p = DOM::ProcessingInstruction<string_type>(n);
|
|
assert(p.getTarget() == SA::construct_from_utf8("target"));
|
|
assert(p.getData() == SA::construct_from_utf8("data"));
|
|
} // test2
|
|
|
|
void test3()
|
|
{
|
|
DOM::Element<string_type> root;
|
|
{
|
|
DOM::Document<string_type> d = factory.createDocument(SA::construct_from_utf8(""), SA::construct_from_utf8(""), 0);
|
|
root = d.createElement(SA::construct_from_utf8("root"));
|
|
d.appendChild(root);
|
|
|
|
root.appendChild(d.createElement(SA::construct_from_utf8("child1")));
|
|
root.appendChild(d.createElement(SA::construct_from_utf8("child2")));
|
|
}
|
|
|
|
DOM::Node<string_type> c = root.getFirstChild();
|
|
assert(c.getNextSibling() == root.getLastChild());
|
|
|
|
root.purgeChild(c);
|
|
|
|
assert(c == 0);
|
|
assert(root.getLastChild() == root.getFirstChild());
|
|
} // test3
|
|
|
|
void test4()
|
|
{
|
|
DOM::Element<string_type> root;
|
|
{
|
|
DOM::Document<string_type> d = factory.createDocument(SA::construct_from_utf8(""), SA::construct_from_utf8(""), 0);
|
|
root = d.createElement(SA::construct_from_utf8("root"));
|
|
d.appendChild(root);
|
|
|
|
root.appendChild(d.createElement(SA::construct_from_utf8("child1")));
|
|
root.appendChild(d.createElement(SA::construct_from_utf8("child2")));
|
|
}
|
|
|
|
DOM::Node<string_type> c1 = root.getFirstChild();
|
|
DOM::Node<string_type> c2 = root.getLastChild();
|
|
|
|
try {
|
|
c1.purgeChild(c2);
|
|
}
|
|
catch(DOM::DOMException& e)
|
|
{
|
|
assert(e.code() == DOM::DOMException::NOT_FOUND_ERR);
|
|
} // catch
|
|
|
|
|
|
assert(c1 != 0);
|
|
assert(c2 != 0);
|
|
|
|
assert(c1.getNextSibling() == c2);
|
|
assert(c2.getPreviousSibling() == c1);
|
|
} // test4
|
|
};
|
|
|
|
template<class string_type, class string_adaptor>
|
|
TestSuite* SiblingsTest_suite()
|
|
{
|
|
TestSuite *suiteOfTests = new TestSuite;
|
|
|
|
suiteOfTests->addTest(new TestCaller<SiblingsTest<string_type, string_adaptor> >("test1", &SiblingsTest<string_type, string_adaptor>::test1));
|
|
suiteOfTests->addTest(new TestCaller<SiblingsTest<string_type, string_adaptor> >("test2", &SiblingsTest<string_type, string_adaptor>::test2));
|
|
suiteOfTests->addTest(new TestCaller<SiblingsTest<string_type, string_adaptor> >("test3", &SiblingsTest<string_type, string_adaptor>::test3));
|
|
suiteOfTests->addTest(new TestCaller<SiblingsTest<string_type, string_adaptor> >("test4", &SiblingsTest<string_type, string_adaptor>::test4));
|
|
|
|
return suiteOfTests;
|
|
} // SiblingsTest_suite
|
|
|
|
#endif
|
|
|