Chromium Code Reviews| OLD | NEW |
|---|---|
| (Empty) | |
| 1 // Copyright 2016 The Chromium Authors. All rights reserved. | |
| 2 // Use of this source code is governed by a BSD-style license that can be | |
| 3 // found in the LICENSE file. | |
| 4 | |
| 5 #include "ui/gfx/win/text_analysis_source.h" | |
| 6 | |
| 7 #include "testing/gtest/include/gtest/gtest.h" | |
| 8 | |
| 9 namespace mswr = Microsoft::WRL; | |
| 10 | |
| 11 namespace gfx { | |
| 12 namespace win { | |
| 13 | |
| 14 namespace { | |
| 15 | |
| 16 DWRITE_READING_DIRECTION kReadingDirection = | |
| 17 DWRITE_READING_DIRECTION_TOP_TO_BOTTOM; | |
| 18 const wchar_t* kLocale = L"hi-in"; | |
| 19 const wchar_t kText[] = L"sample text"; | |
| 20 const size_t kTextLength = _countof(kText) - 1; | |
| 21 } | |
|
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.
| |
| 22 | |
| 23 class TextAnalysisSourceTest : public testing::Test { | |
| 24 public: | |
| 25 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
| |
| 26 mswr::ComPtr<IDWriteFactory> factory; | |
| 27 CreateDWriteFactory(&factory); | |
| 28 | |
| 29 mswr::ComPtr<IDWriteNumberSubstitution> number_substitution; | |
| 30 factory->CreateNumberSubstitution(DWRITE_NUMBER_SUBSTITUTION_METHOD_NONE, | |
| 31 kLocale, true /* ignoreUserOverride */, | |
| 32 &number_substitution); | |
| 33 | |
| 34 mswr::MakeAndInitialize<TextAnalysisSource>( | |
| 35 &source_, kText, kLocale, number_substitution.Get(), kReadingDirection); | |
| 36 } | |
| 37 | |
| 38 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.
| |
| 39 using DWriteCreateFactoryProc = decltype(DWriteCreateFactory)*; | |
| 40 HMODULE dwrite_dll = LoadLibraryW(L"dwrite.dll"); | |
| 41 if (!dwrite_dll) | |
| 42 return; | |
| 43 | |
| 44 DWriteCreateFactoryProc dwrite_create_factory_proc = | |
| 45 reinterpret_cast<DWriteCreateFactoryProc>( | |
| 46 GetProcAddress(dwrite_dll, "DWriteCreateFactory")); | |
| 47 if (!dwrite_create_factory_proc) | |
| 48 return; | |
| 49 | |
| 50 dwrite_create_factory_proc(DWRITE_FACTORY_TYPE_SHARED, | |
| 51 __uuidof(IDWriteFactory), factory); | |
| 52 } | |
| 53 | |
| 54 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.
| |
| 55 }; | |
|
msw
2016/06/27 20:45:37
nit: DISALLOW_COPY_AND_ASSIGN
Ilya Kulshin
2016/06/28 18:08:01
Done.
| |
| 56 | |
| 57 TEST_F(TextAnalysisSourceTest, TestGetLocaleName) { | |
| 58 UINT32 length = 0; | |
| 59 const wchar_t* locale_name = nullptr; | |
| 60 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.
| |
| 61 hr = source_->GetLocaleName(0, &length, &locale_name); | |
| 62 | |
| 63 EXPECT_TRUE(SUCCEEDED(hr)); | |
| 64 EXPECT_EQ(kTextLength, length); | |
| 65 EXPECT_STREQ(kLocale, locale_name); | |
| 66 | |
| 67 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.
| |
| 68 | |
| 69 EXPECT_TRUE(FAILED(hr)); | |
| 70 } | |
| 71 | |
| 72 TEST_F(TextAnalysisSourceTest, TestGetNumberSubstitution) { | |
| 73 UINT32 length = 0; | |
| 74 mswr::ComPtr<IDWriteNumberSubstitution> number_substitution; | |
| 75 HRESULT hr; | |
| 76 hr = source_->GetNumberSubstitution(0, &length, &number_substitution); | |
| 77 | |
| 78 EXPECT_TRUE(SUCCEEDED(hr)); | |
| 79 EXPECT_EQ(kTextLength, length); | |
| 80 EXPECT_NE(nullptr, number_substitution.Get()); | |
| 81 | |
| 82 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.
| |
| 83 &number_substitution); | |
| 84 | |
| 85 EXPECT_TRUE(FAILED(hr)); | |
| 86 } | |
| 87 | |
| 88 TEST_F(TextAnalysisSourceTest, TestGetParagraphReadingDirection) { | |
| 89 EXPECT_EQ(kReadingDirection, source_->GetParagraphReadingDirection()); | |
| 90 } | |
| 91 | |
| 92 TEST_F(TextAnalysisSourceTest, TestGetTextAtPosition) { | |
| 93 UINT32 length = 0; | |
| 94 const wchar_t* text = nullptr; | |
| 95 HRESULT hr; | |
| 96 hr = source_->GetTextAtPosition(0, &text, &length); | |
| 97 | |
| 98 EXPECT_TRUE(SUCCEEDED(hr)); | |
| 99 EXPECT_EQ(kTextLength, length); | |
| 100 EXPECT_STREQ(kText, text); | |
| 101 | |
| 102 hr = source_->GetTextAtPosition(5, &text, &length); | |
| 103 | |
| 104 EXPECT_TRUE(SUCCEEDED(hr)); | |
| 105 EXPECT_EQ(kTextLength - 5, length); | |
| 106 EXPECT_STREQ(kText + 5, text); | |
| 107 | |
| 108 hr = source_->GetTextAtPosition(kTextLength, &text, &length); | |
| 109 | |
| 110 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
| |
| 111 EXPECT_EQ(nullptr, text); | |
| 112 } | |
| 113 | |
| 114 TEST_F(TextAnalysisSourceTest, TestGetTextBeforePosition) { | |
| 115 UINT32 length = 0; | |
| 116 const wchar_t* text = nullptr; | |
| 117 HRESULT hr; | |
| 118 hr = source_->GetTextBeforePosition(0, &text, &length); | |
| 119 | |
| 120 EXPECT_TRUE(SUCCEEDED(hr)); | |
| 121 EXPECT_EQ(nullptr, text); | |
| 122 | |
| 123 hr = source_->GetTextBeforePosition(5, &text, &length); | |
| 124 | |
| 125 EXPECT_TRUE(SUCCEEDED(hr)); | |
| 126 EXPECT_EQ(5u, length); | |
| 127 EXPECT_STREQ(kText, text); | |
| 128 | |
| 129 hr = source_->GetTextBeforePosition(kTextLength, &text, &length); | |
| 130 | |
| 131 EXPECT_TRUE(SUCCEEDED(hr)); | |
| 132 EXPECT_EQ(kTextLength, length); | |
| 133 EXPECT_STREQ(kText, text); | |
| 134 } | |
| 135 | |
| 136 } // namespace win | |
| 137 } // namespace gfx | |
| OLD | NEW |