summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--tests/test_xpath.cpp22
-rw-r--r--tests/test_xpath_api.cpp26
-rw-r--r--tests/test_xpath_functions.cpp5
3 files changed, 51 insertions, 2 deletions
diff --git a/tests/test_xpath.cpp b/tests/test_xpath.cpp
index 29e7244..bfa4fed 100644
--- a/tests/test_xpath.cpp
+++ b/tests/test_xpath.cpp
@@ -272,4 +272,26 @@ TEST(xpath_document_order)
CHECK(xml_attribute().document_order() == 0);
CHECK(xml_node().document_order() == 0);
}
+
+TEST_XML(xpath_context_node, "<node>5</node>")
+{
+ CHECK_XPATH_NODESET(doc, STR("node")) % 2;
+ CHECK_XPATH_BOOLEAN(doc, STR("node"), true);
+ CHECK_XPATH_NUMBER(doc, STR("node"), 5);
+ CHECK_XPATH_STRING(doc, STR("node"), STR("5"));
+}
+
+TEST_XML(xpath_context_position, "<node>5</node>")
+{
+ CHECK_XPATH_NODESET(doc, STR("id(position() + last())"));
+ CHECK_XPATH_BOOLEAN(doc, STR("position() + last() = 2"), true);
+ CHECK_XPATH_NUMBER(doc, STR("position() + last()"), 2);
+ CHECK_XPATH_STRING(doc, STR("position() + last()"), STR("2"));
+}
+
+TEST(xpath_lexer_unknown_lexeme)
+{
+ CHECK_XPATH_FAIL(STR("(^3))"));
+ CHECK_XPATH_FAIL(STR("(!3))"));
+}
#endif
diff --git a/tests/test_xpath_api.cpp b/tests/test_xpath_api.cpp
index bf35b62..ad05083 100644
--- a/tests/test_xpath_api.cpp
+++ b/tests/test_xpath_api.cpp
@@ -114,6 +114,32 @@ TEST_XML(xpath_api_nodeset_accessors, "<node><foo/><foo/></node>")
xpath_node_set nullcopy = null;
}
+TEST_XML(xpath_api_nodeset_copy, "<node><foo/><foo/></node>")
+{
+ xpath_node_set set = doc.select_nodes(STR("node/foo"));
+
+ xpath_node_set copy1 = set;
+ CHECK(copy1.size() == 2);
+ CHECK_STRING(copy1[0].node().name(), STR("foo"));
+
+ xpath_node_set copy2;
+ copy2 = set;
+ CHECK(copy2.size() == 2);
+ CHECK_STRING(copy2[0].node().name(), STR("foo"));
+
+ xpath_node_set copy3;
+ copy3 = set;
+ copy3 = copy3;
+ CHECK(copy3.size() == 2);
+ CHECK_STRING(copy3[0].node().name(), STR("foo"));
+
+ xpath_node_set copy4;
+ copy4 = set;
+ copy4 = copy1;
+ CHECK(copy4.size() == 2);
+ CHECK_STRING(copy4[0].node().name(), STR("foo"));
+}
+
TEST_XML(xpath_api_evaluate, "<node attr='3'/>")
{
xpath_query q(STR("node/@attr"));
diff --git a/tests/test_xpath_functions.cpp b/tests/test_xpath_functions.cpp
index 3eb69c6..1d533b7 100644
--- a/tests/test_xpath_functions.cpp
+++ b/tests/test_xpath_functions.cpp
@@ -248,7 +248,7 @@ TEST_XML(xpath_boolean_lang, "<node xml:lang='en'><child xml:lang='ru-UK'><subch
CHECK_XPATH_FAIL(STR("lang(1, 2)"));
}
-TEST_XML(xpath_string_string, "<node>123<child id='1'>789</child><child><![CDATA[200]]></child>100</node>")
+TEST_XML(xpath_string_string, "<node>123<child id='1'>789</child><child><subchild><![CDATA[200]]></subchild></child>100</node>")
{
xml_node c;
xml_node n = doc.child(STR("node"));
@@ -629,7 +629,7 @@ TEST_XML_FLAGS(xpath_nodeset_local_name, "<node xmlns:foo='http://foo'><c1>text<
CHECK_XPATH_FAIL(STR("local-name(c1, c2)"));
}
-TEST_XML_FLAGS(xpath_nodeset_namespace_uri, "<node xmlns:foo='http://foo'><c1>text</c1><c2 xmlns:foo='http://foo2' foo:attr='value'><foo:child/></c2><c3 xmlns='http://def' attr='value'><child/></c3><c4><?target stuff?></c4><c5><foo:child/></c5><c6 bar:attr=''/></node>", parse_default | parse_pi)
+TEST_XML_FLAGS(xpath_nodeset_namespace_uri, "<node xmlns:foo='http://foo'><c1>text</c1><c2 xmlns:foo='http://foo2' foo:attr='value'><foo:child/></c2><c3 xmlns='http://def' attr='value'><child/></c3><c4><?target stuff?></c4><c5><foo:child/></c5><c6 bar:attr=''/><c7><node foo:attr=''/></c7></node>", parse_default | parse_pi)
{
xml_node c;
xml_node n = doc.child(STR("node"));
@@ -652,6 +652,7 @@ TEST_XML_FLAGS(xpath_nodeset_namespace_uri, "<node xmlns:foo='http://foo'><c1>te
CHECK_XPATH_STRING(n, STR("namespace-uri(c3/@attr)"), STR("")); // the namespace name for an unprefixed attribute name always has no value (Namespaces in XML 1.0)
CHECK_XPATH_STRING(n, STR("namespace-uri(c3/child::node())"), STR("http://def"));
CHECK_XPATH_STRING(n, STR("namespace-uri(c6/@bar:attr)"), STR(""));
+ CHECK_XPATH_STRING(n, STR("namespace-uri(c7/node/@foo:attr)"), STR("http://foo"));
// namespace-uri with 2 arguments
CHECK_XPATH_FAIL(STR("namespace-uri(c1, c2)"));