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

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: Remove use of evil GMock and instead hand-roll custom mock classes. Created 5 years 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.
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
68 // Simple Painter that will be used to test BorderPainter.
69 class MockPainter : public views::Painter {
70 public:
71 // Gets the canvas given to the last call to Paint().
72 gfx::Canvas* given_canvas() const { return given_canvas_; }
73
74 // Gets the size given to the last call to Paint().
75 const gfx::Size& given_size() const { return given_size_; }
76
77 // Painter overrides:
78 gfx::Size GetMinimumSize() const override {
79 // Just return some arbitrary size.
80 return gfx::Size(60, 40);
81 }
82
83 void Paint(gfx::Canvas* canvas, const gfx::Size& size) override {
84 // Just record the arguments.
85 given_canvas_ = canvas;
86 given_size_ = size;
87 }
88
89 private:
90 gfx::Canvas* given_canvas_ = nullptr;
91 gfx::Size given_size_;
92 };
93
94 } // namespace
95
96 namespace views {
97
98 class BorderTest : public ViewsTestBase {
99 public:
100 void SetUp() override {
101 ViewsTestBase::SetUp();
102
103 view_.reset(new views::View());
104 view_->SetSize(gfx::Size(100, 50));
105 // The canvas should be much bigger than the view.
106 sk_canvas_.reset(new MockCanvas(1000, 500));
107 canvas_.reset(new gfx::Canvas(sk_canvas_.get(), 1.0f));
108 }
109
110 protected:
111 scoped_ptr<views::View> view_;
112 scoped_ptr<MockCanvas> sk_canvas_;
113 scoped_ptr<gfx::Canvas> canvas_;
114 };
115
116 TEST_F(BorderTest, NullBorder) {
117 scoped_ptr<Border> border(Border::NullBorder());
118 EXPECT_FALSE(border);
119 }
120
121 TEST_F(BorderTest, SolidBorder) {
122 scoped_ptr<Border> border(Border::CreateSolidBorder(3, SK_ColorBLUE));
123 EXPECT_EQ(gfx::Size(6, 6), border->GetMinimumSize());
124 EXPECT_EQ(gfx::Insets(3, 3, 3, 3), border->GetInsets());
125 border->Paint(*view_, canvas_.get());
126
127 auto draw_rect_calls = sk_canvas_->draw_rect_calls();
danakj 2015/12/10 20:01:27 const auto& please always qualify auto as much as
Matt Giuca 2015/12/11 00:03:21 Done.
128 EXPECT_EQ(4u, draw_rect_calls.size());
129 EXPECT_EQ(SkRect::MakeLTRB(0, 0, 100, 3), draw_rect_calls[0].rect);
130 EXPECT_EQ(SK_ColorBLUE, draw_rect_calls[0].paint.getColor());
131 EXPECT_EQ(SkRect::MakeLTRB(0, 3, 3, 47), draw_rect_calls[1].rect);
132 EXPECT_EQ(SK_ColorBLUE, draw_rect_calls[1].paint.getColor());
133 EXPECT_EQ(SkRect::MakeLTRB(0, 47, 100, 50), draw_rect_calls[2].rect);
134 EXPECT_EQ(SK_ColorBLUE, draw_rect_calls[2].paint.getColor());
135 EXPECT_EQ(SkRect::MakeLTRB(97, 3, 100, 47), draw_rect_calls[3].rect);
136 EXPECT_EQ(SK_ColorBLUE, draw_rect_calls[3].paint.getColor());
137
138 EXPECT_TRUE(sk_canvas_->draw_rrect_calls().empty());
139 }
140
141 // TODO(mgiuca): Fails due to http://crbug.com/565801.
142 TEST_F(BorderTest, DISABLED_RoundedRectBorder) {
143 scoped_ptr<Border> border(
144 Border::CreateRoundedRectBorder(3, 4, SK_ColorBLUE));
145 EXPECT_EQ(gfx::Size(6, 6), border->GetMinimumSize());
146 EXPECT_EQ(gfx::Insets(3, 3, 3, 3), border->GetInsets());
147 border->Paint(*view_, canvas_.get());
148
149 SkRRect expected_rrect;
150 expected_rrect.setRectXY(SkRect::MakeLTRB(1.5, 1.5, 98.5, 48.5), 4, 4);
151 EXPECT_TRUE(sk_canvas_->draw_rect_calls().empty());
152 auto draw_rrect_calls = sk_canvas_->draw_rrect_calls();
danakj 2015/12/10 20:01:27 const auto&
Matt Giuca 2015/12/11 00:03:21 Done.
153 EXPECT_EQ(1u, draw_rrect_calls.size());
154 EXPECT_EQ(expected_rrect, draw_rrect_calls[0].rrect);
155 EXPECT_EQ(3, draw_rrect_calls[0].paint.getStrokeWidth());
156 EXPECT_EQ(SK_ColorBLUE, draw_rrect_calls[0].paint.getColor());
157 EXPECT_EQ(SkPaint::kStroke_Style, draw_rrect_calls[0].paint.getStyle());
158 EXPECT_TRUE(draw_rrect_calls[0].paint.isAntiAlias());
159 }
160
161 TEST_F(BorderTest, EmptyBorder) {
162 const gfx::Insets kInsets(1, 2, 3, 4);
163
164 scoped_ptr<Border> border(Border::CreateEmptyBorder(
165 kInsets.top(), kInsets.left(), kInsets.bottom(), kInsets.right()));
166 // The EmptyBorder has no minimum size despite nonzero insets.
167 EXPECT_EQ(gfx::Size(), border->GetMinimumSize());
168 EXPECT_EQ(kInsets, border->GetInsets());
169 // Should have no effect.
170 border->Paint(*view_, canvas_.get());
171
172 scoped_ptr<Border> border2(Border::CreateEmptyBorder(kInsets));
173 EXPECT_EQ(kInsets, border2->GetInsets());
174 }
175
176 TEST_F(BorderTest, SolidSidedBorder) {
177 const gfx::Insets kInsets(1, 2, 3, 4);
178
179 scoped_ptr<Border> border(Border::CreateSolidSidedBorder(
180 kInsets.top(), kInsets.left(), kInsets.bottom(), kInsets.right(),
181 SK_ColorBLUE));
182 EXPECT_EQ(gfx::Size(6, 4), border->GetMinimumSize());
183 EXPECT_EQ(kInsets, border->GetInsets());
184 border->Paint(*view_, canvas_.get());
185
186 auto draw_rect_calls = sk_canvas_->draw_rect_calls();
187 EXPECT_EQ(4u, draw_rect_calls.size());
188 EXPECT_EQ(SkRect::MakeLTRB(0, 0, 100, 1), draw_rect_calls[0].rect);
189 EXPECT_EQ(SK_ColorBLUE, draw_rect_calls[0].paint.getColor());
190 EXPECT_EQ(SkRect::MakeLTRB(0, 1, 2, 47), draw_rect_calls[1].rect);
191 EXPECT_EQ(SK_ColorBLUE, draw_rect_calls[1].paint.getColor());
192 EXPECT_EQ(SkRect::MakeLTRB(0, 47, 100, 50), draw_rect_calls[2].rect);
193 EXPECT_EQ(SK_ColorBLUE, draw_rect_calls[2].paint.getColor());
194 EXPECT_EQ(SkRect::MakeLTRB(96, 1, 100, 47), draw_rect_calls[3].rect);
195 EXPECT_EQ(SK_ColorBLUE, draw_rect_calls[3].paint.getColor());
196
197 EXPECT_TRUE(sk_canvas_->draw_rrect_calls().empty());
198 }
199
200 TEST_F(BorderTest, BorderPainter) {
201 const gfx::Insets kInsets(1, 2, 3, 4);
202
203 MockPainter* painter = new MockPainter();
204 scoped_ptr<Border> border(Border::CreateBorderPainter(painter, kInsets));
205 EXPECT_EQ(gfx::Size(60, 40), border->GetMinimumSize());
206 EXPECT_EQ(kInsets, border->GetInsets());
207
208 border->Paint(*view_, canvas_.get());
209
210 // Expect that the Painter was called with our canvas and the view's size.
211 EXPECT_EQ(canvas_.get(), painter->given_canvas());
212 EXPECT_EQ(view_->size(), painter->given_size());
213 }
214
215 } // 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