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()); |