Index: ui/base/text/text_elider_unittest.cc |
diff --git a/ui/base/text/text_elider_unittest.cc b/ui/base/text/text_elider_unittest.cc |
index 217170c812c0ab22813390f61dec2b9b660e8e2a..aad021eb72ad7c0fc061f0da7c74533a1a84f977 100644 |
--- a/ui/base/text/text_elider_unittest.cc |
+++ b/ui/base/text/text_elider_unittest.cc |
@@ -55,6 +55,86 @@ void RunUrlTest(Testcase* testcases, size_t num_testcases) { |
} // namespace |
+TEST(TextEliderTest, ElideEmail) { |
+ const std::string kEllipsisStr(kEllipsis); |
+ |
+ // Test emails and their expected elided forms (from which the available |
+ // widths will be derived). |
+ // For elided forms in which both the username and domain must be elided: |
+ // the result (how many characters are left on each side) can be font |
+ // dependent. To avoid this, the username is prefixed with the characters |
+ // expected to remain in the domain. |
+ Testcase testcases[] = { |
+ {"g@g.c", "g@g.c"}, |
+ {"g@g.c", kEllipsisStr}, |
+ {"ga@co.ca", "ga@c" + kEllipsisStr + "a"}, |
+ {"short@small.com", "s" + kEllipsisStr + "@s" + kEllipsisStr}, |
+ {"short@small.com", "s" + kEllipsisStr + "@small.com"}, |
+ {"short@longbutlotsofspace.com", "short@longbutlotsofspace.com"}, |
+ {"short@longbutnotverymuchspace.com", |
+ "short@long" + kEllipsisStr + ".com"}, |
+ {"la_short@longbutverytightspace.ca", |
+ "la" + kEllipsisStr + "@l" + kEllipsisStr + "a"}, |
+ {"longusername@gmail.com", "long" + kEllipsisStr + "@gmail.com"}, |
+ {"elidetothemax@justfits.com", "e" + kEllipsisStr + "@justfits.com"}, |
+ {"thatom_somelongemail@thatdoesntfit.com", |
+ "thatom" + kEllipsisStr + "@tha" + kEllipsisStr + "om"}, |
+ {"namefits@butthedomaindoesnt.com", |
+ "namefits@butthedo" + kEllipsisStr + "snt.com"}, |
+ {"widthtootight@nospace.com", kEllipsisStr}, |
+ {"nospaceforusername@l", kEllipsisStr}, |
+ {"little@littlespace.com", "l" + kEllipsisStr + "@l" + kEllipsisStr}, |
+ {"l@llllllllllllllllllllllll.com", "l@lllll" + kEllipsisStr + ".com"}, |
gab
2012/03/13 20:40:34
It failed on Chromium OS as it seems width("...")
|
+ {"messed\"up@whyanat\"++@notgoogley.com", |
+ "messed\"up@whyanat\"++@notgoogley.com"}, |
+ {"messed\"up@whyanat\"++@notgoogley.com", |
+ "messed\"up@why" + kEllipsisStr + "@notgoogley.com"}, |
+ {"noca_messed\"up@whyanat\"++@notgoogley.ca", |
+ "noca" + kEllipsisStr + "@no" + kEllipsisStr + "ca"}, |
+ {"at\"@@@@@@@@@...@@.@.@.@@@\"@madness.com", |
+ "at\"@@@@@@@@@...@@.@." + kEllipsisStr + "@madness.com"}, |
+ // Special case: "m..." takes more than half of the available width; thus |
+ // the domain must elide to "l..." and not "l...l" as it must allow enough |
+ // space for the minimal username elision although its half of the |
+ // available width would normally allow it to elide to "l...l". |
+ {"mmmmm@llllllllll", "m" + kEllipsisStr + "@l" + kEllipsisStr}, |
+ }; |
+ |
+ const gfx::Font font; |
+ for (size_t i = 0; i < arraysize(testcases); ++i) { |
+ const string16 expected_output = UTF8ToUTF16(testcases[i].output); |
+ EXPECT_EQ(expected_output, |
+ ElideEmail(UTF8ToUTF16(testcases[i].input), |
+ font, |
+ font.GetStringWidth(expected_output))); |
+ } |
+} |
+ |
+TEST(TextEliderTest, ElideEmailMoreSpace) { |
+ const int test_width_factors[] = { |
+ 100, |
+ 10000, |
+ 1000000, |
+ }; |
+ const std::string test_emails[] = { |
+ "a@c", |
+ "test@email.com", |
+ "short@verysuperdupperlongdomain.com", |
+ "supermegalongusername@withasuperlonnnggggdomain.gouv.qc.ca", |
+ }; |
+ |
+ const gfx::Font font; |
+ for (size_t i = 0; i < arraysize(test_width_factors); ++i) { |
+ const int test_width = test_width_factors[i] * |
+ font.GetAverageCharacterWidth(); |
+ for (size_t j = 0; j < arraysize(test_emails); ++j) { |
+ // Extra space is available: the email should not be elided. |
+ const string16 test_email = UTF8ToUTF16(test_emails[j]); |
+ EXPECT_EQ(test_email, ElideEmail(test_email, font, test_width)); |
+ } |
+ } |
+} |
+ |
// Test eliding of commonplace URLs. |
TEST(TextEliderTest, TestGeneralEliding) { |
const std::string kEllipsisStr(kEllipsis); |