summaryrefslogtreecommitdiffstats
path: root/base/i18n
diff options
context:
space:
mode:
authorevan@chromium.org <evan@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2011-03-13 23:36:36 +0000
committerevan@chromium.org <evan@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2011-03-13 23:36:36 +0000
commit607ab296cd74c0c8862836a2f6f4cc00aa0af153 (patch)
treef45e7da05373296d4156e518b11043250e4b5908 /base/i18n
parenta6b74633db8d0ff13c635a0fd25c311f7e191827 (diff)
downloadchromium_src-607ab296cd74c0c8862836a2f6f4cc00aa0af153.zip
chromium_src-607ab296cd74c0c8862836a2f6f4cc00aa0af153.tar.gz
chromium_src-607ab296cd74c0c8862836a2f6f4cc00aa0af153.tar.bz2
wstring: simplify an rtl test
This test is strange; it's testing a function that just inserts a character before and after a string. It doesn't need all the complexity it had. Review URL: http://codereview.chromium.org/6679035 git-svn-id: svn://svn.chromium.org/chrome/trunk/src@77983 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'base/i18n')
-rw-r--r--base/i18n/rtl_unittest.cc96
1 files changed, 31 insertions, 65 deletions
diff --git a/base/i18n/rtl_unittest.cc b/base/i18n/rtl_unittest.cc
index 061e140..363145a 100644
--- a/base/i18n/rtl_unittest.cc
+++ b/base/i18n/rtl_unittest.cc
@@ -4,9 +4,12 @@
#include "base/i18n/rtl.h"
+#include <algorithm>
+
#include "base/file_path.h"
#include "base/string_util.h"
#include "base/utf_string_conversions.h"
+#include "base/sys_string_conversions.h"
#include "testing/gtest/include/gtest/gtest.h"
#include "testing/platform_test.h"
@@ -115,88 +118,51 @@ TEST_F(RTLTest, GetFirstStrongCharacterDirection) {
base::i18n::GetFirstStrongCharacterDirection(string));
}
-typedef struct {
- std::wstring path;
- std::wstring wrapped_path;
-} PathAndWrappedPath;
-
TEST_F(RTLTest, WrapPathWithLTRFormatting) {
- std::wstring kSeparator;
- kSeparator.push_back(static_cast<wchar_t>(FilePath::kSeparators[0]));
- const PathAndWrappedPath test_data[] = {
+ const wchar_t* kTestData[] = {
// 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"
- },
+ L"c:/foo/bar",
// 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"
- },
+ L"c:/foo/bar/test.jpg",
// 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"
- },
+ L"c:/(foo)/bar.",
// 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",
- },
+ L"c:/foo/bar/",
// Test path with RTL character.
- { L"c:" + kSeparator + L"\x05d0",
- L"\x202a"L"c:" + kSeparator + L"\x05d0\x202c",
- },
+ L"c:/\x05d0",
// 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",
- },
+ L"c:/\x05d0/\x0622",
// 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",
- },
+ L"c:/\x05d0/\x0622/(foo)/b.a.r.",
// 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"
- },
+ L"/foo/bar/test.jpg",
// Test path start with current directory, such as "./foo".
- { L"." + kSeparator + L"foo",
- L"\x202a"L"." + kSeparator + L"foo" + L"\x202c"
- },
+ L"./foo",
// 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"
- },
+ L"../foo/bar.jpg",
// 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"
- },
+ L"//foo/bar.jpg",
// 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",
- },
+ L"c:/foo/\x05d0/\x0622/\x05d1.jpg",
// Test empty path.
- { L"",
- L"\x202a\x202c"
- }
+ L""
};
- for (unsigned int i = 0; i < arraysize(test_data); ++i) {
+ for (unsigned int i = 0; i < arraysize(kTestData); ++i) {
+ FilePath path;
+#if defined(OS_WIN)
+ std::wstring win_path(kTestData[i]);
+ std::replace(win_path.begin(), win_path.end(), '/', '\\');
+ path = FilePath(win_path);
+#else
+ path = FilePath(base::SysWideToNativeMB(kTestData[i]));
+#endif
string16 localized_file_path_string;
- FilePath path = FilePath::FromWStringHack(test_data[i].path);
base::i18n::WrapPathWithLTRFormatting(path, &localized_file_path_string);
- std::wstring wrapped_path = UTF16ToWide(localized_file_path_string);
- EXPECT_EQ(wrapped_path, test_data[i].wrapped_path);
+
+ std::wstring wrapped_expected =
+ std::wstring(L"\x202a") + kTestData[i] + L"\x202c";
+ std::wstring wrapped_actual = UTF16ToWide(localized_file_path_string);
+ EXPECT_EQ(wrapped_expected, wrapped_actual);
}
}