diff options
author | crupest <crupest@outlook.com> | 2020-06-28 00:03:11 +0800 |
---|---|---|
committer | crupest <crupest@outlook.com> | 2020-06-28 00:03:11 +0800 |
commit | 06d1d0442276a05b6caad6e3468f4afb1e8ee5df (patch) | |
tree | ebd46f0fb7343dc57bf947b7b5fffc139c3ddeac /test/win/String.cpp | |
parent | e11be6caa9ef9b2b198ca61846e32f469627556e (diff) | |
download | cru-06d1d0442276a05b6caad6e3468f4afb1e8ee5df.tar.gz cru-06d1d0442276a05b6caad6e3468f4afb1e8ee5df.tar.bz2 cru-06d1d0442276a05b6caad6e3468f4afb1e8ee5df.zip |
...
Diffstat (limited to 'test/win/String.cpp')
-rw-r--r-- | test/win/String.cpp | 53 |
1 files changed, 53 insertions, 0 deletions
diff --git a/test/win/String.cpp b/test/win/String.cpp new file mode 100644 index 00000000..a666dc81 --- /dev/null +++ b/test/win/String.cpp @@ -0,0 +1,53 @@ +#include "cru/win/String.hpp" + +#include <gtest/gtest.h> + +using cru::platform::win::k_code_point_end; + +TEST(WinString, Utf8Iterator) { + using cru::platform::win::Utf8Iterator; + std::string_view text = "aπ你🤣!"; + Utf8Iterator i{text}; + ASSERT_EQ(i.Next(), 0x0061); + ASSERT_EQ(i.Next(), 0x03C0); + ASSERT_EQ(i.Next(), 0x4F60); + ASSERT_EQ(i.Next(), 0x1F923); + ASSERT_EQ(i.Next(), 0x0021); + ASSERT_EQ(i.Next(), k_code_point_end); +} + +TEST(WinString, Utf16Iterator) { + using cru::platform::win::Utf16Iterator; + std::wstring_view text = L"aπ你🤣!"; + Utf16Iterator i{text}; + ASSERT_EQ(i.Next(), 0x0061); + ASSERT_EQ(i.Next(), 0x03C0); + ASSERT_EQ(i.Next(), 0x4F60); + ASSERT_EQ(i.Next(), 0x1F923); + ASSERT_EQ(i.Next(), 0x0021); + ASSERT_EQ(i.Next(), k_code_point_end); +} + +TEST(WinString, IndexUtf8ToUtf16) { + using cru::platform::win::IndexUtf8ToUtf16; + std::string_view utf8_string = "aπ你🤣!"; + std::wstring_view utf16_string = L"aπ你🤣!"; + ASSERT_EQ(IndexUtf8ToUtf16(utf8_string, 0, utf16_string), 0); + ASSERT_EQ(IndexUtf8ToUtf16(utf8_string, 1, utf16_string), 1); + ASSERT_EQ(IndexUtf8ToUtf16(utf8_string, 3, utf16_string), 2); + ASSERT_EQ(IndexUtf8ToUtf16(utf8_string, 6, utf16_string), 3); + ASSERT_EQ(IndexUtf8ToUtf16(utf8_string, 10, utf16_string), 5); + ASSERT_EQ(IndexUtf8ToUtf16(utf8_string, 11, utf16_string), 6); +} + +TEST(WinString, IndexUtf16ToUtf8) { + using cru::platform::win::IndexUtf16ToUtf8; + std::string_view utf8_string = "aπ你🤣!"; + std::wstring_view utf16_string = L"aπ你🤣!"; + ASSERT_EQ(IndexUtf16ToUtf8(utf16_string, 0, utf8_string), 0); + ASSERT_EQ(IndexUtf16ToUtf8(utf16_string, 1, utf8_string), 1); + ASSERT_EQ(IndexUtf16ToUtf8(utf16_string, 2, utf8_string), 3); + ASSERT_EQ(IndexUtf16ToUtf8(utf16_string, 3, utf8_string), 6); + ASSERT_EQ(IndexUtf16ToUtf8(utf16_string, 5, utf8_string), 10); + ASSERT_EQ(IndexUtf16ToUtf8(utf16_string, 6, utf8_string), 11); +} |