| Index: tests/PathOpsSimplifyFailTest.cpp
|
| ===================================================================
|
| --- tests/PathOpsSimplifyFailTest.cpp (revision 0)
|
| +++ tests/PathOpsSimplifyFailTest.cpp (revision 0)
|
| @@ -0,0 +1,96 @@
|
| +/*
|
| + * Copyright 2013 Google Inc.
|
| + *
|
| + * Use of this source code is governed by a BSD-style license that can be
|
| + * found in the LICENSE file.
|
| + */
|
| +#include "SkPathOps.h"
|
| +#include "SkPath.h"
|
| +#include "SkPoint.h"
|
| +#include "Test.h"
|
| +
|
| +static const SkPoint nonFinitePts[] = {
|
| + { SK_ScalarInfinity, 0 },
|
| + { 0, SK_ScalarInfinity },
|
| + { SK_ScalarInfinity, SK_ScalarInfinity },
|
| + { SK_ScalarNegativeInfinity, 0},
|
| + { 0, SK_ScalarNegativeInfinity },
|
| + { SK_ScalarNegativeInfinity, SK_ScalarNegativeInfinity },
|
| + { SK_ScalarNegativeInfinity, SK_ScalarInfinity },
|
| + { SK_ScalarInfinity, SK_ScalarNegativeInfinity },
|
| + { SK_ScalarNaN, 0 },
|
| + { 0, SK_ScalarNaN },
|
| + { SK_ScalarNaN, SK_ScalarNaN },
|
| +};
|
| +
|
| +const size_t nonFinitePtsCount = sizeof(nonFinitePts) / sizeof(nonFinitePts[0]);
|
| +
|
| +static const SkPoint finitePts[] = {
|
| + { 0, 0 },
|
| + { SK_ScalarMax, 0 },
|
| + { 0, SK_ScalarMax },
|
| + { SK_ScalarMax, SK_ScalarMax },
|
| + { SK_ScalarMin, 0 },
|
| + { 0, SK_ScalarMin },
|
| + { SK_ScalarMin, SK_ScalarMin },
|
| +};
|
| +
|
| +const size_t finitePtsCount = sizeof(finitePts) / sizeof(finitePts[0]);
|
| +
|
| +static void PathOpsSimplifyFailTest(skiatest::Reporter* reporter) {
|
| + for (int index = 0; index < (int) (13 * nonFinitePtsCount * finitePtsCount); ++index) {
|
| + SkPath path;
|
| + int i = (int) (index % nonFinitePtsCount);
|
| + int f = (int) (index % finitePtsCount);
|
| + int g = (int) ((f + 1) % finitePtsCount);
|
| + switch (index % 13) {
|
| + case 0: path.lineTo(nonFinitePts[i]); break;
|
| + case 1: path.quadTo(nonFinitePts[i], nonFinitePts[i]); break;
|
| + case 2: path.quadTo(nonFinitePts[i], finitePts[f]); break;
|
| + case 3: path.quadTo(finitePts[f], nonFinitePts[i]); break;
|
| + case 4: path.cubicTo(nonFinitePts[i], finitePts[f], finitePts[f]); break;
|
| + case 5: path.cubicTo(finitePts[f], nonFinitePts[i], finitePts[f]); break;
|
| + case 6: path.cubicTo(finitePts[f], finitePts[f], nonFinitePts[i]); break;
|
| + case 7: path.cubicTo(nonFinitePts[i], nonFinitePts[i], finitePts[f]); break;
|
| + case 8: path.cubicTo(nonFinitePts[i], finitePts[f], nonFinitePts[i]); break;
|
| + case 9: path.cubicTo(finitePts[f], nonFinitePts[i], nonFinitePts[i]); break;
|
| + case 10: path.cubicTo(nonFinitePts[i], nonFinitePts[i], nonFinitePts[i]); break;
|
| + case 11: path.cubicTo(nonFinitePts[i], finitePts[f], finitePts[g]); break;
|
| + case 12: path.moveTo(nonFinitePts[i]); break;
|
| + }
|
| + SkPath result;
|
| + result.setFillType(SkPath::kWinding_FillType);
|
| + bool success = Simplify(path, &result);
|
| + REPORTER_ASSERT(reporter, !success);
|
| + REPORTER_ASSERT(reporter, result.isEmpty());
|
| + REPORTER_ASSERT(reporter, result.getFillType() == SkPath::kWinding_FillType);
|
| + reporter->bumpTestCount();
|
| + }
|
| + for (int index = 0; index < (int) (11 * finitePtsCount); ++index) {
|
| + SkPath path;
|
| + int f = (int) (index % finitePtsCount);
|
| + int g = (int) ((f + 1) % finitePtsCount);
|
| + switch (index % 11) {
|
| + case 0: path.lineTo(finitePts[f]); break;
|
| + case 1: path.quadTo(finitePts[f], finitePts[f]); break;
|
| + case 2: path.quadTo(finitePts[f], finitePts[g]); break;
|
| + case 3: path.quadTo(finitePts[g], finitePts[f]); break;
|
| + case 4: path.cubicTo(finitePts[f], finitePts[f], finitePts[f]); break;
|
| + case 5: path.cubicTo(finitePts[f], finitePts[f], finitePts[g]); break;
|
| + case 6: path.cubicTo(finitePts[f], finitePts[g], finitePts[f]); break;
|
| + case 7: path.cubicTo(finitePts[f], finitePts[g], finitePts[g]); break;
|
| + case 8: path.cubicTo(finitePts[g], finitePts[f], finitePts[f]); break;
|
| + case 9: path.cubicTo(finitePts[g], finitePts[f], finitePts[g]); break;
|
| + case 10: path.moveTo(finitePts[f]); break;
|
| + }
|
| + SkPath result;
|
| + result.setFillType(SkPath::kWinding_FillType);
|
| + bool success = Simplify(path, &result);
|
| + REPORTER_ASSERT(reporter, success);
|
| + REPORTER_ASSERT(reporter, result.getFillType() != SkPath::kWinding_FillType);
|
| + reporter->bumpTestCount();
|
| + }
|
| +}
|
| +
|
| +#include "TestClassDef.h"
|
| +DEFINE_TESTCLASS_SHORT(PathOpsSimplifyFailTest)
|
|
|