gecko-dev/intl/components/gtest/TestNumberParser.cpp
Dan Minor 8e4b11994a Bug 1734932 - Add intl::NumberParser; r=platform-i18n-reviewers,gregtatum
Awkwardly, this relies upon a different ICU4C NumberFormat API than
the existing intl::NumberFormat implementation, so it seems best to
have this live in a separate class.

Differential Revision: https://phabricator.services.mozilla.com/D133124
2021-12-09 15:26:20 +00:00

34 lines
1.2 KiB
C++

/* 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 "gtest/gtest.h"
#include "mozilla/intl/NumberParser.h"
namespace mozilla::intl {
TEST(IntlNumberParser, Basic)
{
// Try with an English locale
UniquePtr<NumberParser> np = NumberParser::TryCreate("en-US", true).unwrap();
auto result = np->ParseDouble(MakeStringSpan(u"1,234.56"));
ASSERT_TRUE(result.isOk());
ASSERT_EQ(result.unwrap().first, 1234.56);
ASSERT_EQ(result.unwrap().second, 8);
// Disable grouping, parsing will stop at the first comma
np = NumberParser::TryCreate("en-US", false).unwrap();
result = np->ParseDouble(MakeStringSpan(u"1,234.56"));
ASSERT_TRUE(result.isOk());
ASSERT_EQ(result.unwrap().first, 1);
ASSERT_EQ(result.unwrap().second, 1);
// Try with a Spanish locale
np = NumberParser::TryCreate("es-CR", true).unwrap();
result = np->ParseDouble(MakeStringSpan(u"1234,56"));
ASSERT_TRUE(result.isOk());
ASSERT_EQ(result.unwrap().first, 1234.56);
ASSERT_EQ(result.unwrap().second, 7);
}
} // namespace mozilla::intl