aboutsummaryrefslogtreecommitdiff
path: root/tests/cxx/parser/validation/built-in/qname/driver.cxx
diff options
context:
space:
mode:
Diffstat (limited to 'tests/cxx/parser/validation/built-in/qname/driver.cxx')
-rw-r--r--tests/cxx/parser/validation/built-in/qname/driver.cxx132
1 files changed, 132 insertions, 0 deletions
diff --git a/tests/cxx/parser/validation/built-in/qname/driver.cxx b/tests/cxx/parser/validation/built-in/qname/driver.cxx
new file mode 100644
index 0000000..f3acc6b
--- /dev/null
+++ b/tests/cxx/parser/validation/built-in/qname/driver.cxx
@@ -0,0 +1,132 @@
+// file : tests/cxx/parser/validation/built-in/qname/driver.cxx
+// author : Boris Kolpackov <boris@codesynthesis.com>
+// copyright : Copyright (c) 2006-2009 Code Synthesis Tools CC
+// license : GNU GPL v2 + exceptions; see accompanying LICENSE file
+
+// Test the built-in QName type validation.
+//
+#include <cassert>
+
+#include <xsde/config.h>
+
+// Let the runtime header sort out which version (stl/no-stl) to
+// include.
+//
+#include <xsde/cxx/parser/validating/xml-schema-pimpl.hxx>
+
+using namespace xsde::cxx;
+using namespace xsde::cxx::parser;
+using namespace xsde::cxx::parser::validating;
+
+#ifdef XSDE_STL
+bool
+compare (const qname& x, const char* p, const char* n)
+{
+ return x == qname (p, n);
+}
+#else
+bool
+compare (qname* x, const char* p, const char* n)
+{
+ qname y;
+ y.prefix_copy (p);
+ y.name_copy (n);
+
+ bool r = *x == y;
+ delete x;
+ return r;
+}
+#endif
+
+int
+main ()
+{
+ // Good.
+ //
+ {
+ context c (0);
+ qname_pimpl p;
+ p.pre ();
+ p._pre_impl (c);
+ p._characters (" xsi");
+ p._characters (":");
+ p._characters ("schemaLocation");
+ p._post ();
+ assert (!c.error_type () &&
+ compare (p.post_qname (), "xsi", "schemaLocation"));
+ }
+
+ {
+ context c (0);
+ qname_pimpl p;
+ p.pre ();
+ p._pre_impl (c);
+ p._characters ("schemaLocation");
+ p._post ();
+ assert (!c.error_type () &&
+ compare (p.post_qname (), "", "schemaLocation"));
+ }
+
+
+ // Bad
+ //
+ {
+ context c (0);
+ qname_pimpl p;
+ p.pre ();
+ p._pre_impl (c);
+ //p._characters ("");
+ p._post ();
+ assert (c.schema_error () == schema_error::invalid_qname_value);
+ }
+
+ {
+ context c (0);
+ qname_pimpl p;
+ p.pre ();
+ p._pre_impl (c);
+ p._characters (":");
+ p._post ();
+ assert (c.schema_error () == schema_error::invalid_qname_value);
+ }
+
+ {
+ context c (0);
+ qname_pimpl p;
+ p.pre ();
+ p._pre_impl (c);
+ p._characters ("xsi:");
+ p._post ();
+ assert (c.schema_error () == schema_error::invalid_qname_value);
+ }
+
+ {
+ context c (0);
+ qname_pimpl p;
+ p.pre ();
+ p._pre_impl (c);
+ p._characters (":schemaLocation");
+ p._post ();
+ assert (c.schema_error () == schema_error::invalid_qname_value);
+ }
+
+ {
+ context c (0);
+ qname_pimpl p;
+ p.pre ();
+ p._pre_impl (c);
+ p._characters ("x?i:schemaLocation");
+ p._post ();
+ assert (c.schema_error () == schema_error::invalid_qname_value);
+ }
+
+ {
+ context c (0);
+ qname_pimpl p;
+ p.pre ();
+ p._pre_impl (c);
+ p._characters ("xsi:schema Location");
+ p._post ();
+ assert (c.schema_error () == schema_error::invalid_qname_value);
+ }
+}