From 8e761289a2446367267c6c0d9a26e734f0f78306 Mon Sep 17 00:00:00 2001 From: Karen Arutyunov Date: Wed, 16 Dec 2020 20:29:05 +0300 Subject: Get rid of legacy build systems and rename cutl/ to libcutl/ --- tests/xml/parser/driver.cxx | 309 -------------------------------------------- 1 file changed, 309 deletions(-) delete mode 100644 tests/xml/parser/driver.cxx (limited to 'tests/xml/parser/driver.cxx') diff --git a/tests/xml/parser/driver.cxx b/tests/xml/parser/driver.cxx deleted file mode 100644 index 38fc7f2..0000000 --- a/tests/xml/parser/driver.cxx +++ /dev/null @@ -1,309 +0,0 @@ -// file : tests/xml/parser/driver.cxx -// license : MIT; see accompanying LICENSE file - -#include -#include -#include -#include - -#include - -using namespace std; -namespace xml = cutl::xml; -using namespace xml; - -int -main () -{ - // Test error handling. - // - try - { - istringstream is ("X"); - parser p (is, "test"); - - assert (p.next () == parser::start_element); - assert (p.next () == parser::start_element); - assert (p.next () == parser::characters && p.value () == "X"); - p.next (); - assert (false); - } - catch (const xml::exception& e) - { - // cerr << e.what () << endl; - } - - try - { - istringstream is (""); - is.exceptions (ios_base::badbit | ios_base::failbit); - parser p (is, "test"); - - is.setstate (ios_base::badbit); - p.next (); - assert (false); - } - catch (const ios_base::failure& e) - { - } - - // Test the next_expect() functionality. - // - { - istringstream is (""); - parser p (is, "test"); - p.next_expect (parser::start_element, "root"); - p.next_expect (parser::end_element); - } - - try - { - istringstream is (""); - parser p (is, "test"); - p.next_expect (parser::end_element); - assert (false); - } - catch (const xml::exception& e) - { - // cerr << e.what () << endl; - } - - try - { - istringstream is (""); - parser p (is, "test"); - p.next_expect (parser::start_element, "root1"); - assert (false); - } - catch (const xml::exception& e) - { - // cerr << e.what () << endl; - } - - // Test attribute maps. - // - { - istringstream is (""); - parser p (is, "test"); - p.next_expect (parser::start_element, "root"); - - assert (p.attribute ("a") == "a"); - assert (p.attribute ("b", "B") == "b"); - assert (p.attribute ("c", "C") == "C"); - assert (p.attribute ("d") == 123); - assert (p.attribute ("t") == true); - assert (p.attribute ("f", false) == false); - - p.next_expect (parser::end_element); - } - - { - istringstream is (""); - parser p (is, "test"); - p.next_expect (parser::start_element, "root"); - assert (p.attribute ("a") == "a"); - assert (p.peek () == parser::start_element && p.name () == "nested"); - assert (p.attribute ("a") == "a"); - p.next_expect (parser::start_element, "nested"); - assert (p.attribute ("a") == "A"); - p.next_expect (parser::start_element, "inner"); - assert (p.attribute ("a", "") == ""); - p.next_expect (parser::end_element); - assert (p.attribute ("a") == "A"); - assert (p.peek () == parser::end_element); - assert (p.attribute ("a") == "A"); // Still valid. - p.next_expect (parser::end_element); - assert (p.attribute ("a") == "a"); - p.next_expect (parser::end_element); - assert (p.attribute ("a", "") == ""); - } - - try - { - istringstream is (""); - parser p (is, "test"); - p.next_expect (parser::start_element, "root"); - assert (p.attribute ("a") == "a"); - p.next_expect (parser::end_element); - assert (false); - } - catch (const xml::exception& e) - { - // cerr << e.what () << endl; - } - - try - { - istringstream is (""); - parser p (is, "test"); - p.next_expect (parser::start_element, "root"); - p.attribute ("a"); - assert (false); - } - catch (const xml::exception& e) - { - // cerr << e.what () << endl; - } - - // Test peeking and getting the current event. - // - { - istringstream is ("x"); - parser p (is, "peek", - parser::receive_default | parser::receive_attributes_event); - - assert (p.event () == parser::eof); - - assert (p.peek () == parser::start_element); - assert (p.next () == parser::start_element); - assert (p.event () == parser::start_element); - - assert (p.peek () == parser::start_attribute); - assert (p.event () == parser::start_attribute); - assert (p.next () == parser::start_attribute); - - assert (p.peek () == parser::characters && p.value () == "x"); - assert (p.next () == parser::characters && p.value () == "x"); - assert (p.event () == parser::characters && p.value () == "x"); - - assert (p.peek () == parser::end_attribute); - assert (p.event () == parser::end_attribute); - assert (p.next () == parser::end_attribute); - - assert (p.peek () == parser::characters && p.value () == "x"); - assert (p.next () == parser::characters && p.value () == "x"); - assert (p.event () == parser::characters && p.value () == "x"); - - assert (p.peek () == parser::start_element); - assert (p.next () == parser::start_element); - assert (p.event () == parser::start_element); - - assert (p.peek () == parser::end_element); - assert (p.next () == parser::end_element); - assert (p.event () == parser::end_element); - - assert (p.peek () == parser::end_element); - assert (p.next () == parser::end_element); - assert (p.event () == parser::end_element); - - assert (p.peek () == parser::eof); - assert (p.next () == parser::eof); - assert (p.event () == parser::eof); - } - - // Test content processing. - // - - // empty - // - { - istringstream is (" \n\t "); - parser p (is, "empty", - parser::receive_default | parser::receive_attributes_event); - - assert (p.next () == parser::start_element); - p.content (parser::empty); - assert (p.next () == parser::start_attribute); - assert (p.next () == parser::characters && p.value () == " x "); - assert (p.next () == parser::end_attribute); - assert (p.next () == parser::end_element); - assert (p.next () == parser::eof); - } - - try - { - istringstream is (" \n & X \t "); - parser p (is, "empty"); - - assert (p.next () == parser::start_element); - p.content (parser::empty); - p.next (); - assert (false); - } - catch (const xml::exception& e) - { - // cerr << e.what () << endl; - } - - // simple - // - { - istringstream is (" X "); - parser p (is, "simple"); - - assert (p.next () == parser::start_element); - p.content (parser::simple); - assert (p.next () == parser::characters && p.value () == " X "); - assert (p.next () == parser::end_element); - assert (p.next () == parser::eof); - } - - try - { - istringstream is (" ? "); - parser p (is, "simple"); - - assert (p.next () == parser::start_element); - p.content (parser::simple); - assert (p.next () == parser::characters && p.value () == " ? "); - p.next (); - assert (false); - } - catch (const xml::exception& e) - { - // cerr << e.what () << endl; - } - - // complex - // - { - istringstream is ("\n" - " \n" - " \n" - " X \n" - " \n" - "\n"); - parser p (is, "complex", - parser::receive_default | parser::receive_attributes_event); - - assert (p.next () == parser::start_element); // root - p.content (parser::complex); - - assert (p.next () == parser::start_attribute); - assert (p.next () == parser::characters && p.value () == " x "); - assert (p.next () == parser::end_attribute); - - assert (p.next () == parser::start_element); // nested - p.content (parser::complex); - - assert (p.next () == parser::start_element); // inner - p.content (parser::empty); - assert (p.next () == parser::end_element); // inner - - assert (p.next () == parser::start_element); // inner - p.content (parser::simple); - assert (p.next () == parser::characters && p.value () == " X "); - assert (p.next () == parser::end_element); // inner - - assert (p.next () == parser::end_element); // nested - assert (p.next () == parser::end_element); // root - assert (p.next () == parser::eof); - } - - try - { - istringstream is (" \n X X "); - parser p (is, "complex"); - - assert (p.next () == parser::start_element); - p.content (parser::complex); - assert (p.next () == parser::start_element); - assert (p.next () == parser::end_element); - p.next (); - assert (false); - } - catch (const xml::exception& e) - { - // cerr << e.what () << endl; - } -} -- cgit v1.1