Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(270)

Side by Side Diff: ui/views/border_unittest.cc

Issue 1517463003: Added comprehensive tests for views::Border. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Rebase. Created 4 years, 11 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
« no previous file with comments | « no previous file | ui/views/views.gyp » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
(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
OLDNEW
« no previous file with comments | « no previous file | ui/views/views.gyp » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698