Index: base/sys_string_conversions_win_unittest.cc |
=================================================================== |
--- base/sys_string_conversions_win_unittest.cc (revision 3750) |
+++ base/sys_string_conversions_win_unittest.cc (working copy) |
@@ -1,63 +0,0 @@ |
-// Copyright (c) 2006-2008 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 "base/string_piece.h" |
-#include "base/sys_string_conversions.h" |
-#include "testing/gtest/include/gtest/gtest.h" |
- |
-// Apparently Windows doesn't have constants for these. |
-static const int kCpLatin1 = 850; |
-static const int kCpBig5 = 950; |
- |
-TEST(SysStringsWin, SysWideToUTF8) { |
- using base::SysWideToUTF8; |
- EXPECT_EQ("Hello, world", SysWideToUTF8(L"Hello, world")); |
- EXPECT_EQ("\xe4\xbd\xa0\xe5\xa5\xbd", SysWideToUTF8(L"\x4f60\x597d")); |
- EXPECT_EQ("\xF0\x90\x8C\x80", SysWideToUTF8(L"\xd800\xdf00")); // >16 bits |
- |
- // Error case. When Windows finds a UTF-16 character going off the end of |
- // a string, it just converts that literal value to UTF-8, even though this |
- // is invalid. |
- // |
- // This is what XP does, but Vista has different behavior, so we don't bother |
- // verifying it: |
- //EXPECT_EQ("\xE4\xBD\xA0\xED\xA0\x80zyxw", SysWideToUTF8(L"\x4f60\xd800zyxw")); |
- |
- // Test embedded NULLs. |
- std::wstring wide_null(L"a"); |
- wide_null.push_back(0); |
- wide_null.push_back('b'); |
- |
- std::string expected_null("a"); |
- expected_null.push_back(0); |
- expected_null.push_back('b'); |
- |
- EXPECT_EQ(expected_null, SysWideToUTF8(wide_null)); |
-} |
- |
-TEST(SysStringsWin, SysUTF8ToWide) { |
- using base::SysUTF8ToWide; |
- EXPECT_EQ(L"Hello, world", SysUTF8ToWide("Hello, world")); |
- EXPECT_EQ(L"\x4f60\x597d", SysUTF8ToWide("\xe4\xbd\xa0\xe5\xa5\xbd")); |
- EXPECT_EQ(L"\xd800\xdf00", SysUTF8ToWide("\xF0\x90\x8C\x80")); // >16 bits |
- |
- // Error case. When Windows finds an invalid UTF-8 character, it just skips |
- // it. This seems weird because it's inconsistent with the reverse conversion. |
- // |
- // This is what XP does, but Vista has different behavior, so we don't bother |
- // verifying it: |
- //EXPECT_EQ(L"\x4f60zyxw", SysUTF8ToWide("\xe4\xbd\xa0\xe5\xa5zyxw")); |
- |
- // Test embedded NULLs. |
- std::string utf8_null("a"); |
- utf8_null.push_back(0); |
- utf8_null.push_back('b'); |
- |
- std::wstring expected_null(L"a"); |
- expected_null.push_back(0); |
- expected_null.push_back('b'); |
- |
- EXPECT_EQ(expected_null, SysUTF8ToWide(utf8_null)); |
-} |
- |