diff options
-rw-r--r-- | slicer/test/initial/bare.xml | 25 | ||||
-rw-r--r-- | slicer/test/preprocessor.cpp | 2 | ||||
-rw-r--r-- | slicer/test/serializers.cpp | 16 | ||||
-rw-r--r-- | slicer/test/types.ice | 6 |
4 files changed, 48 insertions, 1 deletions
diff --git a/slicer/test/initial/bare.xml b/slicer/test/initial/bare.xml new file mode 100644 index 0000000..aba53ec --- /dev/null +++ b/slicer/test/initial/bare.xml @@ -0,0 +1,25 @@ +<?xml version="1.0" encoding="UTF-8"?> +<BareContainers> + <bareSeq> + <a>1</a> + <b>2</b> + </bareSeq> + <bareSeq> + <a>3</a> + <b>4</b> + </bareSeq> + <bareMap> + <key>5</key> + <value> + <a>6</a> + <b>7</b> + </value> + </bareMap> + <bareMap> + <key>8</key> + <value> + <a>9</a> + <b>10</b> + </value> + </bareMap> +</BareContainers> diff --git a/slicer/test/preprocessor.cpp b/slicer/test/preprocessor.cpp index 10fedef..c318e84 100644 --- a/slicer/test/preprocessor.cpp +++ b/slicer/test/preprocessor.cpp @@ -13,7 +13,7 @@ namespace fs = boost::filesystem; -const unsigned int COMPONENTS_IN_TEST_ICE = 27; +const unsigned int COMPONENTS_IN_TEST_ICE = 28; BOOST_FIXTURE_TEST_SUITE ( preprocessor, FileStructure ); diff --git a/slicer/test/serializers.cpp b/slicer/test/serializers.cpp index 76a5033..f489af3 100644 --- a/slicer/test/serializers.cpp +++ b/slicer/test/serializers.cpp @@ -211,6 +211,17 @@ checkEntityRef(const TestModule2::EntityRef & er) BOOST_REQUIRE_EQUAL(er.Name, "Hull City"); } +void +checkBare(const TestModule::BareContainers & bc) +{ + BOOST_REQUIRE_EQUAL(bc.bareSeq.size(), 2); + BOOST_REQUIRE_EQUAL(bc.bareSeq[0]->a, 1); + BOOST_REQUIRE_EQUAL(bc.bareSeq[0]->b, 2); + BOOST_REQUIRE_EQUAL(bc.bareSeq[1]->a, 3); + BOOST_REQUIRE_EQUAL(bc.bareSeq[1]->b, 4); + BOOST_REQUIRE_EQUAL(bc.bareMap.size(), 2); +} + xmlpp::Document * readXml(const fs::path & path) { @@ -359,6 +370,11 @@ BOOST_AUTO_TEST_CASE( xml_attribute_xml ) verifyByFile<TestModule::ClassClassPtr, Slicer::XmlFileDeserializer>("xmlattr.xml"); } +BOOST_AUTO_TEST_CASE( xml_barecontainers_xml ) +{ + verifyByFile<TestModule::BareContainers, Slicer::XmlFileDeserializer>("bare.xml", checkBare); +} + BOOST_AUTO_TEST_SUITE_END(); diff --git a/slicer/test/types.ice b/slicer/test/types.ice index 7a66387..4192448 100644 --- a/slicer/test/types.ice +++ b/slicer/test/types.ice @@ -100,6 +100,12 @@ module TestModule { class InheritanceContMapped { Base2 b; }; + struct BareContainers { + [ "slicer:xml:bare" ] + Classes bareSeq; + [ "slicer:xml:bare" ] + ClassMap bareMap; + }; }; module TestModule2 { |