1 /*
2 * Copyright 2011 Google Inc.
3 *
4 * Use of this source code is governed by a BSD-style license that can be
5 * found in the LICENSE file.
6 */
7
8 #include "include/core/SkRect.h"
9 #include "include/private/SkFloatingPoint.h"
10 #include "include/utils/SkRandom.h"
11 #include "tests/Test.h"
12
check_invalid(skiatest::Reporter * reporter,SkScalar l,SkScalar t,SkScalar r,SkScalar b)13 static void check_invalid(skiatest::Reporter* reporter,
14 SkScalar l, SkScalar t, SkScalar r, SkScalar b) {
15 SkRect rect;
16 rect.set(l, t, r, b);
17 REPORTER_ASSERT(reporter, !rect.isFinite());
18 }
19
20 // Tests that isFinite() will reject any rect with +/-inf values
21 // as one of its coordinates.
DEF_TEST(InfRect,reporter)22 DEF_TEST(InfRect, reporter) {
23 float inf = SK_FloatInfinity;
24 float nan = SK_FloatNaN;
25 SkASSERT(!(nan == nan));
26 SkScalar small = SkIntToScalar(10);
27 SkScalar big = SkIntToScalar(100);
28
29 REPORTER_ASSERT(reporter, SkRect::MakeEmpty().isFinite());
30
31 SkRect rect = SkRect::MakeXYWH(small, small, big, big);
32 REPORTER_ASSERT(reporter, rect.isFinite());
33
34 const SkScalar invalid[] = { nan, inf, -inf };
35 for (size_t i = 0; i < SK_ARRAY_COUNT(invalid); ++i) {
36 check_invalid(reporter, small, small, big, invalid[i]);
37 check_invalid(reporter, small, small, invalid[i], big);
38 check_invalid(reporter, small, invalid[i], big, big);
39 check_invalid(reporter, invalid[i], small, big, big);
40 }
41 }
42
43 // need tests for SkStrSearch
44