summaryrefslogtreecommitdiff
path: root/sal/qa/rtl/strings/test_oustring_compare.cxx
diff options
context:
space:
mode:
Diffstat (limited to 'sal/qa/rtl/strings/test_oustring_compare.cxx')
-rw-r--r--sal/qa/rtl/strings/test_oustring_compare.cxx22
1 files changed, 21 insertions, 1 deletions
diff --git a/sal/qa/rtl/strings/test_oustring_compare.cxx b/sal/qa/rtl/strings/test_oustring_compare.cxx
index 4f056e12889d..77f2fb7f293f 100644
--- a/sal/qa/rtl/strings/test_oustring_compare.cxx
+++ b/sal/qa/rtl/strings/test_oustring_compare.cxx
@@ -29,12 +29,13 @@ class Compare: public CppUnit::TestFixture
{
private:
void equalsIgnoreAsciiCaseAscii();
-
void compareToIgnoreAsciiCase();
+ void compareTo();
CPPUNIT_TEST_SUITE(Compare);
CPPUNIT_TEST(equalsIgnoreAsciiCaseAscii);
CPPUNIT_TEST(compareToIgnoreAsciiCase);
+CPPUNIT_TEST(compareTo);
CPPUNIT_TEST_SUITE_END();
};
@@ -74,4 +75,23 @@ void test::oustring::Compare::compareToIgnoreAsciiCase()
rtl::OUString("A").compareToIgnoreAsciiCase("_") > 0);
}
+void test::oustring::Compare::compareTo()
+{
+ // test that embedded NUL does not stop the compare
+ // this sort of thing is how we assing shape ids in oox
+ sal_Unicode str1[2] = { '\0', 'x' };
+ sal_Unicode str2[2] = { '\0', 'y' };
+
+ OUString s1(str1, 2);
+ OUString s2(str2, 2);
+ CPPUNIT_ASSERT(s1.compareTo(s1) == 0);
+ CPPUNIT_ASSERT(s2.compareTo(s2) == 0);
+ CPPUNIT_ASSERT(s1.compareTo(s2) < 0);
+ CPPUNIT_ASSERT(s2.compareTo(s1) > 0);
+ CPPUNIT_ASSERT(s1.compareTo(OUString(s2 + "y")) < 0);
+ CPPUNIT_ASSERT(s2.compareTo(OUString(s1 + "x")) > 0);
+ CPPUNIT_ASSERT(OUString(s1 + "x").compareTo(s2) < 0);
+ CPPUNIT_ASSERT(OUString(s2 + "y").compareTo(s1) > 0);
+}
+
/* vim:set shiftwidth=4 softtabstop=4 expandtab: */