Chromium Code Reviews| OLD | NEW |
|---|---|
| (Empty) | |
| 1 // Copyright 2015 The Chromium Authors. All rights reserved. | |
|
sadrul
2016/05/31 17:31:31
This should be updated I guess.
Matt Giuca
2016/06/03 03:38:42
Done.
| |
| 2 // Use of this source code is governed by a BSD-style license that can be | |
| 3 // found in the LICENSE file. | |
| 4 | |
| 5 #include "ui/views/border.h" | |
| 6 | |
| 7 #include <vector> | |
| 8 | |
| 9 #include "base/memory/scoped_ptr.h" | |
| 10 #include "testing/gtest/include/gtest/gtest.h" | |
| 11 #include "third_party/skia/include/core/SkCanvas.h" | |
| 12 #include "third_party/skia/include/core/SkPaint.h" | |
| 13 #include "third_party/skia/include/core/SkRRect.h" | |
| 14 #include "third_party/skia/include/core/SkRect.h" | |
| 15 #include "ui/gfx/canvas.h" | |
| 16 #include "ui/gfx/geometry/size.h" | |
| 17 #include "ui/views/painter.h" | |
| 18 #include "ui/views/test/views_test_base.h" | |
| 19 #include "ui/views/view.h" | |
| 20 | |
| 21 using namespace testing; | |
| 22 | |
| 23 namespace { | |
| 24 | |
| 25 class MockCanvas : public SkCanvas { | |
| 26 public: | |
| 27 struct DrawRectCall { | |
| 28 DrawRectCall(const SkRect& rect, const SkPaint& paint) | |
| 29 : rect(rect), paint(paint) {} | |
| 30 | |
| 31 SkRect rect; | |
| 32 SkPaint paint; | |
| 33 }; | |
| 34 | |
| 35 struct DrawRRectCall { | |
| 36 DrawRRectCall(const SkRRect& rrect, const SkPaint& paint) | |
| 37 : rrect(rrect), paint(paint) {} | |
| 38 | |
| 39 SkRRect rrect; | |
| 40 SkPaint paint; | |
| 41 }; | |
| 42 | |
| 43 MockCanvas(int width, int height) : SkCanvas(width, height) {} | |
| 44 | |
| 45 const std::vector<DrawRectCall>& draw_rect_calls() { | |
| 46 return draw_rect_calls_; | |
| 47 } | |
| 48 | |
| 49 const std::vector<DrawRRectCall>& draw_rrect_calls() { | |
| 50 return draw_rrect_calls_; | |
| 51 } | |
| 52 | |
| 53 // SkCanvas overrides: | |
| 54 void onDrawRect(const SkRect& rect, const SkPaint& paint) override { | |
| 55 draw_rect_calls_.push_back(DrawRectCall(rect, paint)); | |
| 56 } | |
| 57 | |
| 58 void onDrawRRect(const SkRRect& rrect, const SkPaint& paint) override { | |
| 59 draw_rrect_calls_.push_back(DrawRRectCall(rrect, paint)); | |
| 60 } | |
| 61 | |
| 62 private: | |
| 63 // Stores all the calls for querying by the test. | |
| 64 std::vector<DrawRectCall> draw_rect_calls_; | |
| 65 std::vector<DrawRRectCall> draw_rrect_calls_; | |
| 66 | |
| 67 DISALLOW_COPY_AND_ASSIGN(MockCanvas); | |
| 68 }; | |
| 69 | |
| 70 // Simple Painter that will be used to test BorderPainter. | |
| 71 class MockPainter : public views::Painter { | |
| 72 public: | |
| 73 MockPainter() : views::Painter() {} | |
|
sadrul
2016/05/31 17:31:30
Is the : views::Painter() bit necessary?
Matt Giuca
2016/06/03 03:38:42
Done.
| |
| 74 | |
| 75 // Gets the canvas given to the last call to Paint(). | |
| 76 gfx::Canvas* given_canvas() const { return given_canvas_; } | |
| 77 | |
| 78 // Gets the size given to the last call to Paint(). | |
| 79 const gfx::Size& given_size() const { return given_size_; } | |
| 80 | |
| 81 // Painter overrides: | |
| 82 gfx::Size GetMinimumSize() const override { | |
| 83 // Just return some arbitrary size. | |
| 84 return gfx::Size(60, 40); | |
| 85 } | |
| 86 | |
| 87 void Paint(gfx::Canvas* canvas, const gfx::Size& size) override { | |
| 88 // Just record the arguments. | |
| 89 given_canvas_ = canvas; | |
| 90 given_size_ = size; | |
| 91 } | |
| 92 | |
| 93 private: | |
| 94 gfx::Canvas* given_canvas_ = nullptr; | |
| 95 gfx::Size given_size_; | |
| 96 | |
| 97 DISALLOW_COPY_AND_ASSIGN(MockPainter); | |
| 98 }; | |
| 99 | |
| 100 } // namespace | |
| 101 | |
| 102 namespace views { | |
| 103 | |
| 104 class BorderTest : public ViewsTestBase { | |
| 105 public: | |
| 106 void SetUp() override { | |
| 107 ViewsTestBase::SetUp(); | |
| 108 | |
| 109 view_.reset(new views::View()); | |
| 110 view_->SetSize(gfx::Size(100, 50)); | |
| 111 // The canvas should be much bigger than the view. | |
| 112 sk_canvas_.reset(new MockCanvas(1000, 500)); | |
| 113 canvas_.reset(new gfx::Canvas(sk_canvas_.get(), 1.0f)); | |
| 114 } | |
| 115 | |
| 116 void TearDown() override { | |
| 117 ViewsTestBase::TearDown(); | |
| 118 | |
| 119 canvas_.reset(); | |
| 120 sk_canvas_.reset(); | |
| 121 view_.reset(); | |
| 122 } | |
| 123 | |
| 124 protected: | |
| 125 scoped_ptr<views::View> view_; | |
| 126 scoped_ptr<MockCanvas> sk_canvas_; | |
| 127 scoped_ptr<gfx::Canvas> canvas_; | |
| 128 }; | |
| 129 | |
| 130 TEST_F(BorderTest, NullBorder) { | |
| 131 scoped_ptr<Border> border(Border::NullBorder()); | |
| 132 EXPECT_FALSE(border); | |
| 133 } | |
| 134 | |
| 135 TEST_F(BorderTest, SolidBorder) { | |
| 136 scoped_ptr<Border> border(Border::CreateSolidBorder(3, SK_ColorBLUE)); | |
| 137 EXPECT_EQ(gfx::Size(6, 6), border->GetMinimumSize()); | |
| 138 EXPECT_EQ(gfx::Insets(3, 3, 3, 3), border->GetInsets()); | |
| 139 border->Paint(*view_, canvas_.get()); | |
| 140 | |
| 141 auto draw_rect_calls = sk_canvas_->draw_rect_calls(); | |
| 142 EXPECT_EQ(4u, draw_rect_calls.size()); | |
|
sadrul
2016/05/31 17:31:30
ASSERT_EQ
Matt Giuca
2016/06/03 03:38:42
Done.
| |
| 143 EXPECT_EQ(SkRect::MakeLTRB(0, 0, 100, 3), draw_rect_calls[0].rect); | |
| 144 EXPECT_EQ(SK_ColorBLUE, draw_rect_calls[0].paint.getColor()); | |
| 145 EXPECT_EQ(SkRect::MakeLTRB(0, 3, 3, 47), draw_rect_calls[1].rect); | |
| 146 EXPECT_EQ(SK_ColorBLUE, draw_rect_calls[1].paint.getColor()); | |
| 147 EXPECT_EQ(SkRect::MakeLTRB(0, 47, 100, 50), draw_rect_calls[2].rect); | |
| 148 EXPECT_EQ(SK_ColorBLUE, draw_rect_calls[2].paint.getColor()); | |
| 149 EXPECT_EQ(SkRect::MakeLTRB(97, 3, 100, 47), draw_rect_calls[3].rect); | |
| 150 EXPECT_EQ(SK_ColorBLUE, draw_rect_calls[3].paint.getColor()); | |
|
sadrul
2016/05/31 17:31:31
Can you change this so the ordering of the calls d
Matt Giuca
2016/06/03 03:38:42
Done. (Required operator< in the DrawRectCall and
| |
| 151 | |
| 152 EXPECT_TRUE(sk_canvas_->draw_rrect_calls().empty()); | |
| 153 } | |
| 154 | |
| 155 TEST_F(BorderTest, RoundedRectBorder) { | |
| 156 scoped_ptr<Border> border( | |
| 157 Border::CreateRoundedRectBorder(3, 4, SK_ColorBLUE)); | |
| 158 EXPECT_EQ(gfx::Size(6, 6), border->GetMinimumSize()); | |
| 159 EXPECT_EQ(gfx::Insets(3, 3, 3, 3), border->GetInsets()); | |
| 160 border->Paint(*view_, canvas_.get()); | |
| 161 | |
| 162 SkRRect expected_rrect; | |
| 163 expected_rrect.setRectXY(SkRect::MakeLTRB(1.5, 1.5, 98.5, 48.5), 4, 4); | |
| 164 EXPECT_TRUE(sk_canvas_->draw_rect_calls().empty()); | |
| 165 const auto& draw_rrect_calls = sk_canvas_->draw_rrect_calls(); | |
| 166 EXPECT_EQ(1u, draw_rrect_calls.size()); | |
|
sadrul
2016/05/31 17:31:30
ASSERT_EQ
Matt Giuca
2016/06/03 03:38:42
Done.
| |
| 167 EXPECT_EQ(expected_rrect, draw_rrect_calls[0].rrect); | |
| 168 EXPECT_EQ(3, draw_rrect_calls[0].paint.getStrokeWidth()); | |
| 169 EXPECT_EQ(SK_ColorBLUE, draw_rrect_calls[0].paint.getColor()); | |
| 170 EXPECT_EQ(SkPaint::kStroke_Style, draw_rrect_calls[0].paint.getStyle()); | |
| 171 EXPECT_TRUE(draw_rrect_calls[0].paint.isAntiAlias()); | |
| 172 } | |
| 173 | |
| 174 TEST_F(BorderTest, EmptyBorder) { | |
| 175 const gfx::Insets kInsets(1, 2, 3, 4); | |
| 176 | |
| 177 scoped_ptr<Border> border(Border::CreateEmptyBorder( | |
| 178 kInsets.top(), kInsets.left(), kInsets.bottom(), kInsets.right())); | |
| 179 // The EmptyBorder has no minimum size despite nonzero insets. | |
| 180 EXPECT_EQ(gfx::Size(), border->GetMinimumSize()); | |
| 181 EXPECT_EQ(kInsets, border->GetInsets()); | |
| 182 // Should have no effect. | |
| 183 border->Paint(*view_, canvas_.get()); | |
| 184 | |
| 185 scoped_ptr<Border> border2(Border::CreateEmptyBorder(kInsets)); | |
| 186 EXPECT_EQ(kInsets, border2->GetInsets()); | |
| 187 } | |
| 188 | |
| 189 TEST_F(BorderTest, SolidSidedBorder) { | |
| 190 const gfx::Insets kInsets(1, 2, 3, 4); | |
| 191 | |
| 192 scoped_ptr<Border> border(Border::CreateSolidSidedBorder( | |
| 193 kInsets.top(), kInsets.left(), kInsets.bottom(), kInsets.right(), | |
| 194 SK_ColorBLUE)); | |
| 195 EXPECT_EQ(gfx::Size(6, 4), border->GetMinimumSize()); | |
| 196 EXPECT_EQ(kInsets, border->GetInsets()); | |
| 197 border->Paint(*view_, canvas_.get()); | |
| 198 | |
| 199 const auto& draw_rect_calls = sk_canvas_->draw_rect_calls(); | |
| 200 EXPECT_EQ(4u, draw_rect_calls.size()); | |
| 201 EXPECT_EQ(SkRect::MakeLTRB(0, 0, 100, 1), draw_rect_calls[0].rect); | |
| 202 EXPECT_EQ(SK_ColorBLUE, draw_rect_calls[0].paint.getColor()); | |
| 203 EXPECT_EQ(SkRect::MakeLTRB(0, 1, 2, 47), draw_rect_calls[1].rect); | |
| 204 EXPECT_EQ(SK_ColorBLUE, draw_rect_calls[1].paint.getColor()); | |
| 205 EXPECT_EQ(SkRect::MakeLTRB(0, 47, 100, 50), draw_rect_calls[2].rect); | |
| 206 EXPECT_EQ(SK_ColorBLUE, draw_rect_calls[2].paint.getColor()); | |
| 207 EXPECT_EQ(SkRect::MakeLTRB(96, 1, 100, 47), draw_rect_calls[3].rect); | |
| 208 EXPECT_EQ(SK_ColorBLUE, draw_rect_calls[3].paint.getColor()); | |
| 209 | |
| 210 EXPECT_TRUE(sk_canvas_->draw_rrect_calls().empty()); | |
| 211 } | |
| 212 | |
| 213 TEST_F(BorderTest, BorderPainter) { | |
| 214 const gfx::Insets kInsets(1, 2, 3, 4); | |
| 215 | |
| 216 MockPainter* painter = new MockPainter(); | |
| 217 scoped_ptr<Border> border(Border::CreateBorderPainter(painter, kInsets)); | |
| 218 EXPECT_EQ(gfx::Size(60, 40), border->GetMinimumSize()); | |
| 219 EXPECT_EQ(kInsets, border->GetInsets()); | |
| 220 | |
| 221 border->Paint(*view_, canvas_.get()); | |
| 222 | |
| 223 // Expect that the Painter was called with our canvas and the view's size. | |
| 224 EXPECT_EQ(canvas_.get(), painter->given_canvas()); | |
| 225 EXPECT_EQ(view_->size(), painter->given_size()); | |
| 226 } | |
| 227 | |
| 228 } // namespace views | |
| OLD | NEW |