| Index: ui/gfx/canvas_unittest.cc
|
| diff --git a/ui/gfx/canvas_unittest.cc b/ui/gfx/canvas_unittest.cc
|
| index ba0a0bc9004088814fcb6482be3badbd75728597..2d02725c35ead9a5c3ccdfc7ec2d994c0435ae5e 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,50 @@
|
|
|
| namespace gfx {
|
|
|
| -TEST(CanvasTest, StringWidth) {
|
| - const string16 text = UTF8ToUTF16("Test");
|
| - const int width = Canvas::GetStringWidth(text, Font());
|
| -
|
| - EXPECT_GT(width, 0);
|
| +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);
|
| + }
|
| +
|
| + private:
|
| + gfx::Font font_;
|
| +};
|
| +
|
| +TEST_F(CanvasTest, StringWidth) {
|
| + EXPECT_GT(GetStringWidth("Test"), 0);
|
| }
|
|
|
| -TEST(CanvasTest, StringWidthEmptyString) {
|
| - const string16 text = UTF8ToUTF16("");
|
| - const int width = Canvas::GetStringWidth(text, Font());
|
| -
|
| - EXPECT_EQ(0, width);
|
| +TEST_F(CanvasTest, StringWidthEmptyString) {
|
| + EXPECT_EQ(0, GetStringWidth(""));
|
| }
|
|
|
| -TEST(CanvasTest, StringSizeEmptyString) {
|
| - const Font font;
|
| - const string16 text = UTF8ToUTF16("");
|
| - int width = 0;
|
| - int height = 0;
|
| - Canvas::SizeStringInt(text, font, &width, &height, 0);
|
| +TEST_F(CanvasTest, StringSizeEmptyString) {
|
| + gfx::Size size = SizeStringInt("", 0, 0);
|
| + EXPECT_EQ(0, size.width());
|
| + EXPECT_GT(size.height(), 0);
|
| +}
|
|
|
| - EXPECT_EQ(0, width);
|
| - EXPECT_GT(height, 0);
|
| +// Line height is only supported on Skia.
|
| +#if defined(OS_MACOSX) || defined(OS_ANDROID)
|
| +#define MAYBE_StringSizeWithLineHeight DISABLED_StringSizeWithLineHeight
|
| +#else
|
| +#define MAYBE_StringSizeWithLineHeight StringSizeWithLineHeight
|
| +#endif
|
| +
|
| +TEST_F(CanvasTest, MAYBE_StringSizeWithLineHeight) {
|
| + gfx::Size one_line_size = SizeStringInt("Q", 0, 0);
|
| + 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
|
|
|