Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(390)

Side by Side Diff: ui/gfx/render_text_unittest.cc

Issue 8575020: Improve RenderTextWin font fallback. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src/
Patch Set: '' Created 9 years ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch | Annotate | Revision Log
OLDNEW
1 // Copyright (c) 2011 The Chromium Authors. All rights reserved. 1 // Copyright (c) 2011 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be 2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file. 3 // found in the LICENSE file.
4 4
5 #include "ui/gfx/render_text.h" 5 #include "ui/gfx/render_text.h"
6 6
7 #include "base/memory/scoped_ptr.h" 7 #include "base/memory/scoped_ptr.h"
8 #include "base/utf_string_conversions.h" 8 #include "base/utf_string_conversions.h"
9 #include "testing/gtest/include/gtest/gtest.h" 9 #include "testing/gtest/include/gtest/gtest.h"
10 10
(...skipping 525 matching lines...) Expand 10 before | Expand all | Expand 10 after
536 EXPECT_EQ(4U, render_text->GetCursorPosition()); 536 EXPECT_EQ(4U, render_text->GetCursorPosition());
537 render_text->MoveCursorLeft(CHARACTER_BREAK, false); 537 render_text->MoveCursorLeft(CHARACTER_BREAK, false);
538 EXPECT_EQ(2U, render_text->GetCursorPosition()); 538 EXPECT_EQ(2U, render_text->GetCursorPosition());
539 render_text->MoveCursorLeft(CHARACTER_BREAK, false); 539 render_text->MoveCursorLeft(CHARACTER_BREAK, false);
540 EXPECT_EQ(0U, render_text->GetCursorPosition()); 540 EXPECT_EQ(0U, render_text->GetCursorPosition());
541 render_text->MoveCursorLeft(CHARACTER_BREAK, false); 541 render_text->MoveCursorLeft(CHARACTER_BREAK, false);
542 EXPECT_EQ(0U, render_text->GetCursorPosition()); 542 EXPECT_EQ(0U, render_text->GetCursorPosition());
543 } 543 }
544 #endif 544 #endif
545 545
546 TEST_F(RenderTextTest, GraphemePositions) {
547 scoped_ptr<RenderText> render_text(RenderText::CreateRenderText());
548
549 // LTR 2-character grapheme, LTR abc, LTR 2-character grapheme.
550 const string16 kText1 = WideToUTF16(L"\x0915\x093f"L"abc"L"\x0915\x093f");
551
552 // LTR ab, LTR 2-character grapheme, LTR cd.
553 const string16 kText2 = WideToUTF16(L"ab"L"\x0915\x093f"L"cd");
554
555 struct {
556 string16 text;
557 size_t index;
558 size_t expected_previous;
559 size_t expected_next;
560 } cases[] = {
561 { string16(), 0, 0, 0 },
562 { string16(), 1, 0, 0 },
563 { string16(), 50, 0, 0 },
564 { kText1, 0, 0, 2 },
565 { kText1, 1, 0, 2 },
566 { kText1, 2, 0, 3 },
567 { kText1, 3, 2, 4 },
568 { kText1, 4, 3, 5 },
569 { kText1, 5, 4, 7 },
570 { kText1, 6, 5, 7 },
571 { kText1, 7, 5, 7 },
572 { kText1, 8, 7, 7 },
573 { kText1, 50, 7, 7 },
574 { kText2, 0, 0, 1 },
575 { kText2, 1, 0, 2 },
576 { kText2, 2, 1, 4 },
577 { kText2, 3, 2, 4 },
578 { kText2, 4, 2, 5 },
579 { kText2, 5, 4, 6 },
580 { kText2, 6, 5, 6 },
581 { kText2, 7, 6, 6 },
582 { kText2, 50, 6, 6 },
583 };
584
585 for (size_t i = 0; i < ARRAYSIZE_UNSAFE(cases); i++) {
586 render_text->SetText(cases[i].text);
587
588 size_t next = render_text->GetIndexOfNextGrapheme(cases[i].index);
589 EXPECT_EQ(cases[i].expected_next, next);
590 EXPECT_TRUE(render_text->IsCursorablePosition(next));
591
592 size_t previous = render_text->GetIndexOfPreviousGrapheme(cases[i].index);
593 EXPECT_EQ(cases[i].expected_previous, previous);
594 EXPECT_TRUE(render_text->IsCursorablePosition(previous));
595 }
596 }
597
598 TEST_F(RenderTextTest, SelectionModels) {
599 // Simple Latin text.
600 const string16 kLatin = WideToUTF16(L"abc");
601 // LTR 2-character grapheme.
602 const string16 kLTRGrapheme = WideToUTF16(L"\x0915\x093f");
603 // LTR 2-character grapheme, LTR a, LTR 2-character grapheme.
604 const string16 kHindiLatin = WideToUTF16(L"\x0915\x093f"L"a"L"\x0915\x093f");
605 // RTL 2-character grapheme.
606 const string16 kRTLGrapheme = WideToUTF16(L"\x05e0\x05b8");
607 // RTL 2-character grapheme, LTR a, RTL 2-character grapheme.
608 const string16 kHebrewLatin = WideToUTF16(L"\x05e0\x05b8"L"a"L"\x05e0\x05b8");
609
610 struct {
611 string16 text;
612 size_t expected_left_end_caret;
613 SelectionModel::CaretPlacement expected_left_end_placement;
614 size_t expected_right_end_caret;
615 SelectionModel::CaretPlacement expected_right_end_placement;
616 size_t expected_next;
617 } cases[] = {
618 { string16(), 0, SelectionModel::LEADING, 0, SelectionModel::LEADING },
619 { kLatin, 0, SelectionModel::LEADING, 2, SelectionModel::TRAILING },
620 { kLTRGrapheme, 0, SelectionModel::LEADING, 0, SelectionModel::TRAILING },
621 { kHindiLatin, 0, SelectionModel::LEADING, 3, SelectionModel::TRAILING },
622 { kRTLGrapheme, 0, SelectionModel::TRAILING, 0, SelectionModel::LEADING },
623 // TODO(asvitkine): This behaves differently on Linux. Why?
xji 2011/12/01 20:19:15 Thanks for adding those tests! In Windows, text i
Alexei Svitkine (slow) 2011/12/01 20:58:58 I see. I've added the Linux expectation.
624 #if !defined(OS_LINUX)
625 { kHebrewLatin, 0, SelectionModel::TRAILING, 3, SelectionModel::LEADING },
626 #endif
627 };
628
629 scoped_ptr<RenderText> render_text(RenderText::CreateRenderText());
630 for (size_t i = 0; i < ARRAYSIZE_UNSAFE(cases); i++) {
631 render_text->SetText(cases[i].text);
632
633 SelectionModel model = render_text->LeftEndSelectionModel();
634 EXPECT_EQ(cases[i].expected_left_end_caret, model.caret_pos());
635 EXPECT_TRUE(render_text->IsCursorablePosition(model.caret_pos()));
636 EXPECT_EQ(cases[i].expected_left_end_placement, model.caret_placement());
637
638 model = render_text->RightEndSelectionModel();
639 EXPECT_EQ(cases[i].expected_right_end_caret, model.caret_pos());
640 EXPECT_TRUE(render_text->IsCursorablePosition(model.caret_pos()));
641 EXPECT_EQ(cases[i].expected_right_end_placement, model.caret_placement());
642 }
643 }
644
546 TEST_F(RenderTextTest, MoveCursorLeftRightWithSelection) { 645 TEST_F(RenderTextTest, MoveCursorLeftRightWithSelection) {
547 scoped_ptr<RenderText> render_text(RenderText::CreateRenderText()); 646 scoped_ptr<RenderText> render_text(RenderText::CreateRenderText());
548 render_text->SetText(WideToUTF16(L"abc\x05d0\x05d1\x05d2")); 647 render_text->SetText(WideToUTF16(L"abc\x05d0\x05d1\x05d2"));
549 // Left arrow on select ranging (6, 4). 648 // Left arrow on select ranging (6, 4).
550 render_text->MoveCursorRight(LINE_BREAK, false); 649 render_text->MoveCursorRight(LINE_BREAK, false);
551 EXPECT_EQ(6U, render_text->GetCursorPosition()); 650 EXPECT_EQ(6U, render_text->GetCursorPosition());
552 render_text->MoveCursorLeft(CHARACTER_BREAK, false); 651 render_text->MoveCursorLeft(CHARACTER_BREAK, false);
553 EXPECT_EQ(4U, render_text->GetCursorPosition()); 652 EXPECT_EQ(4U, render_text->GetCursorPosition());
554 render_text->MoveCursorLeft(CHARACTER_BREAK, false); 653 render_text->MoveCursorLeft(CHARACTER_BREAK, false);
555 EXPECT_EQ(5U, render_text->GetCursorPosition()); 654 EXPECT_EQ(5U, render_text->GetCursorPosition());
(...skipping 190 matching lines...) Expand 10 before | Expand all | Expand 10 after
746 EXPECT_EQ(5U, render_text->GetCursorPosition()); 845 EXPECT_EQ(5U, render_text->GetCursorPosition());
747 render_text->MoveCursorRight(WORD_BREAK, false); 846 render_text->MoveCursorRight(WORD_BREAK, false);
748 EXPECT_EQ(6U, render_text->GetCursorPosition()); 847 EXPECT_EQ(6U, render_text->GetCursorPosition());
749 render_text->MoveCursorRight(WORD_BREAK, false); 848 render_text->MoveCursorRight(WORD_BREAK, false);
750 EXPECT_EQ(6U, render_text->GetCursorPosition()); 849 EXPECT_EQ(6U, render_text->GetCursorPosition());
751 } 850 }
752 851
753 #endif 852 #endif
754 853
755 } // namespace gfx 854 } // namespace gfx
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698