| Index: ui/views/controls/label_unittest.cc
|
| diff --git a/ui/views/controls/label_unittest.cc b/ui/views/controls/label_unittest.cc
|
| index 5825b6c88dad84516b88b5d4e916ec5bc00eaf01..1ff16b4bd0cc42c066fadfc1198613a4cc41d675 100644
|
| --- a/ui/views/controls/label_unittest.cc
|
| +++ b/ui/views/controls/label_unittest.cc
|
| @@ -19,6 +19,13 @@ namespace views {
|
| // All text sizing measurements (width and height) should be greater than this.
|
| const int kMinTextDimension = 4;
|
|
|
| +// A test utility function to set the application default text direction.
|
| +void SetRTL(bool rtl) {
|
| + // Override the current locale/direction.
|
| + base::i18n::SetICUDefaultLocale(rtl ? "he" : "en");
|
| + EXPECT_EQ(rtl, base::i18n::IsRTL());
|
| +}
|
| +
|
| TEST(LabelTest, FontPropertySymbol) {
|
| Label label;
|
| std::string font_name("symbol");
|
| @@ -55,38 +62,45 @@ TEST(LabelTest, ColorProperty) {
|
| }
|
|
|
| TEST(LabelTest, AlignmentProperty) {
|
| - Label label;
|
| - bool reverse_alignment = base::i18n::IsRTL();
|
| -
|
| - label.SetHorizontalAlignment(gfx::ALIGN_RIGHT);
|
| - EXPECT_EQ(reverse_alignment ? gfx::ALIGN_LEFT : gfx::ALIGN_RIGHT,
|
| - label.horizontal_alignment());
|
| - label.SetHorizontalAlignment(gfx::ALIGN_LEFT);
|
| - EXPECT_EQ(reverse_alignment ? gfx::ALIGN_RIGHT : gfx::ALIGN_LEFT,
|
| - label.horizontal_alignment());
|
| - label.SetHorizontalAlignment(gfx::ALIGN_CENTER);
|
| - EXPECT_EQ(gfx::ALIGN_CENTER, label.horizontal_alignment());
|
| + const bool was_rtl = base::i18n::IsRTL();
|
|
|
| - // The label's alignment should not be flipped if the directionality mode is
|
| - // AUTO_DETECT_DIRECTIONALITY.
|
| - label.set_directionality_mode(Label::AUTO_DETECT_DIRECTIONALITY);
|
| - label.SetHorizontalAlignment(gfx::ALIGN_RIGHT);
|
| - EXPECT_EQ(gfx::ALIGN_RIGHT, label.horizontal_alignment());
|
| - label.SetHorizontalAlignment(gfx::ALIGN_LEFT);
|
| - EXPECT_EQ(gfx::ALIGN_LEFT, label.horizontal_alignment());
|
| - label.SetHorizontalAlignment(gfx::ALIGN_CENTER);
|
| - EXPECT_EQ(gfx::ALIGN_CENTER, label.horizontal_alignment());
|
| + Label label;
|
| + for (size_t i = 0; i < 2; ++i) {
|
| + // Toggle the application default text direction (to try each direction).
|
| + SetRTL(!base::i18n::IsRTL());
|
| + bool reverse_alignment = base::i18n::IsRTL();
|
| +
|
| + // The alignment should be flipped in RTL UI.
|
| + label.SetHorizontalAlignment(gfx::ALIGN_RIGHT);
|
| + EXPECT_EQ(reverse_alignment ? gfx::ALIGN_LEFT : gfx::ALIGN_RIGHT,
|
| + label.GetHorizontalAlignment());
|
| + label.SetHorizontalAlignment(gfx::ALIGN_LEFT);
|
| + EXPECT_EQ(reverse_alignment ? gfx::ALIGN_RIGHT : gfx::ALIGN_LEFT,
|
| + label.GetHorizontalAlignment());
|
| + label.SetHorizontalAlignment(gfx::ALIGN_CENTER);
|
| + EXPECT_EQ(gfx::ALIGN_CENTER, label.GetHorizontalAlignment());
|
| +
|
| + for (size_t j = 0; j < 2; ++j) {
|
| + label.SetHorizontalAlignment(gfx::ALIGN_TO_HEAD);
|
| + const bool rtl = j == 0;
|
| + label.SetText(rtl ? base::WideToUTF16(L"\x5d0") : ASCIIToUTF16("A"));
|
| + EXPECT_EQ(rtl ? gfx::ALIGN_RIGHT : gfx::ALIGN_LEFT,
|
| + label.GetHorizontalAlignment());
|
| + }
|
| + }
|
| +
|
| + EXPECT_EQ(was_rtl, base::i18n::IsRTL());
|
| }
|
|
|
| TEST(LabelTest, DirectionalityModeProperty) {
|
| Label label;
|
| - EXPECT_EQ(Label::USE_UI_DIRECTIONALITY, label.directionality_mode());
|
| + EXPECT_EQ(gfx::DIRECTIONALITY_FROM_UI, label.directionality_mode());
|
|
|
| - label.set_directionality_mode(Label::AUTO_DETECT_DIRECTIONALITY);
|
| - EXPECT_EQ(Label::AUTO_DETECT_DIRECTIONALITY, label.directionality_mode());
|
| + label.set_directionality_mode(gfx::DIRECTIONALITY_FROM_TEXT);
|
| + EXPECT_EQ(gfx::DIRECTIONALITY_FROM_TEXT, label.directionality_mode());
|
|
|
| - label.set_directionality_mode(Label::USE_UI_DIRECTIONALITY);
|
| - EXPECT_EQ(Label::USE_UI_DIRECTIONALITY, label.directionality_mode());
|
| + label.set_directionality_mode(gfx::DIRECTIONALITY_FROM_UI);
|
| + EXPECT_EQ(gfx::DIRECTIONALITY_FROM_UI, label.directionality_mode());
|
| }
|
|
|
| TEST(LabelTest, MultiLineProperty) {
|
| @@ -317,20 +331,16 @@ TEST(LabelTest, MultiLineSizing) {
|
| required_size.width() + border.width());
|
| }
|
|
|
| -TEST(LabelTest, AutoDetectDirectionality) {
|
| +TEST(LabelTest, DirectionalityFromText) {
|
| Label label;
|
| - label.set_directionality_mode(Label::AUTO_DETECT_DIRECTIONALITY);
|
| + label.set_directionality_mode(gfx::DIRECTIONALITY_FROM_TEXT);
|
| + label.SetBounds(0, 0, 1000, 1000);
|
| + base::string16 paint_text;
|
| + gfx::Rect text_bounds;
|
| + int flags = -1;
|
|
|
| // Test text starts with RTL character.
|
| label.SetText(base::WideToUTF16(L" \x5d0\x5d1\x5d2 abc"));
|
| - gfx::Size required_size(label.GetPreferredSize());
|
| - gfx::Size extra(22, 8);
|
| - label.SetBounds(0, 0, required_size.width() + extra.width(),
|
| - required_size.height() + extra.height());
|
| -
|
| - base::string16 paint_text;
|
| - gfx::Rect text_bounds;
|
| - int flags;
|
| label.CalculateDrawStringParams(&paint_text, &text_bounds, &flags);
|
| EXPECT_EQ(gfx::Canvas::FORCE_RTL_DIRECTIONALITY,
|
| flags & (gfx::Canvas::FORCE_RTL_DIRECTIONALITY |
|
| @@ -338,10 +348,6 @@ TEST(LabelTest, AutoDetectDirectionality) {
|
|
|
| // Test text starts with LTR character.
|
| label.SetText(base::WideToUTF16(L"ltr \x5d0\x5d1\x5d2 abc"));
|
| - required_size = label.GetPreferredSize();
|
| - label.SetBounds(0, 0, required_size.width() + extra.width(),
|
| - required_size.height() + extra.height());
|
| -
|
| label.CalculateDrawStringParams(&paint_text, &text_bounds, &flags);
|
| EXPECT_EQ(gfx::Canvas::FORCE_LTR_DIRECTIONALITY,
|
| flags & (gfx::Canvas::FORCE_RTL_DIRECTIONALITY |
|
| @@ -351,10 +357,8 @@ TEST(LabelTest, AutoDetectDirectionality) {
|
| TEST(LabelTest, DrawSingleLineString) {
|
| Label label;
|
| label.SetFocusable(false);
|
| -
|
| - // Turn off mirroring so that we don't need to figure out if
|
| - // align right really means align left.
|
| - label.set_directionality_mode(Label::AUTO_DETECT_DIRECTIONALITY);
|
| + // Force a directionality to simplify alignment value testing.
|
| + label.set_directionality_mode(gfx::DIRECTIONALITY_FORCE_LTR);
|
|
|
| label.SetText(ASCIIToUTF16("Here's a string with no returns."));
|
| gfx::Size required_size(label.GetPreferredSize());
|
| @@ -365,7 +369,7 @@ TEST(LabelTest, DrawSingleLineString) {
|
| // Do some basic verifications for all three alignments.
|
| base::string16 paint_text;
|
| gfx::Rect text_bounds;
|
| - int flags;
|
| + int flags = -1;
|
|
|
| // Centered text.
|
| label.CalculateDrawStringParams(&paint_text, &text_bounds, &flags);
|
| @@ -474,16 +478,14 @@ TEST(LabelTest, DrawSingleLineString) {
|
| gfx::Canvas::TEXT_ALIGN_RIGHT));
|
| }
|
|
|
| -// On Linux the underlying pango routines require a max height in order to
|
| -// ellide multiline text. So until that can be resolved, we set all
|
| -// multiline lables to not ellide in Linux only.
|
| +// Pango needs a max height to elide multiline text; that is not supported here.
|
| TEST(LabelTest, DrawMultiLineString) {
|
| Label label;
|
| label.SetFocusable(false);
|
| -
|
| - // Turn off mirroring so that we don't need to figure out if
|
| - // align right really means align left.
|
| - label.set_directionality_mode(Label::AUTO_DETECT_DIRECTIONALITY);
|
| + // Force a directionality to simplify alignment value testing.
|
| + label.set_directionality_mode(gfx::DIRECTIONALITY_FORCE_LTR);
|
| + // Set a background color to prevent gfx::Canvas::NO_SUBPIXEL_RENDERING flags.
|
| + label.SetBackgroundColor(SK_ColorWHITE);
|
|
|
| label.SetText(ASCIIToUTF16("Another string\nwith returns\n\n!"));
|
| label.SetMultiLine(true);
|
| @@ -496,7 +498,7 @@ TEST(LabelTest, DrawMultiLineString) {
|
| // Do some basic verifications for all three alignments.
|
| base::string16 paint_text;
|
| gfx::Rect text_bounds;
|
| - int flags;
|
| + int flags = -1;
|
| label.CalculateDrawStringParams(&paint_text, &text_bounds, &flags);
|
| EXPECT_EQ(label.text(), paint_text);
|
| EXPECT_EQ(extra.width() / 2, text_bounds.x());
|
| @@ -509,7 +511,7 @@ TEST(LabelTest, DrawMultiLineString) {
|
| #if !defined(OS_WIN)
|
| expected_flags |= gfx::Canvas::NO_ELLIPSIS;
|
| #endif
|
| - EXPECT_EQ(expected_flags, expected_flags & flags);
|
| + EXPECT_EQ(expected_flags, expected_flags);
|
| gfx::Rect center_bounds(text_bounds);
|
|
|
| label.SetHorizontalAlignment(gfx::ALIGN_LEFT);
|
| @@ -527,7 +529,7 @@ TEST(LabelTest, DrawMultiLineString) {
|
| #if !defined(OS_WIN)
|
| expected_flags |= gfx::Canvas::NO_ELLIPSIS;
|
| #endif
|
| - EXPECT_EQ(expected_flags, expected_flags & flags);
|
| + EXPECT_EQ(expected_flags, expected_flags);
|
|
|
| label.SetHorizontalAlignment(gfx::ALIGN_RIGHT);
|
| paint_text.clear();
|
| @@ -544,7 +546,7 @@ TEST(LabelTest, DrawMultiLineString) {
|
| #if !defined(OS_WIN)
|
| expected_flags |= gfx::Canvas::NO_ELLIPSIS;
|
| #endif
|
| - EXPECT_EQ(expected_flags, expected_flags & flags);
|
| + EXPECT_EQ(expected_flags, expected_flags);
|
|
|
| // Test multiline drawing with a border.
|
| gfx::Insets border(19, 92, 23, 2);
|
| @@ -570,7 +572,7 @@ TEST(LabelTest, DrawMultiLineString) {
|
| #if !defined(OS_WIN)
|
| expected_flags |= gfx::Canvas::NO_ELLIPSIS;
|
| #endif
|
| - EXPECT_EQ(expected_flags, expected_flags & flags);
|
| + EXPECT_EQ(expected_flags, expected_flags);
|
|
|
| label.SetHorizontalAlignment(gfx::ALIGN_LEFT);
|
| paint_text.clear();
|
| @@ -587,7 +589,7 @@ TEST(LabelTest, DrawMultiLineString) {
|
| #if !defined(OS_WIN)
|
| expected_flags |= gfx::Canvas::NO_ELLIPSIS;
|
| #endif
|
| - EXPECT_EQ(expected_flags, expected_flags & flags);
|
| + EXPECT_EQ(expected_flags, expected_flags);
|
|
|
| label.SetHorizontalAlignment(gfx::ALIGN_RIGHT);
|
| paint_text.clear();
|
| @@ -604,7 +606,7 @@ TEST(LabelTest, DrawMultiLineString) {
|
| #if !defined(OS_WIN)
|
| expected_flags |= gfx::Canvas::NO_ELLIPSIS;
|
| #endif
|
| - EXPECT_EQ(expected_flags, expected_flags & flags);
|
| + EXPECT_EQ(expected_flags, expected_flags);
|
| }
|
|
|
| TEST(LabelTest, DrawSingleLineStringInRTL) {
|
| @@ -623,7 +625,7 @@ TEST(LabelTest, DrawSingleLineStringInRTL) {
|
| // Do some basic verifications for all three alignments.
|
| base::string16 paint_text;
|
| gfx::Rect text_bounds;
|
| - int flags;
|
| + int flags = -1;
|
|
|
| // Centered text.
|
| label.CalculateDrawStringParams(&paint_text, &text_bounds, &flags);
|
| @@ -758,7 +760,7 @@ TEST(LabelTest, DrawMultiLineStringInRTL) {
|
| // Do some basic verifications for all three alignments.
|
| base::string16 paint_text;
|
| gfx::Rect text_bounds;
|
| - int flags;
|
| + int flags = -1;
|
| label.CalculateDrawStringParams(&paint_text, &text_bounds, &flags);
|
| EXPECT_EQ(label.text(), paint_text);
|
| EXPECT_EQ(extra.width() / 2, text_bounds.x());
|
|
|