Index: ui/gfx/render_text_unittest.cc |
diff --git a/ui/gfx/render_text_unittest.cc b/ui/gfx/render_text_unittest.cc |
index fa10e542cfca27e22674cd67d7187a1fc06b4f74..949c4e9f8ff1fbfb46267dd527132b98aba86170 100644 |
--- a/ui/gfx/render_text_unittest.cc |
+++ b/ui/gfx/render_text_unittest.cc |
@@ -2076,6 +2076,7 @@ TEST_F(RenderTextTest, Multiline_MinWidth) { |
RenderTextHarfBuzz render_text; |
render_text.SetDisplayRect(Rect(1, 1000)); |
render_text.SetMultiline(true); |
+ render_text.SetWordWrapBehavior(WRAP_LONG_WORDS); |
Canvas canvas; |
for (size_t i = 0; i < arraysize(kTestStrings); ++i) { |
@@ -2109,6 +2110,7 @@ TEST_F(RenderTextTest, Multiline_NormalWidth) { |
render_text.set_glyph_width_for_test(5); |
render_text.SetDisplayRect(Rect(50, 1000)); |
render_text.SetMultiline(true); |
+ render_text.SetWordWrapBehavior(WRAP_LONG_WORDS); |
render_text.SetHorizontalAlignment(ALIGN_TO_HEAD); |
Canvas canvas; |
@@ -2295,6 +2297,45 @@ TEST_F(RenderTextTest, Multiline_HorizontalAlignment) { |
} |
} |
+TEST_F(RenderTextTest, Multiline_WordWrapBehavior) { |
+ RenderTextHarfBuzz render_text; |
+ render_text.SetMultiline(true); |
+ render_text.SetText(ASCIIToUTF16("foo ")); |
+ const int foo_width = render_text.GetStringSize().width(); |
+ |
+ render_text.SetText(ASCIIToUTF16("foo fooooo foo")); |
+ render_text.SetDisplayRect(Rect(0, 0, foo_width, 0)); |
+ |
+ Canvas canvas; |
+ render_text.Draw(&canvas); |
msw
2015/03/26 19:36:30
nit: either render_text.SetWordWrapBehavior(IGNORE
Jun Mukai
2015/03/26 22:47:38
Done.
|
+ EXPECT_EQ(3u, render_text.lines().size()); |
+ EXPECT_EQ(Range(0, 4), render_text.lines()[0].segments[0].char_range); |
msw
2015/03/26 19:36:30
I think you'll need to do render_text.set_glyph_wi
Jun Mukai
2015/03/26 22:47:38
Done, great.
|
+ EXPECT_EQ(Range(4, 11), render_text.lines()[1].segments[0].char_range); |
+ EXPECT_EQ(Range(11, 14), render_text.lines()[2].segments[0].char_range); |
+ |
+ render_text.SetWordWrapBehavior(TRUNCATE_LONG_WORDS); |
+ render_text.Draw(&canvas); |
+ EXPECT_EQ(3u, render_text.lines().size()); |
+ EXPECT_EQ(Range(0, 4), render_text.lines()[0].segments[0].char_range); |
+ EXPECT_GT(11u, render_text.lines()[1].segments[0].char_range.end()); |
msw
2015/03/26 19:36:30
With a fixed width, you can expect this to equal (
Jun Mukai
2015/03/26 22:47:38
Done.
|
+ EXPECT_EQ(Range(11, 14), render_text.lines()[2].segments[0].char_range); |
+ |
+ // TODO(mukai): implement ELIDE_LONG_WORDS. It's not used right now. |
+ |
+ render_text.SetWordWrapBehavior(WRAP_LONG_WORDS); |
+ render_text.Draw(&canvas); |
+ EXPECT_LE(4u, render_text.lines().size()); |
msw
2015/03/26 19:36:30
With a fixed width, you can expect this to equal 4
Jun Mukai
2015/03/26 22:47:38
Done.
|
+ EXPECT_EQ(Range(0, 4), render_text.lines()[0].segments[0].char_range); |
+ for (size_t i = 0; i < render_text.lines().size() - 1; ++i) { |
+ Range char_range = render_text.lines()[i].segments[0].char_range; |
+ Range next_char_range = render_text.lines()[i + 1].segments[0].char_range; |
+ EXPECT_EQ(char_range.end(), next_char_range.start()) |
+ << i << " " << char_range << " vs " << next_char_range; |
+ } |
+ EXPECT_EQ(14u, render_text.lines()[render_text.lines().size() - 1] |
+ .segments[0].char_range.end()); |
+} |
+ |
TEST_F(RenderTextTest, NewlineWithoutMultilineFlag) { |
const wchar_t* kTestStrings[] = { |
L"abc\ndef", L"a \n b ", L"ab\n", L"a\n\nb", L"\nab", L"\n", |