diff options
author | Mike Reed <reed@google.com> | 2018-05-30 16:32:33 -0400 |
---|---|---|
committer | Skia Commit-Bot <skia-commit-bot@chromium.org> | 2018-06-04 15:47:19 +0000 |
commit | 5059541dcc1950107ffeed930f85d986f4b5d613 (patch) | |
tree | 2c8cfe04a155f3163c7cbc37710d8b599dd65023 /tests/PathTest.cpp | |
parent | ad445ce8416474056fded4fa912dae7f53e462ce (diff) |
need conservative bounds for triangles due to SkFixed drift in SkEdge
Bug: oss-fuzz:8018
Change-Id: I09456f906b7eb89f74ffd2c484bc6e30e029bfbb
Reviewed-on: https://skia-review.googlesource.com/131021
Reviewed-by: Cary Clark <caryclark@google.com>
Auto-Submit: Mike Reed <reed@google.com>
Commit-Queue: Mike Reed <reed@google.com>
Diffstat (limited to 'tests/PathTest.cpp')
-rw-r--r-- | tests/PathTest.cpp | 34 |
1 files changed, 31 insertions, 3 deletions
diff --git a/tests/PathTest.cpp b/tests/PathTest.cpp index 45ebd45e31..6cf5dfba13 100644 --- a/tests/PathTest.cpp +++ b/tests/PathTest.cpp @@ -5053,6 +5053,20 @@ DEF_TEST(Path_isRect, reporter) { } #include "SkVertices.h" +static void draw_triangle(SkCanvas* canvas, const SkPoint pts[]) { + // draw in different ways, looking for an assert + + { + SkPath path; + path.addPoly(pts, 3, false); + canvas->drawPath(path, SkPaint()); + } + + const SkColor colors[] = { SK_ColorBLACK, SK_ColorBLACK, SK_ColorBLACK }; + auto v = SkVertices::MakeCopy(SkVertices::kTriangles_VertexMode, 3, pts, nullptr, colors); + canvas->drawVertices(v, SkBlendMode::kSrcOver, SkPaint()); +} + DEF_TEST(triangle_onehalf, reporter) { auto surface(SkSurface::MakeRasterN32Premul(100, 100)); @@ -5061,8 +5075,22 @@ DEF_TEST(triangle_onehalf, reporter) { { 0.499402374f, 7.88207579f }, { 10.2363272f, 0.49999997f } }; - const SkColor colors[] = { SK_ColorBLACK, SK_ColorBLACK, SK_ColorBLACK }; + draw_triangle(surface->getCanvas(), pts); +} - auto v = SkVertices::MakeCopy(SkVertices::kTriangles_VertexMode, 3, pts, nullptr, colors); - surface->getCanvas()->drawVertices(v, SkBlendMode::kSrcOver, SkPaint()); +DEF_TEST(triangle_big, reporter) { + auto surface(SkSurface::MakeRasterN32Premul(4, 4304)); + + // The first two points, when sent through our fixed-point SkEdge, can walk negative beyond + // -0.5 due to accumulated += error of the slope. We have since make the bounds calculation + // be conservative, so we invoke clipping if we get in this situation. + // This test was added to demonstrate the need for this conservative bounds calc. + // (found by a fuzzer) + const SkPoint pts[] = { + { 0.327190518f, -114.945152f }, + { -0.5f, 1.00003874f }, + { 0.666425824f, 4304.26172f }, + }; + draw_triangle(surface->getCanvas(), pts); } + |