| Index: ui/views/controls/label_unittest.cc
|
| ===================================================================
|
| --- ui/views/controls/label_unittest.cc (revision 200651)
|
| +++ ui/views/controls/label_unittest.cc (working copy)
|
| @@ -304,8 +304,9 @@
|
| gfx::Rect text_bounds;
|
| int flags;
|
| label.CalculateDrawStringParams(&paint_text, &text_bounds, &flags);
|
| - EXPECT_EQ(gfx::Canvas::FORCE_RTL_DIRECTIONALITY |
|
| - gfx::Canvas::TEXT_ALIGN_CENTER, flags);
|
| + EXPECT_EQ(gfx::Canvas::FORCE_RTL_DIRECTIONALITY,
|
| + flags & (gfx::Canvas::FORCE_RTL_DIRECTIONALITY |
|
| + gfx::Canvas::FORCE_LTR_DIRECTIONALITY));
|
|
|
| // Test text starts with LTR character.
|
| test_text = (WideToUTF16(L"ltr \x5d0\x5d1\x5d2 abc"));
|
| @@ -317,8 +318,9 @@
|
| required_size.height() + extra.height());
|
|
|
| label.CalculateDrawStringParams(&paint_text, &text_bounds, &flags);
|
| - EXPECT_EQ(gfx::Canvas::FORCE_LTR_DIRECTIONALITY |
|
| - gfx::Canvas::TEXT_ALIGN_CENTER, flags);
|
| + EXPECT_EQ(gfx::Canvas::FORCE_LTR_DIRECTIONALITY,
|
| + flags & (gfx::Canvas::FORCE_RTL_DIRECTIONALITY |
|
| + gfx::Canvas::FORCE_LTR_DIRECTIONALITY));
|
| }
|
|
|
| TEST(LabelTest, DrawSingleLineString) {
|
| @@ -351,8 +353,10 @@
|
| EXPECT_EQ(extra.height() / 2 , text_bounds.y());
|
| EXPECT_EQ(required_size.width(), text_bounds.width());
|
| EXPECT_EQ(required_size.height(), text_bounds.height());
|
| - EXPECT_EQ(gfx::Canvas::FORCE_LTR_DIRECTIONALITY |
|
| - gfx::Canvas::TEXT_ALIGN_CENTER, flags);
|
| + EXPECT_EQ(gfx::Canvas::TEXT_ALIGN_CENTER,
|
| + flags & (gfx::Canvas::TEXT_ALIGN_LEFT |
|
| + gfx::Canvas::TEXT_ALIGN_CENTER |
|
| + gfx::Canvas::TEXT_ALIGN_RIGHT));
|
|
|
| // Left aligned text.
|
| label.SetHorizontalAlignment(gfx::ALIGN_LEFT);
|
| @@ -365,8 +369,10 @@
|
| EXPECT_EQ(extra.height() / 2 , text_bounds.y());
|
| EXPECT_EQ(required_size.width(), text_bounds.width());
|
| EXPECT_EQ(required_size.height(), text_bounds.height());
|
| - EXPECT_EQ(gfx::Canvas::FORCE_LTR_DIRECTIONALITY |
|
| - gfx::Canvas::TEXT_ALIGN_LEFT, flags);
|
| + EXPECT_EQ(gfx::Canvas::TEXT_ALIGN_LEFT,
|
| + flags & (gfx::Canvas::TEXT_ALIGN_LEFT |
|
| + gfx::Canvas::TEXT_ALIGN_CENTER |
|
| + gfx::Canvas::TEXT_ALIGN_RIGHT));
|
|
|
| // Right aligned text.
|
| label.SetHorizontalAlignment(gfx::ALIGN_RIGHT);
|
| @@ -379,8 +385,10 @@
|
| EXPECT_EQ(extra.height() / 2 , text_bounds.y());
|
| EXPECT_EQ(required_size.width(), text_bounds.width());
|
| EXPECT_EQ(required_size.height(), text_bounds.height());
|
| - EXPECT_EQ(gfx::Canvas::FORCE_LTR_DIRECTIONALITY |
|
| - gfx::Canvas::TEXT_ALIGN_RIGHT, flags);
|
| + EXPECT_EQ(gfx::Canvas::TEXT_ALIGN_RIGHT,
|
| + flags & (gfx::Canvas::TEXT_ALIGN_LEFT |
|
| + gfx::Canvas::TEXT_ALIGN_CENTER |
|
| + gfx::Canvas::TEXT_ALIGN_RIGHT));
|
|
|
| // Test single line drawing with a border.
|
| gfx::Insets border(39, 34, 8, 96);
|
| @@ -410,8 +418,10 @@
|
| EXPECT_EQ(border.top() + extra.height() / 2 , text_bounds.y());
|
| EXPECT_EQ(required_size.width(), text_bounds.width());
|
| EXPECT_EQ(required_size.height(), text_bounds.height());
|
| - EXPECT_EQ(gfx::Canvas::FORCE_LTR_DIRECTIONALITY |
|
| - gfx::Canvas::TEXT_ALIGN_CENTER, flags);
|
| + EXPECT_EQ(gfx::Canvas::TEXT_ALIGN_CENTER,
|
| + flags & (gfx::Canvas::TEXT_ALIGN_LEFT |
|
| + gfx::Canvas::TEXT_ALIGN_CENTER |
|
| + gfx::Canvas::TEXT_ALIGN_RIGHT));
|
|
|
| // Left aligned text with border.
|
| label.SetHorizontalAlignment(gfx::ALIGN_LEFT);
|
| @@ -424,8 +434,10 @@
|
| EXPECT_EQ(border.top() + extra.height() / 2 , text_bounds.y());
|
| EXPECT_EQ(required_size.width(), text_bounds.width());
|
| EXPECT_EQ(required_size.height(), text_bounds.height());
|
| - EXPECT_EQ(gfx::Canvas::FORCE_LTR_DIRECTIONALITY |
|
| - gfx::Canvas::TEXT_ALIGN_LEFT, flags);
|
| + EXPECT_EQ(gfx::Canvas::TEXT_ALIGN_LEFT,
|
| + flags & (gfx::Canvas::TEXT_ALIGN_LEFT |
|
| + gfx::Canvas::TEXT_ALIGN_CENTER |
|
| + gfx::Canvas::TEXT_ALIGN_RIGHT));
|
|
|
| // Right aligned text.
|
| label.SetHorizontalAlignment(gfx::ALIGN_RIGHT);
|
| @@ -438,8 +450,10 @@
|
| EXPECT_EQ(border.top() + extra.height() / 2 , text_bounds.y());
|
| EXPECT_EQ(required_size.width(), text_bounds.width());
|
| EXPECT_EQ(required_size.height(), text_bounds.height());
|
| - EXPECT_EQ(gfx::Canvas::FORCE_LTR_DIRECTIONALITY |
|
| - gfx::Canvas::TEXT_ALIGN_RIGHT, flags);
|
| + EXPECT_EQ(gfx::Canvas::TEXT_ALIGN_RIGHT,
|
| + flags & (gfx::Canvas::TEXT_ALIGN_LEFT |
|
| + gfx::Canvas::TEXT_ALIGN_CENTER |
|
| + gfx::Canvas::TEXT_ALIGN_RIGHT));
|
| }
|
|
|
| // On Linux the underlying pango routines require a max height in order to
|
| @@ -615,7 +629,10 @@
|
| EXPECT_EQ(extra.height() / 2 , text_bounds.y());
|
| EXPECT_EQ(required_size.width(), text_bounds.width());
|
| EXPECT_EQ(required_size.height(), text_bounds.height());
|
| - EXPECT_EQ(gfx::Canvas::TEXT_ALIGN_CENTER, flags);
|
| + EXPECT_EQ(gfx::Canvas::TEXT_ALIGN_CENTER,
|
| + flags & (gfx::Canvas::TEXT_ALIGN_LEFT |
|
| + gfx::Canvas::TEXT_ALIGN_CENTER |
|
| + gfx::Canvas::TEXT_ALIGN_RIGHT));
|
|
|
| // ALIGN_LEFT label.
|
| label.SetHorizontalAlignment(gfx::ALIGN_LEFT);
|
| @@ -628,7 +645,10 @@
|
| EXPECT_EQ(extra.height() / 2 , text_bounds.y());
|
| EXPECT_EQ(required_size.width(), text_bounds.width());
|
| EXPECT_EQ(required_size.height(), text_bounds.height());
|
| - EXPECT_EQ(gfx::Canvas::TEXT_ALIGN_RIGHT, flags);
|
| + EXPECT_EQ(gfx::Canvas::TEXT_ALIGN_RIGHT,
|
| + flags & (gfx::Canvas::TEXT_ALIGN_LEFT |
|
| + gfx::Canvas::TEXT_ALIGN_CENTER |
|
| + gfx::Canvas::TEXT_ALIGN_RIGHT));
|
|
|
| // ALIGN_RIGHT label.
|
| label.SetHorizontalAlignment(gfx::ALIGN_RIGHT);
|
| @@ -641,7 +661,10 @@
|
| EXPECT_EQ(extra.height() / 2 , text_bounds.y());
|
| EXPECT_EQ(required_size.width(), text_bounds.width());
|
| EXPECT_EQ(required_size.height(), text_bounds.height());
|
| - EXPECT_EQ(gfx::Canvas::TEXT_ALIGN_LEFT, flags);
|
| + EXPECT_EQ(gfx::Canvas::TEXT_ALIGN_LEFT,
|
| + flags & (gfx::Canvas::TEXT_ALIGN_LEFT |
|
| + gfx::Canvas::TEXT_ALIGN_CENTER |
|
| + gfx::Canvas::TEXT_ALIGN_RIGHT));
|
|
|
|
|
| // Test single line drawing with a border.
|
| @@ -672,7 +695,10 @@
|
| EXPECT_EQ(border.top() + extra.height() / 2 , text_bounds.y());
|
| EXPECT_EQ(required_size.width(), text_bounds.width());
|
| EXPECT_EQ(required_size.height(), text_bounds.height());
|
| - EXPECT_EQ(gfx::Canvas::TEXT_ALIGN_CENTER, flags);
|
| + EXPECT_EQ(gfx::Canvas::TEXT_ALIGN_CENTER,
|
| + flags & (gfx::Canvas::TEXT_ALIGN_LEFT |
|
| + gfx::Canvas::TEXT_ALIGN_CENTER |
|
| + gfx::Canvas::TEXT_ALIGN_RIGHT));
|
|
|
| // ALIGN_LEFT text with border.
|
| label.SetHorizontalAlignment(gfx::ALIGN_LEFT);
|
| @@ -685,7 +711,10 @@
|
| EXPECT_EQ(border.top() + extra.height() / 2 , text_bounds.y());
|
| EXPECT_EQ(required_size.width(), text_bounds.width());
|
| EXPECT_EQ(required_size.height(), text_bounds.height());
|
| - EXPECT_EQ(gfx::Canvas::TEXT_ALIGN_RIGHT, flags);
|
| + EXPECT_EQ(gfx::Canvas::TEXT_ALIGN_RIGHT,
|
| + flags & (gfx::Canvas::TEXT_ALIGN_LEFT |
|
| + gfx::Canvas::TEXT_ALIGN_CENTER |
|
| + gfx::Canvas::TEXT_ALIGN_RIGHT));
|
|
|
| // ALIGN_RIGHT text.
|
| label.SetHorizontalAlignment(gfx::ALIGN_RIGHT);
|
| @@ -698,7 +727,10 @@
|
| EXPECT_EQ(border.top() + extra.height() / 2 , text_bounds.y());
|
| EXPECT_EQ(required_size.width(), text_bounds.width());
|
| EXPECT_EQ(required_size.height(), text_bounds.height());
|
| - EXPECT_EQ(gfx::Canvas::TEXT_ALIGN_LEFT, flags);
|
| + EXPECT_EQ(gfx::Canvas::TEXT_ALIGN_LEFT,
|
| + flags & (gfx::Canvas::TEXT_ALIGN_LEFT |
|
| + gfx::Canvas::TEXT_ALIGN_CENTER |
|
| + gfx::Canvas::TEXT_ALIGN_RIGHT));
|
|
|
| // Reset locale.
|
| base::i18n::SetICUDefaultLocale(locale);
|
|
|