From e08c065820d734d4f5768470ed6a4f123cbb56ef Mon Sep 17 00:00:00 2001 From: "arseny.kapoulkine" Date: Sun, 29 Aug 2010 15:27:51 +0000 Subject: tests: Added XPath tests for attribute context git-svn-id: http://pugixml.googlecode.com/svn/trunk@664 99668b35-9821-0410-8761-19e4c4f06640 --- tests/test_xpath_paths.cpp | 36 +++++++++++++++++++++++++++++++++++- 1 file changed, 35 insertions(+), 1 deletion(-) (limited to 'tests/test_xpath_paths.cpp') diff --git a/tests/test_xpath_paths.cpp b/tests/test_xpath_paths.cpp index 2799f40..829cac7 100644 --- a/tests/test_xpath_paths.cpp +++ b/tests/test_xpath_paths.cpp @@ -6,6 +6,7 @@ TEST_XML(xpath_paths_axes_child, "") { xml_node c; xml_node n = doc.child(STR("node")); + xpath_node na(n.attribute(STR("attr")), n); CHECK_XPATH_NODESET(c, STR("descendant:: node()")); @@ -28,12 +31,14 @@ TEST_XML(xpath_paths_axes_descendant, "") { xml_node c; xml_node n = doc.child(STR("node")); + xpath_node na(n.attribute(STR("attr")), n); CHECK_XPATH_NODESET(c, STR("parent:: node()")); @@ -42,12 +47,15 @@ TEST_XML(xpath_paths_axes_parent, "") { xml_node c; xml_node n = doc.child(STR("node")); + xpath_node na(n.child(STR("child")).attribute(STR("attr")), n.child(STR("child"))); CHECK_XPATH_NODESET(c, STR("ancestor:: node()")); @@ -56,36 +64,45 @@ TEST_XML(xpath_paths_axes_ancestor, "") { xml_node c; xml_node n = doc.child(STR("node")); + xpath_node na(n.attribute(STR("attr1")), n); CHECK_XPATH_NODESET(c, STR("following-sibling:: node()")); CHECK_XPATH_NODESET(n.child(STR("child")), STR("following-sibling:: node()")) % 8 % 10; // another, last CHECK_XPATH_NODESET(n.child(STR("last")), STR("following-sibling:: node()")); + CHECK_XPATH_NODESET(n, STR("@attr1/following-sibling:: node()")); // attributes are not siblings + CHECK_XPATH_NODESET(na, STR("following-sibling:: node()")); // attributes are not siblings } TEST_XML(xpath_paths_axes_preceding_sibling, "") { xml_node c; xml_node n = doc.child(STR("node")); + xpath_node na(n.attribute(STR("attr2")), n); CHECK_XPATH_NODESET(c, STR("preceding-sibling:: node()")); CHECK_XPATH_NODESET(n.child(STR("child")), STR("preceding-sibling:: node()")); CHECK_XPATH_NODESET(n.child(STR("last")), STR("preceding-sibling:: node()")) % 8 % 5; // another, child + CHECK_XPATH_NODESET(n, STR("@attr2/following-sibling:: node()")); // attributes are not siblings + CHECK_XPATH_NODESET(na, STR("following-sibling:: node()")); // attributes are not siblings } TEST_XML(xpath_paths_axes_following, "") { xml_node c; xml_node n = doc.child(STR("node")); + xpath_node na(n.attribute(STR("attr1")), n); CHECK_XPATH_NODESET(c, STR("following:: node()")); @@ -96,12 +113,14 @@ TEST_XML(xpath_paths_axes_following, "") { xml_node c; xml_node n = doc.child(STR("node")); + xpath_node na(n.child(STR("child")).attribute(STR("attr")), n.child(STR("child"))); CHECK_XPATH_NODESET(c, STR("preceding:: node()")); @@ -112,12 +131,14 @@ TEST_XML(xpath_paths_axes_preceding, "") { xml_node c; xml_node n = doc.child(STR("node")); + xpath_node na(n.attribute(STR("attr1")), n); CHECK_XPATH_NODESET(c, STR("attribute:: node()")); @@ -128,20 +149,25 @@ TEST_XML(xpath_paths_axes_attribute, "") { xml_node n = doc.child(STR("node")); + xpath_node na(n.attribute(STR("attr")), n); - CHECK_XPATH_NODESET(n, STR("namespace:: node()")); // namespace nodes are not supported + // namespace nodes are not supported + CHECK_XPATH_NODESET(n, STR("namespace:: node()")); CHECK_XPATH_NODESET(n, STR("@attr/attribute::node()")); + CHECK_XPATH_NODESET(na, STR("attribute::node()")); } TEST_XML(xpath_paths_axes_self, "") { xml_node c; xml_node n = doc.child(STR("node")); + xpath_node na(n.attribute(STR("attr")), n); CHECK_XPATH_NODESET(c, STR("self:: node()")); @@ -150,12 +176,14 @@ TEST_XML(xpath_paths_axes_self, "") { xml_node c; xml_node n = doc.child(STR("node")); + xpath_node na(n.child(STR("child")).attribute(STR("attr")), n.child(STR("child"))); CHECK_XPATH_NODESET(c, STR("descendant-or-self:: node()")); @@ -165,12 +193,14 @@ TEST_XML(xpath_paths_axes_descendant_or_self, "") { xml_node c; xml_node n = doc.child(STR("node")); + xpath_node na(n.child(STR("child")).attribute(STR("attr")), n.child(STR("child"))); CHECK_XPATH_NODESET(c, STR("ancestor-or-self:: node()")); @@ -181,6 +211,7 @@ TEST_XML(xpath_paths_axes_ancestor_or_self, "") @@ -331,15 +362,18 @@ TEST_XML(xpath_paths_absolute, "") { xml_node c; xml_node n = doc.child(STR("node")); + xpath_node na(n.attribute(STR("attr")), n); CHECK_XPATH_NODESET(c, STR("/foo")); CHECK_XPATH_NODESET(n, STR("/foo")); CHECK_XPATH_NODESET(n, STR("/node/foo")) % 3; CHECK_XPATH_NODESET(n.child(STR("foo")), STR("/node/foo")) % 3; + CHECK_XPATH_NODESET(na, STR("/node/foo")) % 3; CHECK_XPATH_NODESET(c, STR("/")); CHECK_XPATH_NODESET(n, STR("/")) % 1; CHECK_XPATH_NODESET(n.child(STR("foo")), STR("/")) % 1; + CHECK_XPATH_NODESET(na, STR("/")) % 1; } TEST_XML(xpath_paths_step_abbrev, "") -- cgit v1.2.3