diff --git a/tests/test_xpath_functions.cpp b/tests/test_xpath_functions.cpp
index e4430f3..d033ab4 100644
--- a/tests/test_xpath_functions.cpp
+++ b/tests/test_xpath_functions.cpp
@@ -185,5 +185,35 @@ TEST(xpath_boolean_false)
CHECK_XPATH_FAIL("false(1)");
}
+TEST_XML(xpath_boolean_lang, "")
+{
+ xml_node c;
+
+ // lang with 0 arguments
+ CHECK_XPATH_FAIL("lang()");
+
+ // lang with 1 argument, no language
+ CHECK_XPATH_BOOLEAN(c, "lang('en')", false);
+ CHECK_XPATH_BOOLEAN(doc.child("foo"), "lang('en')", false);
+ CHECK_XPATH_BOOLEAN(doc.child("foo"), "lang('')", false);
+ CHECK_XPATH_BOOLEAN(doc.child("foo").child("bar"), "lang('en')", false);
+
+ // lang with 1 argument, same language/prefix
+ CHECK_XPATH_BOOLEAN(doc.child("node"), "lang('en')", true);
+ CHECK_XPATH_BOOLEAN(doc.child("node").child("child"), "lang('ru-uk')", true);
+ CHECK_XPATH_BOOLEAN(doc.child("node").child("child"), "lang('ru')", true);
+ CHECK_XPATH_BOOLEAN(doc.child("node").child("child").child("subchild"), "lang('ru')", true);
+
+ // lang with 1 argument, different language/prefix
+ CHECK_XPATH_BOOLEAN(doc.child("node"), "lang('')", false);
+ CHECK_XPATH_BOOLEAN(doc.child("node"), "lang('e')", false);
+ CHECK_XPATH_BOOLEAN(doc.child("node").child("child"), "lang('en')", false);
+ CHECK_XPATH_BOOLEAN(doc.child("node").child("child"), "lang('ru-gb')", false);
+ CHECK_XPATH_BOOLEAN(doc.child("node").child("child"), "lang('r')", false);
+ CHECK_XPATH_BOOLEAN(doc.child("node").child("child").child("subchild"), "lang('en')", false);
+
+ // lang with 2 arguments
+ CHECK_XPATH_FAIL("lang(1, 2)");
+}
+
// $$$: string value of 123789100 should be 123789100 (?)
-// $$$: type -> node set conversion seems to be guarded via assert instead of exception