diff options
Diffstat (limited to 'tests/cxx/serializer/validation/built-in/string')
-rw-r--r-- | tests/cxx/serializer/validation/built-in/string/driver.cxx | 485 | ||||
-rw-r--r-- | tests/cxx/serializer/validation/built-in/string/makefile | 61 |
2 files changed, 546 insertions, 0 deletions
diff --git a/tests/cxx/serializer/validation/built-in/string/driver.cxx b/tests/cxx/serializer/validation/built-in/string/driver.cxx new file mode 100644 index 0000000..c1cfe21 --- /dev/null +++ b/tests/cxx/serializer/validation/built-in/string/driver.cxx @@ -0,0 +1,485 @@ +// file : tests/cxx/serializer/validation/built-in/string/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 string & friends types validation. +// +#include <string> +#include <cassert> + +#include <xsde/config.h> + +// Let the runtime header sort out which version (stl/no-stl) to +// include. +// +#include <xsde/cxx/serializer/validating/xml-schema-simpl.hxx> + +using namespace xsde::cxx; +using namespace xsde::cxx::serializer; +using namespace xsde::cxx::serializer::validating; + +int +main () +{ + // normalized_string + // + { + normalized_string_simpl s; + context c (0); + s.pre ("aaa\nbbb"); + s._pre_impl (c); + s._serialize_content (); + assert (c.schema_error () == schema_error::invalid_normalized_string_value); + } + + { + normalized_string_simpl s; + context c (0); + s.pre ("aaa\tbbb"); + s._pre_impl (c); + s._serialize_content (); + assert (c.schema_error () == schema_error::invalid_normalized_string_value); + } + + { + normalized_string_simpl s; + context c (0); + s.pre ("aaa\rbbb"); + s._pre_impl (c); + s._serialize_content (); + assert (c.schema_error () == schema_error::invalid_normalized_string_value); + } + + // token + // + { + token_simpl s; + context c (0); + s.pre ("aaa\nbbb"); + s._pre_impl (c); + s._serialize_content (); + assert (c.schema_error () == schema_error::invalid_token_value); + } + + { + token_simpl s; + context c (0); + s.pre ("aaa\tbbb"); + s._pre_impl (c); + s._serialize_content (); + assert (c.schema_error () == schema_error::invalid_token_value); + } + + { + token_simpl s; + context c (0); + s.pre ("aaa\rbbb"); + s._pre_impl (c); + s._serialize_content (); + assert (c.schema_error () == schema_error::invalid_token_value); + } + + { + token_simpl s; + context c (0); + s.pre ("aaa bbb"); + s._pre_impl (c); + s._serialize_content (); + assert (c.schema_error () == schema_error::invalid_token_value); + } + + { + token_simpl s; + context c (0); + s.pre (" aaa bbb"); + s._pre_impl (c); + s._serialize_content (); + assert (c.schema_error () == schema_error::invalid_token_value); + } + + { + token_simpl s; + context c (0); + s.pre ("aaa bbb "); + s._pre_impl (c); + s._serialize_content (); + assert (c.schema_error () == schema_error::invalid_token_value); + } + + // name + // + { + name_simpl s; + context c (0); + s.pre (""); + s._pre_impl (c); + s._serialize_content (); + assert (c.schema_error () == schema_error::invalid_name_value); + } + + { + name_simpl s; + context c (0); + s.pre (".a"); + s._pre_impl (c); + s._serialize_content (); + assert (c.schema_error () == schema_error::invalid_name_value); + } + + { + name_simpl s; + context c (0); + s.pre ("-a"); + s._pre_impl (c); + s._serialize_content (); + assert (c.schema_error () == schema_error::invalid_name_value); + } + + { + name_simpl s; + context c (0); + s.pre ("1a"); + s._pre_impl (c); + s._serialize_content (); + assert (c.schema_error () == schema_error::invalid_name_value); + } + + { + name_simpl s; + context c (0); + s.pre (" a"); + s._pre_impl (c); + s._serialize_content (); + assert (c.schema_error () == schema_error::invalid_name_value); + } + + { + name_simpl s; + context c (0); + s.pre ("a,b"); + s._pre_impl (c); + s._serialize_content (); + assert (c.schema_error () == schema_error::invalid_name_value); + } + + { + name_simpl s; + context c (0); + s.pre ("a b"); + s._pre_impl (c); + s._serialize_content (); + assert (c.schema_error () == schema_error::invalid_name_value); + } + + { + name_simpl s; + context c (0); + s.pre ("a<b"); + s._pre_impl (c); + s._serialize_content (); + assert (c.schema_error () == schema_error::invalid_name_value); + } + + { + name_simpl s; + context c (0); + s.pre ("a "); + s._pre_impl (c); + s._serialize_content (); + assert (c.schema_error () == schema_error::invalid_name_value); + } + + // nmtoken + // + { + nmtoken_simpl s; + context c (0); + s.pre (""); + s._pre_impl (c); + s._serialize_content (); + assert (c.schema_error () == schema_error::invalid_nmtoken_value); + } + + { + nmtoken_simpl s; + context c (0); + s.pre (" a"); + s._pre_impl (c); + s._serialize_content (); + assert (c.schema_error () == schema_error::invalid_nmtoken_value); + } + + { + nmtoken_simpl s; + context c (0); + s.pre ("a,b"); + s._pre_impl (c); + s._serialize_content (); + assert (c.schema_error () == schema_error::invalid_nmtoken_value); + } + + { + nmtoken_simpl s; + context c (0); + s.pre ("a b"); + s._pre_impl (c); + s._serialize_content (); + assert (c.schema_error () == schema_error::invalid_nmtoken_value); + } + + { + nmtoken_simpl s; + context c (0); + s.pre ("a<b"); + s._pre_impl (c); + s._serialize_content (); + assert (c.schema_error () == schema_error::invalid_nmtoken_value); + } + + { + nmtoken_simpl s; + context c (0); + s.pre ("a "); + s._pre_impl (c); + s._serialize_content (); + assert (c.schema_error () == schema_error::invalid_nmtoken_value); + } + + // nmtokens + // + { + nmtokens_simpl s; + context c (0); + string_sequence seq; + s.pre (&seq); + s._pre_impl (c); + s._serialize_content (); + assert (c.schema_error () == schema_error::invalid_nmtokens_value); + } + + { + nmtokens_simpl s; + context c (0); + string_sequence seq; +#ifdef XSDE_STL + seq.push_back ("a,b"); + seq.push_back ("ab"); +#else + seq.push_back_copy ("a,b"); + seq.push_back_copy ("ab"); +#endif + s.pre (&seq); + s._pre_impl (c); + s._serialize_content (); + assert (c.schema_error () == schema_error::invalid_nmtoken_value); + } + + // ncname + // + { + ncname_simpl s; + context c (0); + s.pre (""); + s._pre_impl (c); + s._serialize_content (); + assert (c.schema_error () == schema_error::invalid_ncname_value); + } + + { + ncname_simpl s; + context c (0); + s.pre (" a"); + s._pre_impl (c); + s._serialize_content (); + assert (c.schema_error () == schema_error::invalid_ncname_value); + } + + { + ncname_simpl s; + context c (0); + s.pre (".a"); + s._pre_impl (c); + s._serialize_content (); + assert (c.schema_error () == schema_error::invalid_ncname_value); + } + + { + ncname_simpl s; + context c (0); + s.pre ("-a"); + s._pre_impl (c); + s._serialize_content (); + assert (c.schema_error () == schema_error::invalid_ncname_value); + } + + { + ncname_simpl s; + context c (0); + s.pre (":a"); + s._pre_impl (c); + s._serialize_content (); + assert (c.schema_error () == schema_error::invalid_ncname_value); + } + + { + ncname_simpl s; + context c (0); + s.pre ("1a"); + s._pre_impl (c); + s._serialize_content (); + assert (c.schema_error () == schema_error::invalid_ncname_value); + } + + { + ncname_simpl s; + context c (0); + s.pre ("a,b"); + s._pre_impl (c); + s._serialize_content (); + assert (c.schema_error () == schema_error::invalid_ncname_value); + } + + { + ncname_simpl s; + context c (0); + s.pre ("a b"); + s._pre_impl (c); + s._serialize_content (); + assert (c.schema_error () == schema_error::invalid_ncname_value); + } + + { + ncname_simpl s; + context c (0); + s.pre ("a:b"); + s._pre_impl (c); + s._serialize_content (); + assert (c.schema_error () == schema_error::invalid_ncname_value); + } + + { + ncname_simpl s; + context c (0); + s.pre ("a<b"); + s._pre_impl (c); + s._serialize_content (); + assert (c.schema_error () == schema_error::invalid_ncname_value); + } + + { + ncname_simpl s; + context c (0); + s.pre ("a "); + s._pre_impl (c); + s._serialize_content (); + assert (c.schema_error () == schema_error::invalid_ncname_value); + } + + // id + // + { + id_simpl s; + context c (0); + s.pre ("a b"); + s._pre_impl (c); + s._serialize_content (); + assert (c.schema_error () == schema_error::invalid_id_value); + } + + // idref + // + { + idref_simpl s; + context c (0); + s.pre ("a b"); + s._pre_impl (c); + s._serialize_content (); + assert (c.schema_error () == schema_error::invalid_idref_value); + } + + // idrefs + // + { + idrefs_simpl s; + context c (0); + string_sequence seq; + s.pre (&seq); + s._pre_impl (c); + s._serialize_content (); + assert (c.schema_error () == schema_error::invalid_idrefs_value); + } + + { + idrefs_simpl s; + context c (0); + string_sequence seq; +#ifdef XSDE_STL + seq.push_back ("a,b"); + seq.push_back ("ab"); +#else + seq.push_back_copy ("a,b"); + seq.push_back_copy ("ab"); +#endif + s.pre (&seq); + s._pre_impl (c); + s._serialize_content (); + assert (c.schema_error () == schema_error::invalid_idref_value); + } + + // language + // + { + language_simpl s; + context c (0); + s.pre (""); + s._pre_impl (c); + s._serialize_content (); + assert (c.schema_error () == schema_error::invalid_language_value); + } + + { + language_simpl s; + context c (0); + s.pre (" "); + s._pre_impl (c); + s._serialize_content (); + assert (c.schema_error () == schema_error::invalid_language_value); + } + + { + language_simpl s; + context c (0); + s.pre ("en-"); + s._pre_impl (c); + s._serialize_content (); + assert (c.schema_error () == schema_error::invalid_language_value); + } + + { + language_simpl s; + context c (0); + s.pre ("a1"); + s._pre_impl (c); + s._serialize_content (); + assert (c.schema_error () == schema_error::invalid_language_value); + } + + { + language_simpl s; + context c (0); + s.pre ("en+us"); + s._pre_impl (c); + s._serialize_content (); + assert (c.schema_error () == schema_error::invalid_language_value); + } + + { + language_simpl s; + context c (0); + s.pre ("en-nine99999"); + s._pre_impl (c); + s._serialize_content (); + assert (c.schema_error () == schema_error::invalid_language_value); + } +} diff --git a/tests/cxx/serializer/validation/built-in/string/makefile b/tests/cxx/serializer/validation/built-in/string/makefile new file mode 100644 index 0000000..42a7d81 --- /dev/null +++ b/tests/cxx/serializer/validation/built-in/string/makefile @@ -0,0 +1,61 @@ +# file : tests/cxx/serializer/validation/built-in/string/makefile +# author : Boris Kolpackov <boris@codesynthesis.com> +# copyright : Copyright (c) 2006-2009 Code Synthesis Tools CC +# license : GNU GPL v2 + exceptions; see accompanying LICENSE file + +include $(dir $(lastword $(MAKEFILE_LIST)))../../../../../../build/bootstrap.make + +cxx := driver.cxx + +obj := $(addprefix $(out_base)/,$(cxx:.cxx=.o)) +dep := $(obj:.o=.o.d) + +xsde.l := $(out_root)/libxsde/xsde/xsde.l +xsde.l.cpp-options := $(out_root)/libxsde/xsde/xsde.l.cpp-options + +driver := $(out_base)/driver +test := $(out_base)/.test +clean := $(out_base)/.clean + + +# Build. +# +$(driver): $(obj) $(xsde.l) + +$(obj) $(dep): $(xsde.l.cpp-options) + +$(call include-dep,$(dep)) + +# Convenience alias for default target. +# +.PHONY: $(out_base)/ +$(out_base)/: $(driver) + + +# Test. +# +.PHONY: $(test) + +$(test): driver := $(driver) +$(test): $(driver) + $(call message,test $$1,$$1,$(driver)) + +# Clean. +# +.PHONY: $(clean) + +$(clean): $(driver).o.clean \ + $(addsuffix .cxx.clean,$(obj)) \ + $(addsuffix .cxx.clean,$(dep)) + + +# How to. +# +$(call include,$(bld_root)/cxx/o-e.make) +$(call include,$(bld_root)/cxx/cxx-o.make) +$(call include,$(bld_root)/cxx/cxx-d.make) + + +# Dependencies. +# +$(call import,$(src_root)/libxsde/xsde/makefile) |