blob: a68ecd496254694daf66bf906ed8e4791d8d2596 [file] [log] [blame]
// Copyright (c) 2011 The Chromium Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#include <limits>
#include "base/i18n/number_formatting.h"
#include "base/i18n/rtl.h"
#include "base/macros.h"
#include "base/strings/utf_string_conversions.h"
#include "base/test/icu_test_util.h"
#include "build/build_config.h"
#include "starboard/types.h"
#include "testing/gtest/include/gtest/gtest.h"
#include "third_party/icu/source/i18n/unicode/usearch.h"
namespace base {
namespace {
TEST(NumberFormattingTest, FormatNumber) {
static const struct {
int64_t number;
const char* expected_english;
const char* expected_german;
} cases[] = {
{0, "0", "0"},
{1024, "1,024", "1.024"},
{std::numeric_limits<int64_t>::max(),
"9,223,372,036,854,775,807", "9.223.372.036.854.775.807"},
{std::numeric_limits<int64_t>::min(),
"-9,223,372,036,854,775,808", "-9.223.372.036.854.775.808"},
{-42, "-42", "-42"},
};
test::ScopedRestoreICUDefaultLocale restore_locale;
for (size_t i = 0; i < arraysize(cases); ++i) {
i18n::SetICUDefaultLocale("en");
testing::ResetFormatters();
EXPECT_EQ(cases[i].expected_english,
UTF16ToUTF8(FormatNumber(cases[i].number)));
i18n::SetICUDefaultLocale("de");
testing::ResetFormatters();
EXPECT_EQ(cases[i].expected_german,
UTF16ToUTF8(FormatNumber(cases[i].number)));
}
}
TEST(NumberFormattingTest, FormatDouble) {
static const struct {
double number;
int frac_digits;
const char* expected_english;
const char* expected_german;
}
cases[] = {
{0.0, 0, "0", "0"},
#if !defined(OS_ANDROID)
// Bionic can't printf negative zero correctly.
{-0.0, 4, "-0.0000", "-0,0000"},
#endif
{1024.2, 0, "1,024", "1.024"},
{-1024.223, 2, "-1,024.22", "-1.024,22"},
{std::numeric_limits<double>::max(), 6,
#if defined(STARBOARD)
// Cobalt still uses an old version of ICU which has less default
// significant numbers.
"179,769,313,486,232,000,000,000,000,000,000,000,000,000,000,000,000,"
"000,000,000,000,000,000,000,000,000,000,000,000,000,000,000,000,000,"
"000,000,000,000,000,000,000,000,000,000,000,000,000,000,000,000,000,"
"000,000,000,000,000,000,000,000,000,000,000,000,000,000,000,000,000,"
"000,000,000,000,000,000,000,000,000,000,000,000,000,000,000,000,000,"
"000,000,000,000,000,000,000,000,000,000,000,000,000,000,000,000,000,"
"000.000000",
"179.769.313.486.232.000.000.000.000.000.000.000.000.000.000.000.000."
"000.000.000.000.000.000.000.000.000.000.000.000.000.000.000.000.000."
"000.000.000.000.000.000.000.000.000.000.000.000.000.000.000.000.000."
"000.000.000.000.000.000.000.000.000.000.000.000.000.000.000.000.000."
"000.000.000.000.000.000.000.000.000.000.000.000.000.000.000.000.000."
"000.000.000.000.000.000.000.000.000.000.000.000.000.000.000.000.000."
"000,000000"},
#else
"179,769,313,486,231,570,000,000,000,000,000,000,000,000,000,000,000,"
"000,000,000,000,000,000,000,000,000,000,000,000,000,000,000,000,000,"
"000,000,000,000,000,000,000,000,000,000,000,000,000,000,000,000,000,"
"000,000,000,000,000,000,000,000,000,000,000,000,000,000,000,000,000,"
"000,000,000,000,000,000,000,000,000,000,000,000,000,000,000,000,000,"
"000,000,000,000,000,000,000,000,000,000,000,000,000,000,000,000,000,"
"000.000000",
"179.769.313.486.231.570.000.000.000.000.000.000.000.000.000.000.000."
"000.000.000.000.000.000.000.000.000.000.000.000.000.000.000.000.000."
"000.000.000.000.000.000.000.000.000.000.000.000.000.000.000.000.000."
"000.000.000.000.000.000.000.000.000.000.000.000.000.000.000.000.000."
"000.000.000.000.000.000.000.000.000.000.000.000.000.000.000.000.000."
"000.000.000.000.000.000.000.000.000.000.000.000.000.000.000.000.000."
"000,000000"},
#endif
{std::numeric_limits<double>::min(), 2, "0.00", "0,00"},
{-42.7, 3, "-42.700", "-42,700"},
};
test::ScopedRestoreICUDefaultLocale restore_locale;
for (size_t i = 0; i < arraysize(cases); ++i) {
i18n::SetICUDefaultLocale("en");
testing::ResetFormatters();
EXPECT_EQ(cases[i].expected_english,
UTF16ToUTF8(FormatDouble(cases[i].number, cases[i].frac_digits)));
i18n::SetICUDefaultLocale("de");
testing::ResetFormatters();
EXPECT_EQ(cases[i].expected_german,
UTF16ToUTF8(FormatDouble(cases[i].number, cases[i].frac_digits)));
}
}
#if !defined(STARBOARD)
TEST(NumberFormattingTest, FormatPercent) {
static const struct {
int64_t number;
const char* expected_english;
const char* expected_german; // Note: Space before % isn't \x20.
// Note: Eastern Arabic-Indic digits (U+06Fx) for Persian and
// Arabic-Indic digits (U+066x) for Arabic in Egypt(ar-EG). In Arabic (ar),
// uses European digits (Google-patch).
// See https://unicode.org/cldr/trac/ticket/9040 for details.
// See also https://unicode.org/cldr/trac/ticket/10176 .
// For now, take what CLDR 32 has (percent sign to the right of
// a number in Persian).
const char* expected_persian;
const char* expected_arabic;
const char* expected_arabic_egypt;
} cases[] = {
{0, "0%", u8"0\u00a0%", u8"\u06f0\u066a", u8"0\u200e%\u200e",
u8"\u0660\u066a\u061c"},
{42, "42%", "42\u00a0%", u8"\u06f4\u06f2\u066a", u8"42\u200e%\u200e",
"\u0664\u0662\u066a\u061c"},
{1024, "1,024%", "1.024\u00a0%", u8"\u06f1\u066c\u06f0\u06f2\u06f4\u066a",
"1,024\u200e%\u200e", "\u0661\u066c\u0660\u0662\u0664\u066a\u061c"},
};
test::ScopedRestoreICUDefaultLocale restore_locale;
for (size_t i = 0; i < arraysize(cases); ++i) {
i18n::SetICUDefaultLocale("en");
EXPECT_EQ(ASCIIToUTF16(cases[i].expected_english),
FormatPercent(cases[i].number));
i18n::SetICUDefaultLocale("de");
EXPECT_EQ(UTF8ToUTF16(cases[i].expected_german),
FormatPercent(cases[i].number));
i18n::SetICUDefaultLocale("fa");
EXPECT_EQ(UTF8ToUTF16(cases[i].expected_persian),
FormatPercent(cases[i].number));
i18n::SetICUDefaultLocale("ar");
EXPECT_EQ(UTF8ToUTF16(cases[i].expected_arabic),
FormatPercent(cases[i].number));
i18n::SetICUDefaultLocale("ar-EG");
EXPECT_EQ(UTF8ToUTF16(cases[i].expected_arabic_egypt),
FormatPercent(cases[i].number));
}
}
#endif // !defined(STARBOARD)
} // namespace
} // namespace base