9c13f1ad63
add Korean Numbering test cases 1. koreanCounting 2. koreanLegal 3. koreanDigital 4. koreanDigital2 fix Korean Hanja number codepoint for Zero(0) Following MS Office's numFmt Strng example https://docs.microsoft.com/en-us/openspecs/office_standards/ms-docx/a1bb5809-e361-4e49-8e16-7f1a67da4121 Korean Hanja notation for Hanja is `零 U+96F6` on MS Word 2019 and that document. So, fix the Korean Hanja number code pointfor Zero(0) `零 U+96F6` Change-Id: I1a5b95640a93e7fbc3a0e724b154587877b198a0 Reviewed-on: https://gerrit.libreoffice.org/c/core/+/120676 Tested-by: Jenkins Reviewed-by: Eike Rathke <erack@redhat.com>
470 lines
20 KiB
C++
470 lines
20 KiB
C++
/* -*- 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 <test/bootstrapfixture.hxx>
|
|
|
|
#include <com/sun/star/style/NumberingType.hpp>
|
|
#include <com/sun/star/text/DefaultNumberingProvider.hpp>
|
|
#include <com/sun/star/text/XNumberingFormatter.hpp>
|
|
#include <com/sun/star/text/XNumberingTypeInfo.hpp>
|
|
|
|
#include <comphelper/propertyvalue.hxx>
|
|
|
|
#include <unordered_map>
|
|
|
|
using namespace ::com::sun::star;
|
|
|
|
/// i18npool defaultnumberingprovider tests.
|
|
class I18npoolDefaultnumberingproviderTest : public test::BootstrapFixture
|
|
{
|
|
};
|
|
|
|
CPPUNIT_TEST_FIXTURE(I18npoolDefaultnumberingproviderTest, testNumberingIdentifiers)
|
|
{
|
|
// All numbering identifiers must be unique.
|
|
std::unordered_map<OUString, sal_Int16> aMap;
|
|
std::vector<OString> aFail;
|
|
|
|
uno::Reference<text::XNumberingTypeInfo> xFormatter(
|
|
text::DefaultNumberingProvider::create(mxComponentContext), uno::UNO_QUERY);
|
|
|
|
// Do not use getSupportedNumberingTypes() because it depends on
|
|
// configuration whether CTL and CJK numberings are included or not.
|
|
// Also do not test for known values of
|
|
// offapi/com/sun/star/style/NumberingType.idl and miss newly added values.
|
|
// Instead, enumerate until an empty ID is returned but also check there
|
|
// are at least the known NumberingType values covered, just in case the
|
|
// table wasn't maintained. So this may have to be adapted from time to
|
|
// time.
|
|
constexpr sal_Int16 kLastKnown = css::style::NumberingType::NUMBER_LEGAL_KO;
|
|
for (sal_Int16 i = 0; i < SAL_MAX_INT16; ++i)
|
|
{
|
|
OUString aID(xFormatter->getNumberingIdentifier(i));
|
|
if (aID.isEmpty() && i > kLastKnown)
|
|
break; // for
|
|
|
|
switch (i)
|
|
{
|
|
case css::style::NumberingType::TRANSLITERATION:
|
|
// TODO: why does this have no identifier?
|
|
case css::style::NumberingType::NUMBER_UPPER_KO:
|
|
// FIXME: duplicate of NUMBER_UPPER_ZH_TW
|
|
case css::style::NumberingType::NUMBER_INDIC_DEVANAGARI:
|
|
// FIXME: duplicate of NUMBER_EAST_ARABIC_INDIC
|
|
break;
|
|
default:
|
|
if (aID.isEmpty() || !aMap.insert(std::pair(aID, i)).second)
|
|
{
|
|
aFail.emplace_back(
|
|
"Numbering: " + OString::number(i) + " \"" + aID.toUtf8() + "\""
|
|
+ (aID.isEmpty() ? ""
|
|
: OString(" duplicate of " + OString::number(aMap[aID])))
|
|
+ "\n");
|
|
}
|
|
}
|
|
}
|
|
|
|
if (!aFail.empty())
|
|
{
|
|
OString aMsg("Not unique numbering identifiers:\n");
|
|
for (auto const& r : aFail)
|
|
aMsg += r;
|
|
CPPUNIT_ASSERT_MESSAGE(aMsg.getStr(), false);
|
|
}
|
|
}
|
|
|
|
CPPUNIT_TEST_FIXTURE(I18npoolDefaultnumberingproviderTest, testArabicZero)
|
|
{
|
|
// 1 -> "01"
|
|
uno::Reference<text::XNumberingFormatter> xFormatter(
|
|
text::DefaultNumberingProvider::create(mxComponentContext), uno::UNO_QUERY);
|
|
uno::Sequence<beans::PropertyValue> aProperties = {
|
|
comphelper::makePropertyValue("NumberingType",
|
|
static_cast<sal_uInt16>(style::NumberingType::ARABIC_ZERO)),
|
|
comphelper::makePropertyValue("Value", static_cast<sal_Int32>(1)),
|
|
};
|
|
lang::Locale aLocale;
|
|
OUString aActual = xFormatter->makeNumberingString(aProperties, aLocale);
|
|
// Without the accompanying fix in place, this test would have failed with a
|
|
// lang.IllegalArgumentException, support for ARABIC_ZERO was missing.
|
|
CPPUNIT_ASSERT_EQUAL(OUString("01"), aActual);
|
|
|
|
// 10 -> "10"
|
|
aProperties = {
|
|
comphelper::makePropertyValue("NumberingType",
|
|
static_cast<sal_uInt16>(style::NumberingType::ARABIC_ZERO)),
|
|
comphelper::makePropertyValue("Value", static_cast<sal_Int32>(10)),
|
|
};
|
|
aActual = xFormatter->makeNumberingString(aProperties, aLocale);
|
|
CPPUNIT_ASSERT_EQUAL(OUString("10"), aActual);
|
|
}
|
|
|
|
CPPUNIT_TEST_FIXTURE(I18npoolDefaultnumberingproviderTest, testArabicZero3)
|
|
{
|
|
// 10 -> "010"
|
|
uno::Reference<text::XNumberingFormatter> xFormatter(
|
|
text::DefaultNumberingProvider::create(mxComponentContext), uno::UNO_QUERY);
|
|
uno::Sequence<beans::PropertyValue> aProperties = {
|
|
comphelper::makePropertyValue("NumberingType",
|
|
static_cast<sal_uInt16>(style::NumberingType::ARABIC_ZERO3)),
|
|
comphelper::makePropertyValue("Value", static_cast<sal_Int32>(10)),
|
|
};
|
|
lang::Locale aLocale;
|
|
OUString aActual = xFormatter->makeNumberingString(aProperties, aLocale);
|
|
// Without the accompanying fix in place, this test would have failed with a
|
|
// lang.IllegalArgumentException, support for ARABIC_ZERO3 was missing.
|
|
CPPUNIT_ASSERT_EQUAL(OUString("010"), aActual);
|
|
|
|
// 100 -> "100"
|
|
aProperties = {
|
|
comphelper::makePropertyValue("NumberingType",
|
|
static_cast<sal_uInt16>(style::NumberingType::ARABIC_ZERO3)),
|
|
comphelper::makePropertyValue("Value", static_cast<sal_Int32>(100)),
|
|
};
|
|
aActual = xFormatter->makeNumberingString(aProperties, aLocale);
|
|
CPPUNIT_ASSERT_EQUAL(OUString("100"), aActual);
|
|
}
|
|
|
|
CPPUNIT_TEST_FIXTURE(I18npoolDefaultnumberingproviderTest, testArabicZero4)
|
|
{
|
|
// 100 -> "0100"
|
|
uno::Reference<text::XNumberingFormatter> xFormatter(
|
|
text::DefaultNumberingProvider::create(mxComponentContext), uno::UNO_QUERY);
|
|
uno::Sequence<beans::PropertyValue> aProperties = {
|
|
comphelper::makePropertyValue("NumberingType",
|
|
static_cast<sal_uInt16>(style::NumberingType::ARABIC_ZERO4)),
|
|
comphelper::makePropertyValue("Value", static_cast<sal_Int32>(100)),
|
|
};
|
|
lang::Locale aLocale;
|
|
OUString aActual = xFormatter->makeNumberingString(aProperties, aLocale);
|
|
// Without the accompanying fix in place, this test would have failed with a
|
|
// lang.IllegalArgumentException, support for ARABIC_ZERO4 was missing.
|
|
CPPUNIT_ASSERT_EQUAL(OUString("0100"), aActual);
|
|
|
|
// 1000 -> "1000"
|
|
aProperties = {
|
|
comphelper::makePropertyValue("NumberingType",
|
|
static_cast<sal_uInt16>(style::NumberingType::ARABIC_ZERO4)),
|
|
comphelper::makePropertyValue("Value", static_cast<sal_Int32>(1000)),
|
|
};
|
|
aActual = xFormatter->makeNumberingString(aProperties, aLocale);
|
|
CPPUNIT_ASSERT_EQUAL(OUString("1000"), aActual);
|
|
}
|
|
|
|
CPPUNIT_TEST_FIXTURE(I18npoolDefaultnumberingproviderTest, testArabicZero5)
|
|
{
|
|
// 1000 -> "01000"
|
|
uno::Reference<text::XNumberingFormatter> xFormatter(
|
|
text::DefaultNumberingProvider::create(mxComponentContext), uno::UNO_QUERY);
|
|
uno::Sequence<beans::PropertyValue> aProperties = {
|
|
comphelper::makePropertyValue("NumberingType",
|
|
static_cast<sal_uInt16>(style::NumberingType::ARABIC_ZERO5)),
|
|
comphelper::makePropertyValue("Value", static_cast<sal_Int32>(1000)),
|
|
};
|
|
lang::Locale aLocale;
|
|
OUString aActual = xFormatter->makeNumberingString(aProperties, aLocale);
|
|
// Without the accompanying fix in place, this test would have failed with a
|
|
// lang.IllegalArgumentException, support for ARABIC_ZERO5 was missing.
|
|
CPPUNIT_ASSERT_EQUAL(OUString("01000"), aActual);
|
|
|
|
// 10000 -> "10000"
|
|
aProperties = {
|
|
comphelper::makePropertyValue("NumberingType",
|
|
static_cast<sal_uInt16>(style::NumberingType::ARABIC_ZERO5)),
|
|
comphelper::makePropertyValue("Value", static_cast<sal_Int32>(10000)),
|
|
};
|
|
aActual = xFormatter->makeNumberingString(aProperties, aLocale);
|
|
CPPUNIT_ASSERT_EQUAL(OUString("10000"), aActual);
|
|
}
|
|
|
|
CPPUNIT_TEST_FIXTURE(I18npoolDefaultnumberingproviderTest, testKoreanCounting)
|
|
{
|
|
// 1 -> "일"
|
|
uno::Reference<text::XNumberingFormatter> xFormatter(
|
|
text::DefaultNumberingProvider::create(mxComponentContext), uno::UNO_QUERY);
|
|
uno::Sequence<beans::PropertyValue> aProperties = {
|
|
comphelper::makePropertyValue(
|
|
"NumberingType", static_cast<sal_uInt16>(style::NumberingType::NUMBER_HANGUL_KO)),
|
|
comphelper::makePropertyValue("Value", static_cast<sal_Int32>(1)),
|
|
};
|
|
lang::Locale aLocale;
|
|
OUString aActual = xFormatter->makeNumberingString(aProperties, aLocale);
|
|
// Without the accompanying fix in place, this test would have failed with a
|
|
// lang.IllegalArgumentException, support for NUMBER_HANGUL_KO was missing.
|
|
CPPUNIT_ASSERT_EQUAL(OUString(u"\uc77c"), aActual);
|
|
|
|
// 10 -> "십"
|
|
aProperties = {
|
|
comphelper::makePropertyValue(
|
|
"NumberingType", static_cast<sal_uInt16>(style::NumberingType::NUMBER_HANGUL_KO)),
|
|
comphelper::makePropertyValue("Value", static_cast<sal_Int32>(10)),
|
|
};
|
|
aActual = xFormatter->makeNumberingString(aProperties, aLocale);
|
|
CPPUNIT_ASSERT_EQUAL(OUString(u"\uc2ed"), aActual);
|
|
|
|
// 100 -> "백"
|
|
aProperties = {
|
|
comphelper::makePropertyValue(
|
|
"NumberingType", static_cast<sal_uInt16>(style::NumberingType::NUMBER_HANGUL_KO)),
|
|
comphelper::makePropertyValue("Value", static_cast<sal_Int32>(100)),
|
|
};
|
|
aActual = xFormatter->makeNumberingString(aProperties, aLocale);
|
|
CPPUNIT_ASSERT_EQUAL(OUString(u"\ubc31"), aActual);
|
|
}
|
|
|
|
CPPUNIT_TEST_FIXTURE(I18npoolDefaultnumberingproviderTest, testKoreanLegal)
|
|
{
|
|
// 1 -> "하나"
|
|
uno::Reference<text::XNumberingFormatter> xFormatter(
|
|
text::DefaultNumberingProvider::create(mxComponentContext), uno::UNO_QUERY);
|
|
uno::Sequence<beans::PropertyValue> aProperties = {
|
|
comphelper::makePropertyValue(
|
|
"NumberingType", static_cast<sal_uInt16>(style::NumberingType::NUMBER_LEGAL_KO)),
|
|
comphelper::makePropertyValue("Value", static_cast<sal_Int32>(1)),
|
|
};
|
|
lang::Locale aLocale;
|
|
OUString aActual = xFormatter->makeNumberingString(aProperties, aLocale);
|
|
// Without the accompanying fix in place, this test would have failed with a
|
|
// lang.IllegalArgumentException, support for NUMBER_LEGAL_KO was missing.
|
|
CPPUNIT_ASSERT_EQUAL(OUString(u"\ud558\ub098"), aActual);
|
|
|
|
// 2 -> "둘"
|
|
aProperties = {
|
|
comphelper::makePropertyValue(
|
|
"NumberingType", static_cast<sal_uInt16>(style::NumberingType::NUMBER_LEGAL_KO)),
|
|
comphelper::makePropertyValue("Value", static_cast<sal_Int32>(2)),
|
|
};
|
|
aActual = xFormatter->makeNumberingString(aProperties, aLocale);
|
|
CPPUNIT_ASSERT_EQUAL(OUString(u"\ub458"), aActual);
|
|
|
|
// 3 -> "셋"
|
|
aProperties = {
|
|
comphelper::makePropertyValue(
|
|
"NumberingType", static_cast<sal_uInt16>(style::NumberingType::NUMBER_LEGAL_KO)),
|
|
comphelper::makePropertyValue("Value", static_cast<sal_Int32>(3)),
|
|
};
|
|
aActual = xFormatter->makeNumberingString(aProperties, aLocale);
|
|
CPPUNIT_ASSERT_EQUAL(OUString(u"\uc14b"), aActual);
|
|
|
|
// 4 -> "넷"
|
|
aProperties = {
|
|
comphelper::makePropertyValue(
|
|
"NumberingType", static_cast<sal_uInt16>(style::NumberingType::NUMBER_LEGAL_KO)),
|
|
comphelper::makePropertyValue("Value", static_cast<sal_Int32>(4)),
|
|
};
|
|
aActual = xFormatter->makeNumberingString(aProperties, aLocale);
|
|
CPPUNIT_ASSERT_EQUAL(OUString(u"\ub137"), aActual);
|
|
|
|
// 5 -> "다섯"
|
|
aProperties = {
|
|
comphelper::makePropertyValue(
|
|
"NumberingType", static_cast<sal_uInt16>(style::NumberingType::NUMBER_LEGAL_KO)),
|
|
comphelper::makePropertyValue("Value", static_cast<sal_Int32>(5)),
|
|
};
|
|
aActual = xFormatter->makeNumberingString(aProperties, aLocale);
|
|
CPPUNIT_ASSERT_EQUAL(OUString(u"\ub2e4\uc12f"), aActual);
|
|
// 6 -> "여섯
|
|
aProperties = {
|
|
comphelper::makePropertyValue(
|
|
"NumberingType", static_cast<sal_uInt16>(style::NumberingType::NUMBER_LEGAL_KO)),
|
|
comphelper::makePropertyValue("Value", static_cast<sal_Int32>(6)),
|
|
};
|
|
aActual = xFormatter->makeNumberingString(aProperties, aLocale);
|
|
CPPUNIT_ASSERT_EQUAL(OUString(u"\uc5ec\uc12f"), aActual);
|
|
// 7 -> "일곱"
|
|
aProperties = {
|
|
comphelper::makePropertyValue(
|
|
"NumberingType", static_cast<sal_uInt16>(style::NumberingType::NUMBER_LEGAL_KO)),
|
|
comphelper::makePropertyValue("Value", static_cast<sal_Int32>(7)),
|
|
};
|
|
aActual = xFormatter->makeNumberingString(aProperties, aLocale);
|
|
CPPUNIT_ASSERT_EQUAL(OUString(u"\uc77c\uacf1"), aActual);
|
|
|
|
// 8 -> "여덟"
|
|
aProperties = {
|
|
comphelper::makePropertyValue(
|
|
"NumberingType", static_cast<sal_uInt16>(style::NumberingType::NUMBER_LEGAL_KO)),
|
|
comphelper::makePropertyValue("Value", static_cast<sal_Int32>(8)),
|
|
};
|
|
aActual = xFormatter->makeNumberingString(aProperties, aLocale);
|
|
CPPUNIT_ASSERT_EQUAL(OUString(u"\uc5ec\ub35f"), aActual);
|
|
|
|
// 9 -> "아홉"
|
|
aProperties = {
|
|
comphelper::makePropertyValue(
|
|
"NumberingType", static_cast<sal_uInt16>(style::NumberingType::NUMBER_LEGAL_KO)),
|
|
comphelper::makePropertyValue("Value", static_cast<sal_Int32>(9)),
|
|
};
|
|
aActual = xFormatter->makeNumberingString(aProperties, aLocale);
|
|
CPPUNIT_ASSERT_EQUAL(OUString(u"\uc544\ud649"), aActual);
|
|
|
|
// 10 -> "열"
|
|
aProperties = {
|
|
comphelper::makePropertyValue(
|
|
"NumberingType", static_cast<sal_uInt16>(style::NumberingType::NUMBER_LEGAL_KO)),
|
|
comphelper::makePropertyValue("Value", static_cast<sal_Int32>(10)),
|
|
};
|
|
aActual = xFormatter->makeNumberingString(aProperties, aLocale);
|
|
CPPUNIT_ASSERT_EQUAL(OUString(u"\uc5f4"), aActual);
|
|
|
|
// 21 -> "스물하나"
|
|
aProperties = {
|
|
comphelper::makePropertyValue(
|
|
"NumberingType", static_cast<sal_uInt16>(style::NumberingType::NUMBER_LEGAL_KO)),
|
|
comphelper::makePropertyValue("Value", static_cast<sal_Int32>(21)),
|
|
};
|
|
aActual = xFormatter->makeNumberingString(aProperties, aLocale);
|
|
CPPUNIT_ASSERT_EQUAL(OUString(u"\uc2a4\ubb3c\ud558\ub098"), aActual);
|
|
|
|
// 32 -> "서른둘"
|
|
aProperties = {
|
|
comphelper::makePropertyValue(
|
|
"NumberingType", static_cast<sal_uInt16>(style::NumberingType::NUMBER_LEGAL_KO)),
|
|
comphelper::makePropertyValue("Value", static_cast<sal_Int32>(32)),
|
|
};
|
|
aActual = xFormatter->makeNumberingString(aProperties, aLocale);
|
|
CPPUNIT_ASSERT_EQUAL(OUString(u"\uc11c\ub978\ub458"), aActual);
|
|
|
|
// 43 -> "마흔셋"
|
|
aProperties = {
|
|
comphelper::makePropertyValue(
|
|
"NumberingType", static_cast<sal_uInt16>(style::NumberingType::NUMBER_LEGAL_KO)),
|
|
comphelper::makePropertyValue("Value", static_cast<sal_Int32>(43)),
|
|
};
|
|
aActual = xFormatter->makeNumberingString(aProperties, aLocale);
|
|
CPPUNIT_ASSERT_EQUAL(OUString(u"\ub9c8\ud754\uc14b"), aActual);
|
|
|
|
// 54 -> "쉰넷"
|
|
aProperties = {
|
|
comphelper::makePropertyValue(
|
|
"NumberingType", static_cast<sal_uInt16>(style::NumberingType::NUMBER_LEGAL_KO)),
|
|
comphelper::makePropertyValue("Value", static_cast<sal_Int32>(54)),
|
|
};
|
|
aActual = xFormatter->makeNumberingString(aProperties, aLocale);
|
|
CPPUNIT_ASSERT_EQUAL(OUString(u"\uc270\ub137"), aActual);
|
|
|
|
// 65 -> "예순다섯"
|
|
aProperties = {
|
|
comphelper::makePropertyValue(
|
|
"NumberingType", static_cast<sal_uInt16>(style::NumberingType::NUMBER_LEGAL_KO)),
|
|
comphelper::makePropertyValue("Value", static_cast<sal_Int32>(65)),
|
|
};
|
|
aActual = xFormatter->makeNumberingString(aProperties, aLocale);
|
|
CPPUNIT_ASSERT_EQUAL(OUString(u"\uc608\uc21c\ub2e4\uc12f"), aActual);
|
|
|
|
// 76 -> "일흔여섯"
|
|
aProperties = {
|
|
comphelper::makePropertyValue(
|
|
"NumberingType", static_cast<sal_uInt16>(style::NumberingType::NUMBER_LEGAL_KO)),
|
|
comphelper::makePropertyValue("Value", static_cast<sal_Int32>(76)),
|
|
};
|
|
aActual = xFormatter->makeNumberingString(aProperties, aLocale);
|
|
CPPUNIT_ASSERT_EQUAL(OUString(u"\uc77c\ud754\uc5ec\uc12f"), aActual);
|
|
|
|
// 87 -> "여든일곱"
|
|
aProperties = {
|
|
comphelper::makePropertyValue(
|
|
"NumberingType", static_cast<sal_uInt16>(style::NumberingType::NUMBER_LEGAL_KO)),
|
|
comphelper::makePropertyValue("Value", static_cast<sal_Int32>(87)),
|
|
};
|
|
aActual = xFormatter->makeNumberingString(aProperties, aLocale);
|
|
CPPUNIT_ASSERT_EQUAL(OUString(u"\uc5ec\ub4e0\uc77c\uacf1"), aActual);
|
|
|
|
// 98 -> "아흔여덟"
|
|
aProperties = {
|
|
comphelper::makePropertyValue(
|
|
"NumberingType", static_cast<sal_uInt16>(style::NumberingType::NUMBER_LEGAL_KO)),
|
|
comphelper::makePropertyValue("Value", static_cast<sal_Int32>(98)),
|
|
};
|
|
aActual = xFormatter->makeNumberingString(aProperties, aLocale);
|
|
CPPUNIT_ASSERT_EQUAL(OUString(u"\uc544\ud754\uc5ec\ub35f"), aActual);
|
|
|
|
// 99 -> "아흔아홉"
|
|
aProperties = {
|
|
comphelper::makePropertyValue(
|
|
"NumberingType", static_cast<sal_uInt16>(style::NumberingType::NUMBER_LEGAL_KO)),
|
|
comphelper::makePropertyValue("Value", static_cast<sal_Int32>(99)),
|
|
};
|
|
aActual = xFormatter->makeNumberingString(aProperties, aLocale);
|
|
CPPUNIT_ASSERT_EQUAL(OUString(u"\uc544\ud754\uc544\ud649"), aActual);
|
|
}
|
|
|
|
CPPUNIT_TEST_FIXTURE(I18npoolDefaultnumberingproviderTest, testKoreanDigital)
|
|
{
|
|
// 1 -> "일"
|
|
uno::Reference<text::XNumberingFormatter> xFormatter(
|
|
text::DefaultNumberingProvider::create(mxComponentContext), uno::UNO_QUERY);
|
|
uno::Sequence<beans::PropertyValue> aProperties = {
|
|
comphelper::makePropertyValue(
|
|
"NumberingType", static_cast<sal_uInt16>(style::NumberingType::NUMBER_DIGITAL_KO)),
|
|
comphelper::makePropertyValue("Value", static_cast<sal_Int32>(1)),
|
|
};
|
|
lang::Locale aLocale;
|
|
OUString aActual = xFormatter->makeNumberingString(aProperties, aLocale);
|
|
// Without the accompanying fix in place, this test would have failed with a
|
|
// lang.IllegalArgumentException, support for NUMBER_DIGITAL_KO was missing.
|
|
CPPUNIT_ASSERT_EQUAL(OUString(u"\uc77c"), aActual);
|
|
|
|
// 10 -> "일영"
|
|
aProperties = {
|
|
comphelper::makePropertyValue(
|
|
"NumberingType", static_cast<sal_uInt16>(style::NumberingType::NUMBER_DIGITAL_KO)),
|
|
comphelper::makePropertyValue("Value", static_cast<sal_Int32>(10)),
|
|
};
|
|
aActual = xFormatter->makeNumberingString(aProperties, aLocale);
|
|
CPPUNIT_ASSERT_EQUAL(OUString(u"\uc77c\uc601"), aActual);
|
|
|
|
// 100 -> "일영영"
|
|
aProperties = {
|
|
comphelper::makePropertyValue(
|
|
"NumberingType", static_cast<sal_uInt16>(style::NumberingType::NUMBER_DIGITAL_KO)),
|
|
comphelper::makePropertyValue("Value", static_cast<sal_Int32>(100)),
|
|
};
|
|
aActual = xFormatter->makeNumberingString(aProperties, aLocale);
|
|
CPPUNIT_ASSERT_EQUAL(OUString(u"\uc77c\uc601\uc601"), aActual);
|
|
}
|
|
|
|
CPPUNIT_TEST_FIXTURE(I18npoolDefaultnumberingproviderTest, testKoreanDigital2)
|
|
{
|
|
// 1 -> "一"
|
|
uno::Reference<text::XNumberingFormatter> xFormatter(
|
|
text::DefaultNumberingProvider::create(mxComponentContext), uno::UNO_QUERY);
|
|
uno::Sequence<beans::PropertyValue> aProperties = {
|
|
comphelper::makePropertyValue(
|
|
"NumberingType", static_cast<sal_uInt16>(style::NumberingType::NUMBER_DIGITAL2_KO)),
|
|
comphelper::makePropertyValue("Value", static_cast<sal_Int32>(1)),
|
|
};
|
|
lang::Locale aLocale;
|
|
OUString aActual = xFormatter->makeNumberingString(aProperties, aLocale);
|
|
// Without the accompanying fix in place, this test would have failed with a
|
|
// lang.IllegalArgumentException, support for NUMBER_DIGITAL2_KO was missing.
|
|
CPPUNIT_ASSERT_EQUAL(OUString(u"\u4e00"), aActual);
|
|
|
|
// 10 -> "一零"
|
|
aProperties = {
|
|
comphelper::makePropertyValue(
|
|
"NumberingType", static_cast<sal_uInt16>(style::NumberingType::NUMBER_DIGITAL2_KO)),
|
|
comphelper::makePropertyValue("Value", static_cast<sal_Int32>(10)),
|
|
};
|
|
aActual = xFormatter->makeNumberingString(aProperties, aLocale);
|
|
CPPUNIT_ASSERT_EQUAL(OUString(u"\u4e00\u96f6"), aActual);
|
|
|
|
// 100 -> "一零零"
|
|
aProperties = {
|
|
comphelper::makePropertyValue(
|
|
"NumberingType", static_cast<sal_uInt16>(style::NumberingType::NUMBER_DIGITAL2_KO)),
|
|
comphelper::makePropertyValue("Value", static_cast<sal_Int32>(100)),
|
|
};
|
|
aActual = xFormatter->makeNumberingString(aProperties, aLocale);
|
|
CPPUNIT_ASSERT_EQUAL(OUString(u"\u4e00\u96f6\u96f6"), aActual);
|
|
}
|
|
|
|
CPPUNIT_PLUGIN_IMPLEMENT();
|
|
|
|
/* vim:set shiftwidth=4 softtabstop=4 expandtab: */
|