Add unit test for SkRect::hasValidCoordinates().

git-svn-id: http://skia.googlecode.com/svn/trunk@765 2bbb7eff-a529-9590-31e7-b0007b416f81
diff --git a/tests/InfRectTest.cpp b/tests/InfRectTest.cpp
new file mode 100644
index 0000000..fc9c6eb
--- /dev/null
+++ b/tests/InfRectTest.cpp
@@ -0,0 +1,39 @@
+#include "Test.h"
+#include "SkRect.h"
+
+// Tests that hasValidCoordinates() will reject any rect with +/-inf values
+// as one of its coordinates.
+static void TestInfRect(skiatest::Reporter* reporter) {
+
+    SkRect rect = SkRect::MakeXYWH(10.0f, 10.0f, 100.0f, 100.0f);
+    REPORTER_ASSERT(reporter, rect.hasValidCoordinates());
+
+    rect = SkRect::MakeXYWH(10.0f, 10.0f, 100.0f, 1.0f/0.0f); // Make 'inf' value without numeric_limits.
+    REPORTER_ASSERT(reporter, !rect.hasValidCoordinates());
+
+    rect = SkRect::MakeXYWH(10.0f, 10.0f, 1.0f/0.0f, 100.0f);
+    REPORTER_ASSERT(reporter, !rect.hasValidCoordinates());
+
+    rect = SkRect::MakeXYWH(1.0f/0.0f, 10.0f, 100.0f, 100.0f);
+    REPORTER_ASSERT(reporter, !rect.hasValidCoordinates());
+
+    rect = SkRect::MakeXYWH(10.0f, 1.0f/0.0f, 100.0f, 100.0f);
+    REPORTER_ASSERT(reporter, !rect.hasValidCoordinates());
+
+    rect = SkRect::MakeXYWH(10.0f, 10.0f, 100.0f, -1.0f/0.0f);
+    REPORTER_ASSERT(reporter, !rect.hasValidCoordinates());
+
+    rect = SkRect::MakeXYWH(10.0f, 10.0f, -1.0f/0.0f, 100.0f);
+    REPORTER_ASSERT(reporter, !rect.hasValidCoordinates());
+
+    rect = SkRect::MakeXYWH(-1.0f/0.0f, 10.0f, 100.0f, 100.0f);
+    REPORTER_ASSERT(reporter, !rect.hasValidCoordinates());
+
+    rect = SkRect::MakeXYWH(10.0f, -1.0f/0.0f, 100.0f, 100.0f);
+    REPORTER_ASSERT(reporter, !rect.hasValidCoordinates());
+}
+
+// need tests for SkStrSearch
+
+#include "TestClassDef.h"
+DEFINE_TESTCLASS("InfRect", InfRectTestClass, TestInfRect)