From 267c6f2ac71f92999e969232431ba04678e7437e Mon Sep 17 00:00:00 2001 From: Daniel Baumann Date: Mon, 15 Apr 2024 07:54:39 +0200 Subject: Adding upstream version 4:24.2.0. Signed-off-by: Daniel Baumann --- .../qa/cppunit/test_characterclassification.cxx | 289 +++++++++++++++++++++ 1 file changed, 289 insertions(+) create mode 100644 i18npool/qa/cppunit/test_characterclassification.cxx (limited to 'i18npool/qa/cppunit/test_characterclassification.cxx') diff --git a/i18npool/qa/cppunit/test_characterclassification.cxx b/i18npool/qa/cppunit/test_characterclassification.cxx new file mode 100644 index 0000000000..06f6095a37 --- /dev/null +++ b/i18npool/qa/cppunit/test_characterclassification.cxx @@ -0,0 +1,289 @@ +/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */ +/* + * This file is part of the LibreOffice project. + * + * This Source Code Form is subject to the terms of the Mozilla Public + * License, v. 2.0. If a copy of the MPL was not distributed with this + * file, You can obtain one at http://mozilla.org/MPL/2.0/. + */ + +#include +#include +#include + +using namespace ::com::sun::star; + +class TestCharacterClassification : public test::BootstrapFixtureBase +{ +public: + virtual void setUp() override; + virtual void tearDown() override; + +protected: + uno::Reference m_xCC; +}; + +//A test to ensure that our Title Case functionality is working +//http://lists.freedesktop.org/archives/libreoffice/2012-June/032767.html +//https://bz.apache.org/ooo/show_bug.cgi?id=30863 +CPPUNIT_TEST_FIXTURE(TestCharacterClassification, testTitleCase) +{ + lang::Locale aLocale; + aLocale.Language = "en"; + aLocale.Country = "US"; + + { + //basic example + OUString sTest("Some text"); + OUString sTitleCase = m_xCC->toTitle(sTest, 0, sTest.getLength(), aLocale); + CPPUNIT_ASSERT_EQUAL_MESSAGE("Should be title", OUString("Some Text"), sTitleCase); + OUString sUpperCase = m_xCC->toUpper(sTest, 0, sTest.getLength(), aLocale); + CPPUNIT_ASSERT_EQUAL_MESSAGE("Should be upper", OUString("SOME TEXT"), sUpperCase); + OUString sLowerCase = m_xCC->toLower(sTest, 0, sTest.getLength(), aLocale); + CPPUNIT_ASSERT_EQUAL_MESSAGE("Should be lower ", OUString("some text"), sLowerCase); + } + + { + //tricky one + static constexpr OUString aTest = u"\u01F3"_ustr; // LATIN SMALL LETTER DZ + OUString sTitleCase = m_xCC->toTitle(aTest, 0, aTest.getLength(), aLocale); + CPPUNIT_ASSERT_EQUAL_MESSAGE("Should be title", sal_Int32(1), sTitleCase.getLength()); + CPPUNIT_ASSERT_EQUAL_MESSAGE("Should be title", u'\u01F2', sTitleCase[0]); + OUString sUpperCase = m_xCC->toUpper(aTest, 0, aTest.getLength(), aLocale); + CPPUNIT_ASSERT_EQUAL_MESSAGE("Should be upper", sal_Int32(1), sUpperCase.getLength()); + CPPUNIT_ASSERT_EQUAL_MESSAGE("Should be upper", u'\u01F1', sUpperCase[0]); + OUString sLowerCase = m_xCC->toLower(aTest, 0, aTest.getLength(), aLocale); + CPPUNIT_ASSERT_EQUAL_MESSAGE("Should be lower ", sal_Int32(1), sLowerCase.getLength()); + CPPUNIT_ASSERT_EQUAL_MESSAGE("Should be lower ", u'\u01F3', sLowerCase[0]); + } +} + +//https://bugs.libreoffice.org/show_bug.cgi?id=69641 +CPPUNIT_TEST_FIXTURE(TestCharacterClassification, testStringType) +{ + lang::Locale aLocale; + aLocale.Language = "en"; + aLocale.Country = "US"; + + { + //simple case + OUString sTest("Some text"); + sal_Int32 nResult = m_xCC->getStringType(sTest, 0, sTest.getLength(), aLocale); + CPPUNIT_ASSERT_EQUAL(sal_Int32(230), nResult); + } + + { + //tricky case + static constexpr OUString sTest = u"\U0001D703"_ustr; // MATHEMATICAL ITALIC SMALL THETA + sal_Int32 nResult = m_xCC->getStringType(sTest, 0, sTest.getLength(), aLocale); + CPPUNIT_ASSERT_EQUAL(sal_Int32(228), nResult); + } + +} + +CPPUNIT_TEST_FIXTURE(TestCharacterClassification, testSigma) +{ + { + // From upper case + OUString sTest(u"ὈΔΥΣΣΕΎΣ"_ustr); + OUString sLowerCase = m_xCC->toLower(sTest, 0, sTest.getLength(), {}); + CPPUNIT_ASSERT_EQUAL_MESSAGE("Should be lower", u"ὀδυσσεύς"_ustr, sLowerCase); + OUString sUpperCase = m_xCC->toUpper(sLowerCase, 0, sLowerCase.getLength(), {}); + CPPUNIT_ASSERT_EQUAL_MESSAGE("Should be upper", sTest, sUpperCase); + } + + { + // From lower case + OUString sTest(u"ὀδυσσεύς"_ustr); + OUString sTitleCase = m_xCC->toTitle(sTest, 0, sTest.getLength(), {}); + CPPUNIT_ASSERT_EQUAL_MESSAGE("Should be title", u"Ὀδυσσεύς"_ustr, sTitleCase); + OUString sUpperCase = m_xCC->toUpper(sTest, 0, sTest.getLength(), {}); + CPPUNIT_ASSERT_EQUAL_MESSAGE("Should be upper", u"ὈΔΥΣΣΕΎΣ"_ustr, sUpperCase); + OUString sLowerCase = m_xCC->toLower(sUpperCase, 0, sUpperCase.getLength(), {}); + CPPUNIT_ASSERT_EQUAL_MESSAGE("Should be lower", sTest, sLowerCase); + } + + { + // From title case + OUString sTest(u"Ὀδυσσεύς"_ustr); + OUString sTitleCase = m_xCC->toTitle(sTest, 0, sTest.getLength(), {}); + CPPUNIT_ASSERT_EQUAL_MESSAGE("Should be title", u"Ὀδυσσεύς"_ustr, sTitleCase); + OUString sUpperCase = m_xCC->toUpper(sTest, 0, sTest.getLength(), {}); + CPPUNIT_ASSERT_EQUAL_MESSAGE("Should be upper", u"ὈΔΥΣΣΕΎΣ"_ustr, sUpperCase); + OUString sLowerCase = m_xCC->toLower(sTest, 0, sTest.getLength(), {}); + CPPUNIT_ASSERT_EQUAL_MESSAGE("Should be lower", u"ὀδυσσεύς"_ustr, sLowerCase); + } +} + +CPPUNIT_TEST_FIXTURE(TestCharacterClassification, testTdf96343) +{ + { + // From upper case + OUString sTest(u"ꙊꙌꙖ"_ustr); + OUString sLowerCase = m_xCC->toLower(sTest, 0, sTest.getLength(), {}); + CPPUNIT_ASSERT_EQUAL_MESSAGE("Should be lower", u"ꙋꙍꙗ"_ustr, sLowerCase); + OUString sUpperCase = m_xCC->toUpper(sLowerCase, 0, sLowerCase.getLength(), {}); + CPPUNIT_ASSERT_EQUAL_MESSAGE("Should be upper", sTest, sUpperCase); + } + + { + // From lower case + OUString sTest(u"ꙋꙍꙗ"_ustr); + OUString sTitleCase = m_xCC->toTitle(sTest, 0, sTest.getLength(), {}); + CPPUNIT_ASSERT_EQUAL_MESSAGE("Should be title", u"Ꙋꙍꙗ"_ustr, sTitleCase); + OUString sUpperCase = m_xCC->toUpper(sTest, 0, sTest.getLength(), {}); + CPPUNIT_ASSERT_EQUAL_MESSAGE("Should be upper", u"ꙊꙌꙖ"_ustr, sUpperCase); + OUString sLowerCase = m_xCC->toLower(sUpperCase, 0, sUpperCase.getLength(), {}); + CPPUNIT_ASSERT_EQUAL_MESSAGE("Should be lower", sTest, sLowerCase); + } + + { + // From title case + OUString sTest(u"Ꙋꙍꙗ"_ustr); + OUString sTitleCase = m_xCC->toTitle(sTest, 0, sTest.getLength(), {}); + CPPUNIT_ASSERT_EQUAL_MESSAGE("Should be title", u"Ꙋꙍꙗ"_ustr, sTitleCase); + OUString sUpperCase = m_xCC->toUpper(sTest, 0, sTest.getLength(), {}); + CPPUNIT_ASSERT_EQUAL_MESSAGE("Should be upper", u"ꙊꙌꙖ"_ustr, sUpperCase); + OUString sLowerCase = m_xCC->toLower(sTest, 0, sTest.getLength(), {}); + CPPUNIT_ASSERT_EQUAL_MESSAGE("Should be lower", u"ꙋꙍꙗ"_ustr, sLowerCase); + } +} + +CPPUNIT_TEST_FIXTURE(TestCharacterClassification, testTdf134766) +{ + { + // From upper case + OUString sTest(u"QꞋORBꞋAL"_ustr); + OUString sLowerCase = m_xCC->toLower(sTest, 0, sTest.getLength(), {}); + CPPUNIT_ASSERT_EQUAL_MESSAGE("Should be lower", u"qꞌorbꞌal"_ustr, sLowerCase); + OUString sUpperCase = m_xCC->toUpper(sLowerCase, 0, sLowerCase.getLength(), {}); + CPPUNIT_ASSERT_EQUAL_MESSAGE("Should be upper", sTest, sUpperCase); + } + + { + // From lower case + OUString sTest(u"qꞌorbꞌal"_ustr); + OUString sTitleCase = m_xCC->toTitle(sTest, 0, sTest.getLength(), {}); + CPPUNIT_ASSERT_EQUAL_MESSAGE("Should be title", u"Qꞌorbꞌal"_ustr, sTitleCase); + OUString sUpperCase = m_xCC->toUpper(sTest, 0, sTest.getLength(), {}); + CPPUNIT_ASSERT_EQUAL_MESSAGE("Should be upper", u"QꞋORBꞋAL"_ustr, sUpperCase); + OUString sLowerCase = m_xCC->toLower(sUpperCase, 0, sUpperCase.getLength(), {}); + CPPUNIT_ASSERT_EQUAL_MESSAGE("Should be lower", sTest, sLowerCase); + } + + { + // From title case + OUString sTest(u"Qꞌorbꞌal"_ustr); + OUString sTitleCase = m_xCC->toTitle(sTest, 0, sTest.getLength(), {}); + CPPUNIT_ASSERT_EQUAL_MESSAGE("Should be title", u"Qꞌorbꞌal"_ustr, sTitleCase); + OUString sUpperCase = m_xCC->toUpper(sTest, 0, sTest.getLength(), {}); + CPPUNIT_ASSERT_EQUAL_MESSAGE("Should be upper", u"QꞋORBꞋAL"_ustr, sUpperCase); + OUString sLowerCase = m_xCC->toLower(sTest, 0, sTest.getLength(), {}); + CPPUNIT_ASSERT_EQUAL_MESSAGE("Should be lower", u"qꞌorbꞌal"_ustr, sLowerCase); + } +} + +CPPUNIT_TEST_FIXTURE(TestCharacterClassification, testTdf97152) +{ + { + // From upper case + OUString sTest(u"ͲͰϽϾϿͿϏϹ"_ustr); + OUString sLowerCase = m_xCC->toLower(sTest, 0, sTest.getLength(), {}); + CPPUNIT_ASSERT_EQUAL_MESSAGE("Should be lower", u"ͳͱͻͼͽϳϗϲ"_ustr, sLowerCase); + OUString sUpperCase = m_xCC->toUpper(sLowerCase, 0, sLowerCase.getLength(), {}); + CPPUNIT_ASSERT_EQUAL_MESSAGE("Should be upper", sTest, sUpperCase); + } + + { + // From lower case + OUString sTest(u"ͳͱͻͼͽϳϗϲ"_ustr); + OUString sTitleCase = m_xCC->toTitle(sTest, 0, sTest.getLength(), {}); + CPPUNIT_ASSERT_EQUAL_MESSAGE("Should be title", u"Ͳͱͻͼͽϳϗϲ"_ustr, sTitleCase); + OUString sUpperCase = m_xCC->toUpper(sTest, 0, sTest.getLength(), {}); + CPPUNIT_ASSERT_EQUAL_MESSAGE("Should be upper", u"ͲͰϽϾϿͿϏϹ"_ustr, sUpperCase); + OUString sLowerCase = m_xCC->toLower(sUpperCase, 0, sUpperCase.getLength(), {}); + CPPUNIT_ASSERT_EQUAL_MESSAGE("Should be lower", sTest, sLowerCase); + } + + { + // From title case + OUString sTest(u"Ͳͱͻͼͽϳϗϲ"_ustr); + OUString sTitleCase = m_xCC->toTitle(sTest, 0, sTest.getLength(), {}); + CPPUNIT_ASSERT_EQUAL_MESSAGE("Should be title", u"Ͳͱͻͼͽϳϗϲ"_ustr, sTitleCase); + OUString sUpperCase = m_xCC->toUpper(sTest, 0, sTest.getLength(), {}); + CPPUNIT_ASSERT_EQUAL_MESSAGE("Should be upper", u"ͲͰϽϾϿͿϏϹ"_ustr, sUpperCase); + OUString sLowerCase = m_xCC->toLower(sTest, 0, sTest.getLength(), {}); + CPPUNIT_ASSERT_EQUAL_MESSAGE("Should be lower", u"ͳͱͻͼͽϳϗϲ"_ustr, sLowerCase); + } +} + +CPPUNIT_TEST_FIXTURE(TestCharacterClassification, testSurrogatePairs) +{ + { + // No case mapping + OUString sTest(u"\U0001F600"_ustr); + OUString sLowerCase = m_xCC->toLower(sTest, 0, sTest.getLength(), {}); + CPPUNIT_ASSERT_EQUAL_MESSAGE("Should be lower", u"\U0001F600"_ustr, sLowerCase); + OUString sUpperCase = m_xCC->toUpper(sLowerCase, 0, sLowerCase.getLength(), {}); + CPPUNIT_ASSERT_EQUAL_MESSAGE("Should be upper", sTest, sUpperCase); + } + + { + // Case mapping + OUString sTest(u"\U00010400"_ustr); + OUString sLowerCase = m_xCC->toLower(sTest, 0, sTest.getLength(), {}); + CPPUNIT_ASSERT_EQUAL_MESSAGE("Should be lower", u"\U00010428"_ustr, sLowerCase); + OUString sUpperCase = m_xCC->toUpper(sLowerCase, 0, sLowerCase.getLength(), {}); + CPPUNIT_ASSERT_EQUAL_MESSAGE("Should be upper", sTest, sUpperCase); + } +} + +CPPUNIT_TEST_FIXTURE(TestCharacterClassification, testAdlam) +{ + OUString sUpper(u"𞤀𞤁𞤂𞤃𞤄𞤅𞤆𞤇𞤈𞤉𞤊𞤋𞤌𞤍𞤎𞤏𞤐𞤑𞤒𞤓𞤔𞤕𞤖𞤗𞤘𞤙𞤚𞤛𞤜𞤝𞤞𞤟𞤠𞤡"_ustr); + OUString sLower(u"𞤢𞤣𞤤𞤥𞤦𞤧𞤨𞤩𞤪𞤫𞤬𞤭𞤮𞤯𞤰𞤱𞤲𞤳𞤴𞤵𞤶𞤷𞤸𞤹𞤺𞤻𞤼𞤽𞤾𞤿𞥀𞥁𞥂𞥃"_ustr); + OUString sTitle = sLower; // Adlam doesn’t have title case? + { + // From upper case + OUString sLowerRes = m_xCC->toLower(sUpper, 0, sUpper.getLength(), {}); + CPPUNIT_ASSERT_EQUAL_MESSAGE("Should be lower", sLower, sLowerRes); + OUString sUpperRes = m_xCC->toUpper(sLowerRes, 0, sLower.getLength(), {}); + CPPUNIT_ASSERT_EQUAL_MESSAGE("Should be upper", sUpper, sUpperRes); + } + + { + // From lower case + OUString sTitleRes = m_xCC->toTitle(sLower, 0, sLower.getLength(), {}); + CPPUNIT_ASSERT_EQUAL_MESSAGE("Should be title", sTitle, sTitleRes); + OUString sUpperRes = m_xCC->toUpper(sLower, 0, sLower.getLength(), {}); + CPPUNIT_ASSERT_EQUAL_MESSAGE("Should be upper", sUpper, sUpperRes); + OUString sLowerRes = m_xCC->toLower(sUpperRes, 0, sUpperRes.getLength(), {}); + CPPUNIT_ASSERT_EQUAL_MESSAGE("Should be lower", sLower, sLowerRes); + } + + { + // From title case + OUString sTitleRes = m_xCC->toTitle(sTitle, 0, sTitle.getLength(), {}); + CPPUNIT_ASSERT_EQUAL_MESSAGE("Should be title", sTitle, sTitleRes); + OUString sUpperRes = m_xCC->toUpper(sTitle, 0, sTitle.getLength(), {}); + CPPUNIT_ASSERT_EQUAL_MESSAGE("Should be upper", sUpper, sUpperRes); + OUString sLowerRes = m_xCC->toLower(sTitle, 0, sTitle.getLength(), {}); + CPPUNIT_ASSERT_EQUAL_MESSAGE("Should be lower", sLower, sLowerRes); + } +} + +void TestCharacterClassification::setUp() +{ + BootstrapFixtureBase::setUp(); + m_xCC.set(m_xSFactory->createInstance("com.sun.star.i18n.CharacterClassification"), uno::UNO_QUERY_THROW); +} + +void TestCharacterClassification::tearDown() +{ + BootstrapFixtureBase::tearDown(); + m_xCC.clear(); +} + +CPPUNIT_PLUGIN_IMPLEMENT(); + +/* vim:set shiftwidth=4 softtabstop=4 expandtab: */ -- cgit v1.2.3