diff options
Diffstat (limited to 'sal/qa/rtl/strings/test_oustring_compare.cxx')
-rw-r--r-- | sal/qa/rtl/strings/test_oustring_compare.cxx | 22 |
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: */ |