1 /* 2 * Copyright 2012 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 #include "PathOpsTestCommon.h" 8 #include "SkPathOpsPoint.h" 9 #include "Test.h" 10 11 static const SkDPoint tests[] = { 12 {0, 0}, 13 {1, 0}, 14 {0, 1}, 15 {2, 1}, 16 {1, 2}, 17 {1, 1}, 18 {2, 2} 19 }; 20 21 static const size_t tests_count = SK_ARRAY_COUNT(tests); 22 23 DEF_TEST(PathOpsDPoint, reporter) { 24 for (size_t index = 0; index < tests_count; ++index) { 25 const SkDPoint& pt = tests[index]; 26 SkASSERT(ValidPoint(pt)); 27 SkDPoint p = pt; 28 REPORTER_ASSERT(reporter, p == pt); 29 REPORTER_ASSERT(reporter, !(pt != pt)); 30 SkDVector v = p - pt; 31 p += v; 32 REPORTER_ASSERT(reporter, p == pt); 33 p -= v; 34 REPORTER_ASSERT(reporter, p == pt); 35 REPORTER_ASSERT(reporter, p.approximatelyEqual(pt)); 36 SkPoint sPt = pt.asSkPoint(); 37 p.set(sPt); 38 REPORTER_ASSERT(reporter, p == pt); 39 REPORTER_ASSERT(reporter, p.approximatelyEqual(sPt)); 40 REPORTER_ASSERT(reporter, p.roughlyEqual(pt)); 41 p.fX = p.fY = 0; 42 REPORTER_ASSERT(reporter, p.fX == 0 && p.fY == 0); 43 REPORTER_ASSERT(reporter, p.approximatelyZero()); 44 REPORTER_ASSERT(reporter, pt.distanceSquared(p) == pt.fX * pt.fX + pt.fY * pt.fY); 45 REPORTER_ASSERT(reporter, approximately_equal(pt.distance(p), 46 sqrt(pt.fX * pt.fX + pt.fY * pt.fY))); 47 } 48 } 49