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

Unified 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 side-by-side diff with in-line comments
Download patch
« no previous file with comments | « no previous file | ui/views/views.gyp » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: ui/views/border_unittest.cc
diff --git a/ui/views/border_unittest.cc b/ui/views/border_unittest.cc
new file mode 100644
index 0000000000000000000000000000000000000000..008f81329617cec87014d85bf4d2f0b8236c0a2c
--- /dev/null
+++ b/ui/views/border_unittest.cc
@@ -0,0 +1,228 @@
+// 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.
+// Use of this source code is governed by a BSD-style license that can be
+// found in the LICENSE file.
+
+#include "ui/views/border.h"
+
+#include <vector>
+
+#include "base/memory/scoped_ptr.h"
+#include "testing/gtest/include/gtest/gtest.h"
+#include "third_party/skia/include/core/SkCanvas.h"
+#include "third_party/skia/include/core/SkPaint.h"
+#include "third_party/skia/include/core/SkRRect.h"
+#include "third_party/skia/include/core/SkRect.h"
+#include "ui/gfx/canvas.h"
+#include "ui/gfx/geometry/size.h"
+#include "ui/views/painter.h"
+#include "ui/views/test/views_test_base.h"
+#include "ui/views/view.h"
+
+using namespace testing;
+
+namespace {
+
+class MockCanvas : public SkCanvas {
+ public:
+ struct DrawRectCall {
+ DrawRectCall(const SkRect& rect, const SkPaint& paint)
+ : rect(rect), paint(paint) {}
+
+ SkRect rect;
+ SkPaint paint;
+ };
+
+ struct DrawRRectCall {
+ DrawRRectCall(const SkRRect& rrect, const SkPaint& paint)
+ : rrect(rrect), paint(paint) {}
+
+ SkRRect rrect;
+ SkPaint paint;
+ };
+
+ MockCanvas(int width, int height) : SkCanvas(width, height) {}
+
+ const std::vector<DrawRectCall>& draw_rect_calls() {
+ return draw_rect_calls_;
+ }
+
+ const std::vector<DrawRRectCall>& draw_rrect_calls() {
+ return draw_rrect_calls_;
+ }
+
+ // SkCanvas overrides:
+ void onDrawRect(const SkRect& rect, const SkPaint& paint) override {
+ draw_rect_calls_.push_back(DrawRectCall(rect, paint));
+ }
+
+ void onDrawRRect(const SkRRect& rrect, const SkPaint& paint) override {
+ draw_rrect_calls_.push_back(DrawRRectCall(rrect, paint));
+ }
+
+ private:
+ // Stores all the calls for querying by the test.
+ std::vector<DrawRectCall> draw_rect_calls_;
+ std::vector<DrawRRectCall> draw_rrect_calls_;
+
+ DISALLOW_COPY_AND_ASSIGN(MockCanvas);
+};
+
+// Simple Painter that will be used to test BorderPainter.
+class MockPainter : public views::Painter {
+ public:
+ 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.
+
+ // Gets the canvas given to the last call to Paint().
+ gfx::Canvas* given_canvas() const { return given_canvas_; }
+
+ // Gets the size given to the last call to Paint().
+ const gfx::Size& given_size() const { return given_size_; }
+
+ // Painter overrides:
+ gfx::Size GetMinimumSize() const override {
+ // Just return some arbitrary size.
+ return gfx::Size(60, 40);
+ }
+
+ void Paint(gfx::Canvas* canvas, const gfx::Size& size) override {
+ // Just record the arguments.
+ given_canvas_ = canvas;
+ given_size_ = size;
+ }
+
+ private:
+ gfx::Canvas* given_canvas_ = nullptr;
+ gfx::Size given_size_;
+
+ DISALLOW_COPY_AND_ASSIGN(MockPainter);
+};
+
+} // namespace
+
+namespace views {
+
+class BorderTest : public ViewsTestBase {
+ public:
+ void SetUp() override {
+ ViewsTestBase::SetUp();
+
+ view_.reset(new views::View());
+ view_->SetSize(gfx::Size(100, 50));
+ // The canvas should be much bigger than the view.
+ sk_canvas_.reset(new MockCanvas(1000, 500));
+ canvas_.reset(new gfx::Canvas(sk_canvas_.get(), 1.0f));
+ }
+
+ void TearDown() override {
+ ViewsTestBase::TearDown();
+
+ canvas_.reset();
+ sk_canvas_.reset();
+ view_.reset();
+ }
+
+ protected:
+ scoped_ptr<views::View> view_;
+ scoped_ptr<MockCanvas> sk_canvas_;
+ scoped_ptr<gfx::Canvas> canvas_;
+};
+
+TEST_F(BorderTest, NullBorder) {
+ scoped_ptr<Border> border(Border::NullBorder());
+ EXPECT_FALSE(border);
+}
+
+TEST_F(BorderTest, SolidBorder) {
+ scoped_ptr<Border> border(Border::CreateSolidBorder(3, SK_ColorBLUE));
+ EXPECT_EQ(gfx::Size(6, 6), border->GetMinimumSize());
+ EXPECT_EQ(gfx::Insets(3, 3, 3, 3), border->GetInsets());
+ border->Paint(*view_, canvas_.get());
+
+ auto draw_rect_calls = sk_canvas_->draw_rect_calls();
+ 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.
+ EXPECT_EQ(SkRect::MakeLTRB(0, 0, 100, 3), draw_rect_calls[0].rect);
+ EXPECT_EQ(SK_ColorBLUE, draw_rect_calls[0].paint.getColor());
+ EXPECT_EQ(SkRect::MakeLTRB(0, 3, 3, 47), draw_rect_calls[1].rect);
+ EXPECT_EQ(SK_ColorBLUE, draw_rect_calls[1].paint.getColor());
+ EXPECT_EQ(SkRect::MakeLTRB(0, 47, 100, 50), draw_rect_calls[2].rect);
+ EXPECT_EQ(SK_ColorBLUE, draw_rect_calls[2].paint.getColor());
+ EXPECT_EQ(SkRect::MakeLTRB(97, 3, 100, 47), draw_rect_calls[3].rect);
+ 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
+
+ EXPECT_TRUE(sk_canvas_->draw_rrect_calls().empty());
+}
+
+TEST_F(BorderTest, RoundedRectBorder) {
+ scoped_ptr<Border> border(
+ Border::CreateRoundedRectBorder(3, 4, SK_ColorBLUE));
+ EXPECT_EQ(gfx::Size(6, 6), border->GetMinimumSize());
+ EXPECT_EQ(gfx::Insets(3, 3, 3, 3), border->GetInsets());
+ border->Paint(*view_, canvas_.get());
+
+ SkRRect expected_rrect;
+ expected_rrect.setRectXY(SkRect::MakeLTRB(1.5, 1.5, 98.5, 48.5), 4, 4);
+ EXPECT_TRUE(sk_canvas_->draw_rect_calls().empty());
+ const auto& draw_rrect_calls = sk_canvas_->draw_rrect_calls();
+ 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.
+ EXPECT_EQ(expected_rrect, draw_rrect_calls[0].rrect);
+ EXPECT_EQ(3, draw_rrect_calls[0].paint.getStrokeWidth());
+ EXPECT_EQ(SK_ColorBLUE, draw_rrect_calls[0].paint.getColor());
+ EXPECT_EQ(SkPaint::kStroke_Style, draw_rrect_calls[0].paint.getStyle());
+ EXPECT_TRUE(draw_rrect_calls[0].paint.isAntiAlias());
+}
+
+TEST_F(BorderTest, EmptyBorder) {
+ const gfx::Insets kInsets(1, 2, 3, 4);
+
+ scoped_ptr<Border> border(Border::CreateEmptyBorder(
+ kInsets.top(), kInsets.left(), kInsets.bottom(), kInsets.right()));
+ // The EmptyBorder has no minimum size despite nonzero insets.
+ EXPECT_EQ(gfx::Size(), border->GetMinimumSize());
+ EXPECT_EQ(kInsets, border->GetInsets());
+ // Should have no effect.
+ border->Paint(*view_, canvas_.get());
+
+ scoped_ptr<Border> border2(Border::CreateEmptyBorder(kInsets));
+ EXPECT_EQ(kInsets, border2->GetInsets());
+}
+
+TEST_F(BorderTest, SolidSidedBorder) {
+ const gfx::Insets kInsets(1, 2, 3, 4);
+
+ scoped_ptr<Border> border(Border::CreateSolidSidedBorder(
+ kInsets.top(), kInsets.left(), kInsets.bottom(), kInsets.right(),
+ SK_ColorBLUE));
+ EXPECT_EQ(gfx::Size(6, 4), border->GetMinimumSize());
+ EXPECT_EQ(kInsets, border->GetInsets());
+ border->Paint(*view_, canvas_.get());
+
+ const auto& draw_rect_calls = sk_canvas_->draw_rect_calls();
+ EXPECT_EQ(4u, draw_rect_calls.size());
+ EXPECT_EQ(SkRect::MakeLTRB(0, 0, 100, 1), draw_rect_calls[0].rect);
+ EXPECT_EQ(SK_ColorBLUE, draw_rect_calls[0].paint.getColor());
+ EXPECT_EQ(SkRect::MakeLTRB(0, 1, 2, 47), draw_rect_calls[1].rect);
+ EXPECT_EQ(SK_ColorBLUE, draw_rect_calls[1].paint.getColor());
+ EXPECT_EQ(SkRect::MakeLTRB(0, 47, 100, 50), draw_rect_calls[2].rect);
+ EXPECT_EQ(SK_ColorBLUE, draw_rect_calls[2].paint.getColor());
+ EXPECT_EQ(SkRect::MakeLTRB(96, 1, 100, 47), draw_rect_calls[3].rect);
+ EXPECT_EQ(SK_ColorBLUE, draw_rect_calls[3].paint.getColor());
+
+ EXPECT_TRUE(sk_canvas_->draw_rrect_calls().empty());
+}
+
+TEST_F(BorderTest, BorderPainter) {
+ const gfx::Insets kInsets(1, 2, 3, 4);
+
+ MockPainter* painter = new MockPainter();
+ scoped_ptr<Border> border(Border::CreateBorderPainter(painter, kInsets));
+ EXPECT_EQ(gfx::Size(60, 40), border->GetMinimumSize());
+ EXPECT_EQ(kInsets, border->GetInsets());
+
+ border->Paint(*view_, canvas_.get());
+
+ // Expect that the Painter was called with our canvas and the view's size.
+ EXPECT_EQ(canvas_.get(), painter->given_canvas());
+ EXPECT_EQ(view_->size(), painter->given_size());
+}
+
+} // namespace views
« 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