diff options
author | ben@chromium.org <ben@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2010-03-20 06:37:01 +0000 |
---|---|---|
committer | ben@chromium.org <ben@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2010-03-20 06:37:01 +0000 |
commit | 7cf1b6ced3b14cce1d66ca0ddc713851f0d37536 (patch) | |
tree | 1c2fc9f4d52bf3046addf820d5eec03a2e150749 /app/l10n_util_unittest.cc | |
parent | f9f4841b14a9f309ce5ee613f0d4de6afad88767 (diff) | |
download | chromium_src-7cf1b6ced3b14cce1d66ca0ddc713851f0d37536.zip chromium_src-7cf1b6ced3b14cce1d66ca0ddc713851f0d37536.tar.gz chromium_src-7cf1b6ced3b14cce1d66ca0ddc713851f0d37536.tar.bz2 |
Move RTL related functions from app/l10n_util to base/i18n/rtl
TBR=darin
BUG=none
TEST=none
Review URL: http://codereview.chromium.org/1073005
git-svn-id: svn://svn.chromium.org/chrome/trunk/src@42182 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'app/l10n_util_unittest.cc')
-rw-r--r-- | app/l10n_util_unittest.cc | 242 |
1 files changed, 0 insertions, 242 deletions
diff --git a/app/l10n_util_unittest.cc b/app/l10n_util_unittest.cc index cd299d1..94dd8fd 100644 --- a/app/l10n_util_unittest.cc +++ b/app/l10n_util_unittest.cc @@ -39,10 +39,6 @@ class StringWrapper { DISALLOW_COPY_AND_ASSIGN(StringWrapper); }; -l10n_util::TextDirection GetTextDirection(const char* locale_name) { - return l10n_util::GetTextDirectionForLocale(locale_name); -} - } // namespace class L10nUtilTest : public PlatformTest { @@ -274,244 +270,6 @@ TEST_F(L10nUtilTest, SortStringsUsingFunction) { STLDeleteElements(&strings); } -TEST_F(L10nUtilTest, GetFirstStrongCharacterDirection) { - // Test pure LTR string. - std::wstring string(L"foo bar"); - EXPECT_EQ(l10n_util::LEFT_TO_RIGHT, - l10n_util::GetFirstStrongCharacterDirection(string)); - - // Test bidi string in which the first character with strong directionality - // is a character with type L. - string.assign(L"foo \x05d0 bar"); - EXPECT_EQ(l10n_util::LEFT_TO_RIGHT, - l10n_util::GetFirstStrongCharacterDirection(string)); - - // Test bidi string in which the first character with strong directionality - // is a character with type R. - string.assign(L"\x05d0 foo bar"); - EXPECT_EQ(l10n_util::RIGHT_TO_LEFT, - l10n_util::GetFirstStrongCharacterDirection(string)); - - // Test bidi string which starts with a character with weak directionality - // and in which the first character with strong directionality is a character - // with type L. - string.assign(L"!foo \x05d0 bar"); - EXPECT_EQ(l10n_util::LEFT_TO_RIGHT, - l10n_util::GetFirstStrongCharacterDirection(string)); - - // Test bidi string which starts with a character with weak directionality - // and in which the first character with strong directionality is a character - // with type R. - string.assign(L",\x05d0 foo bar"); - EXPECT_EQ(l10n_util::RIGHT_TO_LEFT, - l10n_util::GetFirstStrongCharacterDirection(string)); - - // Test bidi string in which the first character with strong directionality - // is a character with type LRE. - string.assign(L"\x202a \x05d0 foo bar"); - EXPECT_EQ(l10n_util::LEFT_TO_RIGHT, - l10n_util::GetFirstStrongCharacterDirection(string)); - - // Test bidi string in which the first character with strong directionality - // is a character with type LRO. - string.assign(L"\x202d \x05d0 foo bar"); - EXPECT_EQ(l10n_util::LEFT_TO_RIGHT, - l10n_util::GetFirstStrongCharacterDirection(string)); - - // Test bidi string in which the first character with strong directionality - // is a character with type RLE. - string.assign(L"\x202b foo \x05d0 bar"); - EXPECT_EQ(l10n_util::RIGHT_TO_LEFT, - l10n_util::GetFirstStrongCharacterDirection(string)); - - // Test bidi string in which the first character with strong directionality - // is a character with type RLO. - string.assign(L"\x202e foo \x05d0 bar"); - EXPECT_EQ(l10n_util::RIGHT_TO_LEFT, - l10n_util::GetFirstStrongCharacterDirection(string)); - - // Test bidi string in which the first character with strong directionality - // is a character with type AL. - string.assign(L"\x0622 foo \x05d0 bar"); - EXPECT_EQ(l10n_util::RIGHT_TO_LEFT, - l10n_util::GetFirstStrongCharacterDirection(string)); - - // Test a string without strong directionality characters. - string.assign(L",!.{}"); - EXPECT_EQ(l10n_util::LEFT_TO_RIGHT, - l10n_util::GetFirstStrongCharacterDirection(string)); - - // Test empty string. - string.assign(L""); - EXPECT_EQ(l10n_util::LEFT_TO_RIGHT, - l10n_util::GetFirstStrongCharacterDirection(string)); - - // Test characters in non-BMP (e.g. Phoenician letters. Please refer to - // http://demo.icu-project.org/icu-bin/ubrowse?scr=151&b=10910 for more - // information). -#if defined(WCHAR_T_IS_UTF32) - string.assign(L" ! \x10910" L"abc 123"); -#elif defined(WCHAR_T_IS_UTF16) - string.assign(L" ! \xd802\xdd10" L"abc 123"); -#else -#error wchar_t should be either UTF-16 or UTF-32 -#endif - EXPECT_EQ(l10n_util::RIGHT_TO_LEFT, - l10n_util::GetFirstStrongCharacterDirection(string)); - -#if defined(WCHAR_T_IS_UTF32) - string.assign(L" ! \x10401" L"abc 123"); -#elif defined(WCHAR_T_IS_UTF16) - string.assign(L" ! \xd801\xdc01" L"abc 123"); -#else -#error wchar_t should be either UTF-16 or UTF-32 -#endif - EXPECT_EQ(l10n_util::LEFT_TO_RIGHT, - l10n_util::GetFirstStrongCharacterDirection(string)); -} - -typedef struct { - std::wstring path; - std::wstring wrapped_path; -} PathAndWrappedPath; - -TEST_F(L10nUtilTest, WrapPathWithLTRFormatting) { - std::wstring kSeparator; - kSeparator.push_back(static_cast<wchar_t>(FilePath::kSeparators[0])); - const PathAndWrappedPath test_data[] = { - // Test common path, such as "c:\foo\bar". - { L"c:" + kSeparator + L"foo" + kSeparator + L"bar", - L"\x202a"L"c:" + kSeparator + L"foo" + kSeparator + - L"bar\x202c" - }, - // Test path with file name, such as "c:\foo\bar\test.jpg". - { L"c:" + kSeparator + L"foo" + kSeparator + L"bar" + kSeparator + - L"test.jpg", - L"\x202a"L"c:" + kSeparator + L"foo" + kSeparator + - L"bar" + kSeparator + L"test.jpg\x202c" - }, - // Test path ending with punctuation, such as "c:\(foo)\bar.". - { L"c:" + kSeparator + L"(foo)" + kSeparator + L"bar.", - L"\x202a"L"c:" + kSeparator + L"(foo)" + kSeparator + - L"bar.\x202c" - }, - // Test path ending with separator, such as "c:\foo\bar\". - { L"c:" + kSeparator + L"foo" + kSeparator + L"bar" + kSeparator, - L"\x202a"L"c:" + kSeparator + L"foo" + kSeparator + - L"bar" + kSeparator + L"\x202c", - }, - // Test path with RTL character. - { L"c:" + kSeparator + L"\x05d0", - L"\x202a"L"c:" + kSeparator + L"\x05d0\x202c", - }, - // Test path with 2 level RTL directory names. - { L"c:" + kSeparator + L"\x05d0" + kSeparator + L"\x0622", - L"\x202a"L"c:" + kSeparator + L"\x05d0" + kSeparator + - L"\x0622\x202c", - }, - // Test path with mixed RTL/LTR directory names and ending with punctuation. - { L"c:" + kSeparator + L"\x05d0" + kSeparator + L"\x0622" + kSeparator + - L"(foo)" + kSeparator + L"b.a.r.", - L"\x202a"L"c:" + kSeparator + L"\x05d0" + kSeparator + - L"\x0622" + kSeparator + L"(foo)" + kSeparator + - L"b.a.r.\x202c", - }, - // Test path without driver name, such as "/foo/bar/test/jpg". - { kSeparator + L"foo" + kSeparator + L"bar" + kSeparator + L"test.jpg", - L"\x202a" + kSeparator + L"foo" + kSeparator + L"bar" + - kSeparator + L"test.jpg" + L"\x202c" - }, - // Test path start with current directory, such as "./foo". - { L"." + kSeparator + L"foo", - L"\x202a"L"." + kSeparator + L"foo" + L"\x202c" - }, - // Test path start with parent directory, such as "../foo/bar.jpg". - { L".." + kSeparator + L"foo" + kSeparator + L"bar.jpg", - L"\x202a"L".." + kSeparator + L"foo" + kSeparator + - L"bar.jpg" + L"\x202c" - }, - // Test absolute path, such as "//foo/bar.jpg". - { kSeparator + kSeparator + L"foo" + kSeparator + L"bar.jpg", - L"\x202a" + kSeparator + kSeparator + L"foo" + kSeparator + - L"bar.jpg" + L"\x202c" - }, - // Test path with mixed RTL/LTR directory names. - { L"c:" + kSeparator + L"foo" + kSeparator + L"\x05d0" + kSeparator + - L"\x0622" + kSeparator + L"\x05d1.jpg", - L"\x202a"L"c:" + kSeparator + L"foo" + kSeparator + L"\x05d0" + - kSeparator + L"\x0622" + kSeparator + L"\x05d1.jpg" + L"\x202c", - }, - // Test empty path. - { L"", - L"\x202a\x202c" - } - }; - for (unsigned int i = 0; i < arraysize(test_data); ++i) { - string16 localized_file_path_string; - FilePath path = FilePath::FromWStringHack(test_data[i].path); - l10n_util::WrapPathWithLTRFormatting(path, &localized_file_path_string); - std::wstring wrapped_path = UTF16ToWide(localized_file_path_string); - EXPECT_EQ(wrapped_path, test_data[i].wrapped_path); - } -} - -typedef struct { - std::wstring raw_filename; - std::wstring display_string; -} StringAndLTRString; - -TEST_F(L10nUtilTest, GetDisplayStringInLTRDirectionality) { - const StringAndLTRString test_data[] = { - { L"test", L"\x202atest\x202c" }, - { L"test.html", L"\x202atest.html\x202c" }, - { L"\x05d0\x05d1\x05d2", L"\x202a\x05d0\x05d1\x05d2\x202c" }, - { L"\x05d0\x05d1\x05d2.txt", L"\x202a\x05d0\x05d1\x05d2.txt\x202c" }, - { L"\x05d0"L"abc", L"\x202a\x05d0"L"abc\x202c" }, - { L"\x05d0"L"abc.txt", L"\x202a\x05d0"L"abc.txt\x202c" }, - { L"abc\x05d0\x05d1", L"\x202a"L"abc\x05d0\x05d1\x202c" }, - { L"abc\x05d0\x05d1.jpg", L"\x202a"L"abc\x05d0\x05d1.jpg\x202c" }, - }; - for (unsigned int i = 0; i < arraysize(test_data); ++i) { - std::wstring input = test_data[i].raw_filename; - std::wstring expected = - l10n_util::GetDisplayStringInLTRDirectionality(&input); - if (l10n_util::GetTextDirection() == l10n_util::RIGHT_TO_LEFT) - EXPECT_EQ(test_data[i].display_string, expected); - else - EXPECT_EQ(input, expected); - } -} - -TEST_F(L10nUtilTest, GetTextDirection) { - EXPECT_EQ(l10n_util::RIGHT_TO_LEFT, GetTextDirection("ar")); - EXPECT_EQ(l10n_util::RIGHT_TO_LEFT, GetTextDirection("ar_EG")); - EXPECT_EQ(l10n_util::RIGHT_TO_LEFT, GetTextDirection("he")); - EXPECT_EQ(l10n_util::RIGHT_TO_LEFT, GetTextDirection("he_IL")); - // iw is an obsolete code for Hebrew. - EXPECT_EQ(l10n_util::RIGHT_TO_LEFT, GetTextDirection("iw")); - // Although we're not yet localized to Farsi and Urdu, we - // do have the text layout direction information for them. - EXPECT_EQ(l10n_util::RIGHT_TO_LEFT, GetTextDirection("fa")); - EXPECT_EQ(l10n_util::RIGHT_TO_LEFT, GetTextDirection("ur")); -#if 0 - // Enable these when we include the minimal locale data for Azerbaijani - // written in Arabic and Dhivehi. At the moment, our copy of - // ICU data does not have entries for them. - EXPECT_EQ(l10n_util::RIGHT_TO_LEFT, GetTextDirection("az_Arab")); - // Dhivehi that uses Thaana script. - EXPECT_EQ(l10n_util::RIGHT_TO_LEFT, GetTextDirection("dv")); -#endif - EXPECT_EQ(l10n_util::LEFT_TO_RIGHT, GetTextDirection("en")); - // Chinese in China with '-'. - EXPECT_EQ(l10n_util::LEFT_TO_RIGHT, GetTextDirection("zh-CN")); - // Filipino : 3-letter code - EXPECT_EQ(l10n_util::LEFT_TO_RIGHT, GetTextDirection("fil")); - // Russian - EXPECT_EQ(l10n_util::LEFT_TO_RIGHT, GetTextDirection("ru")); - // Japanese that uses multiple scripts - EXPECT_EQ(l10n_util::LEFT_TO_RIGHT, GetTextDirection("ja")); -} - // Test upper and lower case string conversion. TEST_F(L10nUtilTest, UpperLower) { string16 mixed(ASCIIToUTF16("Text with UPPer & lowER casE.")); |