Index: ui/gfx/win/text_analysis_source_unittest.cc |
diff --git a/ui/gfx/win/text_analysis_source_unittest.cc b/ui/gfx/win/text_analysis_source_unittest.cc |
new file mode 100644 |
index 0000000000000000000000000000000000000000..dda3ee8d77e4cbe827935281b92609ab6af1036d |
--- /dev/null |
+++ b/ui/gfx/win/text_analysis_source_unittest.cc |
@@ -0,0 +1,137 @@ |
+// Copyright 2016 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 "ui/gfx/win/text_analysis_source.h" |
+ |
+#include "testing/gtest/include/gtest/gtest.h" |
+ |
+namespace mswr = Microsoft::WRL; |
+ |
+namespace gfx { |
+namespace win { |
+ |
+namespace { |
+ |
+DWRITE_READING_DIRECTION kReadingDirection = |
+ DWRITE_READING_DIRECTION_TOP_TO_BOTTOM; |
+const wchar_t* kLocale = L"hi-in"; |
+const wchar_t kText[] = L"sample text"; |
+const size_t kTextLength = _countof(kText) - 1; |
+} |
msw
2016/06/27 20:45:37
nit: blank line above and add a comment: "} // na
Ilya Kulshin
2016/06/28 18:08:01
Done.
|
+ |
+class TextAnalysisSourceTest : public testing::Test { |
+ public: |
+ TextAnalysisSourceTest() { |
msw
2016/06/27 20:45:37
nit: define a dtor or use "= default;"?
Ilya Kulshin
2016/06/28 18:08:01
This class does not require custom destruction log
|
+ mswr::ComPtr<IDWriteFactory> factory; |
+ CreateDWriteFactory(&factory); |
+ |
+ mswr::ComPtr<IDWriteNumberSubstitution> number_substitution; |
+ factory->CreateNumberSubstitution(DWRITE_NUMBER_SUBSTITUTION_METHOD_NONE, |
+ kLocale, true /* ignoreUserOverride */, |
+ &number_substitution); |
+ |
+ mswr::MakeAndInitialize<TextAnalysisSource>( |
+ &source_, kText, kLocale, number_substitution.Get(), kReadingDirection); |
+ } |
+ |
+ void CreateDWriteFactory(IUnknown** factory) { |
msw
2016/06/27 20:45:37
Can you use gfx::win::CreateDWriteFactory instead?
Ilya Kulshin
2016/06/28 18:08:01
Done.
|
+ using DWriteCreateFactoryProc = decltype(DWriteCreateFactory)*; |
+ HMODULE dwrite_dll = LoadLibraryW(L"dwrite.dll"); |
+ if (!dwrite_dll) |
+ return; |
+ |
+ DWriteCreateFactoryProc dwrite_create_factory_proc = |
+ reinterpret_cast<DWriteCreateFactoryProc>( |
+ GetProcAddress(dwrite_dll, "DWriteCreateFactory")); |
+ if (!dwrite_create_factory_proc) |
+ return; |
+ |
+ dwrite_create_factory_proc(DWRITE_FACTORY_TYPE_SHARED, |
+ __uuidof(IDWriteFactory), factory); |
+ } |
+ |
+ mswr::ComPtr<TextAnalysisSource> source_; |
msw
2016/06/27 20:45:36
nit: make private; add a protected/public accessor
Ilya Kulshin
2016/06/28 18:08:01
Made protected.
|
+}; |
msw
2016/06/27 20:45:37
nit: DISALLOW_COPY_AND_ASSIGN
Ilya Kulshin
2016/06/28 18:08:01
Done.
|
+ |
+TEST_F(TextAnalysisSourceTest, TestGetLocaleName) { |
+ UINT32 length = 0; |
+ const wchar_t* locale_name = nullptr; |
+ HRESULT hr; |
msw
2016/06/27 20:45:36
nit: init to E_FAIL or E_UNEXPECTED; ditto elsewhe
Ilya Kulshin
2016/06/28 18:08:01
Done.
|
+ hr = source_->GetLocaleName(0, &length, &locale_name); |
+ |
+ EXPECT_TRUE(SUCCEEDED(hr)); |
+ EXPECT_EQ(kTextLength, length); |
+ EXPECT_STREQ(kLocale, locale_name); |
+ |
+ hr = source_->GetLocaleName(kTextLength, &length, &locale_name); |
msw
2016/06/27 20:45:37
nit: add a comment explaining why this fails? (is
Ilya Kulshin
2016/06/28 18:08:01
Done.
|
+ |
+ EXPECT_TRUE(FAILED(hr)); |
+} |
+ |
+TEST_F(TextAnalysisSourceTest, TestGetNumberSubstitution) { |
+ UINT32 length = 0; |
+ mswr::ComPtr<IDWriteNumberSubstitution> number_substitution; |
+ HRESULT hr; |
+ hr = source_->GetNumberSubstitution(0, &length, &number_substitution); |
+ |
+ EXPECT_TRUE(SUCCEEDED(hr)); |
+ EXPECT_EQ(kTextLength, length); |
+ EXPECT_NE(nullptr, number_substitution.Get()); |
+ |
+ hr = source_->GetNumberSubstitution(kTextLength, &length, |
msw
2016/06/27 20:45:36
ditto nit: add a simple comment on why this fails.
Ilya Kulshin
2016/06/28 18:08:01
Done.
|
+ &number_substitution); |
+ |
+ EXPECT_TRUE(FAILED(hr)); |
+} |
+ |
+TEST_F(TextAnalysisSourceTest, TestGetParagraphReadingDirection) { |
+ EXPECT_EQ(kReadingDirection, source_->GetParagraphReadingDirection()); |
+} |
+ |
+TEST_F(TextAnalysisSourceTest, TestGetTextAtPosition) { |
+ UINT32 length = 0; |
+ const wchar_t* text = nullptr; |
+ HRESULT hr; |
+ hr = source_->GetTextAtPosition(0, &text, &length); |
+ |
+ EXPECT_TRUE(SUCCEEDED(hr)); |
+ EXPECT_EQ(kTextLength, length); |
+ EXPECT_STREQ(kText, text); |
+ |
+ hr = source_->GetTextAtPosition(5, &text, &length); |
+ |
+ EXPECT_TRUE(SUCCEEDED(hr)); |
+ EXPECT_EQ(kTextLength - 5, length); |
+ EXPECT_STREQ(kText + 5, text); |
+ |
+ hr = source_->GetTextAtPosition(kTextLength, &text, &length); |
+ |
+ EXPECT_TRUE(SUCCEEDED(hr)); |
msw
2016/06/27 20:45:37
nit: odd that this passes... should you check that
Ilya Kulshin
2016/06/28 18:08:01
My reading of https://msdn.microsoft.com/en-us/lib
|
+ EXPECT_EQ(nullptr, text); |
+} |
+ |
+TEST_F(TextAnalysisSourceTest, TestGetTextBeforePosition) { |
+ UINT32 length = 0; |
+ const wchar_t* text = nullptr; |
+ HRESULT hr; |
+ hr = source_->GetTextBeforePosition(0, &text, &length); |
+ |
+ EXPECT_TRUE(SUCCEEDED(hr)); |
+ EXPECT_EQ(nullptr, text); |
+ |
+ hr = source_->GetTextBeforePosition(5, &text, &length); |
+ |
+ EXPECT_TRUE(SUCCEEDED(hr)); |
+ EXPECT_EQ(5u, length); |
+ EXPECT_STREQ(kText, text); |
+ |
+ hr = source_->GetTextBeforePosition(kTextLength, &text, &length); |
+ |
+ EXPECT_TRUE(SUCCEEDED(hr)); |
+ EXPECT_EQ(kTextLength, length); |
+ EXPECT_STREQ(kText, text); |
+} |
+ |
+} // namespace win |
+} // namespace gfx |