Chromium Code Reviews| Index: ui/gfx/canvas_unittest.cc |
| diff --git a/ui/gfx/canvas_unittest.cc b/ui/gfx/canvas_unittest.cc |
| index ba0a0bc9004088814fcb6482be3badbd75728597..a89bd99907fe1efe1b9b3c14188f1c06f48aa9cf 100644 |
| --- a/ui/gfx/canvas_unittest.cc |
| +++ b/ui/gfx/canvas_unittest.cc |
| @@ -2,6 +2,8 @@ |
| // Use of this source code is governed by a BSD-style license that can be |
| // found in the LICENSE file. |
| +#include <limits> |
| + |
| #include "base/utf_string_conversions.h" |
| #include "testing/gtest/include/gtest/gtest.h" |
| #include "ui/gfx/canvas.h" |
| @@ -9,29 +11,54 @@ |
| namespace gfx { |
| -TEST(CanvasTest, StringWidth) { |
| - const string16 text = UTF8ToUTF16("Test"); |
| - const int width = Canvas::GetStringWidth(text, Font()); |
| +/* Test fixture ***************************************************************/ |
| + |
| +class CanvasTest : public testing::Test { |
| + protected: |
| + int GetStringWidth(const char *text) { |
| + return Canvas::GetStringWidth(UTF8ToUTF16(text), font_); |
| + } |
| + |
| + gfx::Size SizeStringInt(const char *text, int width, int line_height) { |
| + string16 text16 = UTF8ToUTF16(text); |
| + int height = 0; |
| + int flags = (text16.find('\n') != string16::npos) ? Canvas::MULTI_LINE : 0; |
| + Canvas::SizeStringInt(text16, font_, &width, &height, line_height, flags); |
| + return gfx::Size(width, height); |
| + } |
| - EXPECT_GT(width, 0); |
| + private: |
| + gfx::Font font_; |
| +}; |
| + |
| +/* Test cases *****************************************************************/ |
| + |
| +TEST_F(CanvasTest, StringWidth) { |
| + EXPECT_GT(GetStringWidth("Test"), 0); |
| } |
| -TEST(CanvasTest, StringWidthEmptyString) { |
| - const string16 text = UTF8ToUTF16(""); |
| - const int width = Canvas::GetStringWidth(text, Font()); |
| +TEST_F(CanvasTest, StringWidthEmptyString) { |
| + EXPECT_EQ(0, GetStringWidth("")); |
| +} |
| - EXPECT_EQ(0, width); |
| +TEST_F(CanvasTest, StringSizeEmptyString) { |
| + gfx::Size size = SizeStringInt("", 0, -1); |
| + EXPECT_EQ(0, size.width()); |
| + EXPECT_GT(size.height(), 0); |
| } |
| -TEST(CanvasTest, StringSizeEmptyString) { |
| - const Font font; |
| - const string16 text = UTF8ToUTF16(""); |
| - int width = 0; |
| - int height = 0; |
| - Canvas::SizeStringInt(text, font, &width, &height, 0); |
| +// Line height only supported on SKIA. |
|
Jun Mukai
2013/04/17 17:08:57
Not so sure but it seems to be written as 'Skia',
dharcourt
2013/04/17 17:52:21
You're right. Fixed.
|
| +#if defined(OS_CHROMEOS) |
|
Jun Mukai
2013/04/17 17:08:57
build/common.gypi says that canvas_skia.cc is used
dharcourt
2013/04/17 17:52:21
Much better, thanks. Fixed.
|
| +#define MAYBE_StringSizeWithLineHeight StringSizeWithLineHeight |
| +#else |
| +#define MAYBE_StringSizeWithLineHeight DISABLED_StringSizeWithLineHeight |
| +#endif |
| - EXPECT_EQ(0, width); |
| - EXPECT_GT(height, 0); |
| +TEST_F(CanvasTest, MAYBE_StringSizeWithLineHeight) { |
| + gfx::Size one_line_size = SizeStringInt("Q", 0, -1); |
| + gfx::Size four_line_size = SizeStringInt("Q\nQ\nQ\nQ", 1000000, 1000); |
| + EXPECT_EQ(one_line_size.width(), four_line_size.width()); |
| + EXPECT_EQ(3 * 1000 + one_line_size.height(), four_line_size.height()); |
| } |
| } // namespace gfx |