Index: pkg/dev_compiler/test/codegen/lib/math/rectangle_test.dart |
diff --git a/pkg/dev_compiler/test/codegen/lib/math/rectangle_test.dart b/pkg/dev_compiler/test/codegen/lib/math/rectangle_test.dart |
index baacd966e692f1e7a585e4c25d7f4199b4f20afa..493a614f0581303eddc8b0b06e05c3b8eecabf35 100644 |
--- a/pkg/dev_compiler/test/codegen/lib/math/rectangle_test.dart |
+++ b/pkg/dev_compiler/test/codegen/lib/math/rectangle_test.dart |
@@ -2,249 +2,254 @@ |
// for details. All rights reserved. Use of this source code is governed by a |
// BSD-style license that can be found in the LICENSE file. |
-library rect_test; |
- |
import 'dart:math'; |
-import 'package:unittest/unittest.dart'; |
+import 'package:expect/expect.dart'; |
main() { |
- Rectangle createRectangle(List<num> a) { |
- return a != null ? new Rectangle(a[0], a[1], a[2] - a[0], a[3] - a[1]) |
- : null; |
+ testConstruction(); |
+ testIntersection(); |
+ testIntersects(); |
+ testBoundingBox(); |
+ testContainsRectangle(); |
+ testContainsPoint(); |
+ testHashCode(); |
+ testEdgeCases(); |
+ testEquality(); |
+ testNegativeLengths(); |
+ testNaNLeft(); |
+ testNaNTop(); |
+ testNaNWidth(); |
+ testNaNHeight(); |
+} |
+ |
+Rectangle createRectangle(List<num> a) { |
+ return a != null ? new Rectangle(a[0], a[1], a[2] - a[0], a[3] - a[1]) |
+ : null; |
+} |
+ |
+testConstruction() { |
+ var r0 = new Rectangle(10, 20, 30, 40); |
+ Expect.equals('Rectangle (10, 20) 30 x 40', r0.toString()); |
+ Expect.equals(40, r0.right); |
+ Expect.equals(60, r0.bottom); |
+ |
+ var r1 = new Rectangle.fromPoints(r0.topLeft, r0.bottomRight); |
+ Expect.equals(r0, r1); |
+ |
+ var r2 = new Rectangle.fromPoints(r0.bottomRight, r0.topLeft); |
+ Expect.equals(r0, r2); |
+} |
+ |
+testIntersection() { |
+ var tests = [ |
+ [[10, 10, 20, 20], [15, 15, 25, 25], [15, 15, 20, 20]], |
+ [[10, 10, 20, 20], [20, 0, 30, 10], [20, 10, 20, 10]], |
+ [[0, 0, 1, 1], [10, 11, 12, 13], null], |
+ [[11, 12, 98, 99], [22, 23, 34, 35], [22, 23, 34, 35]]]; |
+ |
+ for (var test in tests) { |
+ var r0 = createRectangle(test[0]); |
+ var r1 = createRectangle(test[1]); |
+ var expected = createRectangle(test[2]); |
+ |
+ Expect.equals(expected, r0.intersection(r1)); |
+ Expect.equals(expected, r1.intersection(r0)); |
} |
+} |
+ |
+testIntersects() { |
+ var r0 = new Rectangle(10, 10, 20, 20); |
+ var r1 = new Rectangle(15, 15, 25, 25); |
+ var r2 = new Rectangle(0, 0, 1, 1); |
+ |
+ Expect.isTrue(r0.intersects(r1)); |
+ Expect.isTrue(r1.intersects(r0)); |
+ |
+ Expect.isFalse(r0.intersects(r2)); |
+ Expect.isFalse(r2.intersects(r0)); |
+} |
- test('construction', () { |
- var r0 = new Rectangle(10, 20, 30, 40); |
- expect(r0.toString(), 'Rectangle (10, 20) 30 x 40'); |
- expect(r0.right, 40); |
- expect(r0.bottom, 60); |
- |
- var r1 = new Rectangle.fromPoints(r0.topLeft, r0.bottomRight); |
- expect(r1, r0); |
- |
- var r2 = new Rectangle.fromPoints(r0.bottomRight, r0.topLeft); |
- expect(r2, r0); |
- }); |
- |
- test('intersection', () { |
- var tests = [ |
- [[10, 10, 20, 20], [15, 15, 25, 25], [15, 15, 20, 20]], |
- [[10, 10, 20, 20], [20, 0, 30, 10], [20, 10, 20, 10]], |
- [[0, 0, 1, 1], [10, 11, 12, 13], null], |
- [[11, 12, 98, 99], [22, 23, 34, 35], [22, 23, 34, 35]]]; |
- |
- for (var test in tests) { |
- var r0 = createRectangle(test[0]); |
- var r1 = createRectangle(test[1]); |
- var expected = createRectangle(test[2]); |
- |
- expect(r0.intersection(r1), expected); |
- expect(r1.intersection(r0), expected); |
- } |
- }); |
- |
- test('intersects', () { |
- var r0 = new Rectangle(10, 10, 20, 20); |
- var r1 = new Rectangle(15, 15, 25, 25); |
- var r2 = new Rectangle(0, 0, 1, 1); |
- |
- expect(r0.intersects(r1), isTrue); |
- expect(r1.intersects(r0), isTrue); |
- |
- expect(r0.intersects(r2), isFalse); |
- expect(r2.intersects(r0), isFalse); |
- }); |
- |
- test('boundingBox', () { |
- var tests = [ |
- [[10, 10, 20, 20], [15, 15, 25, 25], [10, 10, 25, 25]], |
- [[10, 10, 20, 20], [20, 0, 30, 10], [10, 0, 30, 20]], |
- [[0, 0, 1, 1], [10, 11, 12, 13], [0, 0, 12, 13]], |
- [[11, 12, 98, 99], [22, 23, 34, 35], [11, 12, 98, 99]]]; |
- |
- for (var test in tests) { |
- var r0 = createRectangle(test[0]); |
- var r1 = createRectangle(test[1]); |
- var expected = createRectangle(test[2]); |
- |
- expect(r0.boundingBox(r1), expected); |
- expect(r1.boundingBox(r0), expected); |
- } |
- }); |
- |
- test('containsRectangle', () { |
- var r = new Rectangle(-10, 0, 20, 10); |
- expect(r.containsRectangle(r), isTrue); |
- |
- expect(r.containsRectangle( |
- new Rectangle(double.NAN, double.NAN, double.NAN, double.NAN)), isFalse); |
- |
- var r2 = new Rectangle(0, 2, 5, 5); |
- expect(r.containsRectangle(r2), isTrue); |
- expect(r2.containsRectangle(r), isFalse); |
- |
- r2 = new Rectangle(-11, 2, 5, 5); |
- expect(r.containsRectangle(r2), isFalse); |
- r2 = new Rectangle(0, 2, 15, 5); |
- expect(r.containsRectangle(r2), isFalse); |
- r2 = new Rectangle(0, 2, 5, 10); |
- expect(r.containsRectangle(r2), isFalse); |
- r2 = new Rectangle(0, 0, 5, 10); |
- expect(r.containsRectangle(r2), isTrue); |
- }); |
- |
- test('containsPoint', () { |
- var r = new Rectangle(20, 40, 60, 80); |
- |
- // Test middle. |
- expect(r.containsPoint(new Point(50, 80)), isTrue); |
- |
- // Test edges. |
- expect(r.containsPoint(new Point(20, 40)), isTrue); |
- expect(r.containsPoint(new Point(50, 40)), isTrue); |
- expect(r.containsPoint(new Point(80, 40)), isTrue); |
- expect(r.containsPoint(new Point(80, 80)), isTrue); |
- expect(r.containsPoint(new Point(80, 120)), isTrue); |
- expect(r.containsPoint(new Point(50, 120)), isTrue); |
- expect(r.containsPoint(new Point(20, 120)), isTrue); |
- expect(r.containsPoint(new Point(20, 80)), isTrue); |
- |
- // Test outside. |
- expect(r.containsPoint(new Point(0, 0)), isFalse); |
- expect(r.containsPoint(new Point(50, 0)), isFalse); |
- expect(r.containsPoint(new Point(100, 0)), isFalse); |
- expect(r.containsPoint(new Point(100, 80)), isFalse); |
- expect(r.containsPoint(new Point(100, 160)), isFalse); |
- expect(r.containsPoint(new Point(50, 160)), isFalse); |
- expect(r.containsPoint(new Point(0, 160)), isFalse); |
- expect(r.containsPoint(new Point(0, 80)), isFalse); |
- }); |
- |
- test('hashCode', () { |
- var a = new Rectangle(0, 1, 2, 3); |
- var b = new Rectangle(0, 1, 2, 3); |
- expect(a.hashCode, b.hashCode); |
- |
- var c = new Rectangle(1, 0, 2, 3); |
- expect(a.hashCode == c.hashCode, isFalse); |
- }); |
- |
- { // Edge cases for boundingBox/intersection |
- edgeTest(a, l) { |
- test('edge case $a/$l', () { |
- var r = new Rectangle(a, a, l, l); |
- expect(r.boundingBox(r), r); |
- expect(r.intersection(r), r); |
- }); |
- } |
- |
- var bignum1 = 0x20000000000000 + 0.0; |
- var bignum2 = 0x20000000000002 + 0.0; |
- var bignum3 = 0x20000000000004 + 0.0; |
- edgeTest(1.0, bignum1); |
- edgeTest(1.0, bignum2); |
- edgeTest(1.0, bignum3); |
- edgeTest(bignum1, 1.0); |
- edgeTest(bignum2, 1.0); |
- edgeTest(bignum3, 1.0); |
+testBoundingBox() { |
+ var tests = [ |
+ [[10, 10, 20, 20], [15, 15, 25, 25], [10, 10, 25, 25]], |
+ [[10, 10, 20, 20], [20, 0, 30, 10], [10, 0, 30, 20]], |
+ [[0, 0, 1, 1], [10, 11, 12, 13], [0, 0, 12, 13]], |
+ [[11, 12, 98, 99], [22, 23, 34, 35], [11, 12, 98, 99]]]; |
+ |
+ for (var test in tests) { |
+ var r0 = createRectangle(test[0]); |
+ var r1 = createRectangle(test[1]); |
+ var expected = createRectangle(test[2]); |
+ |
+ Expect.equals(expected, r0.boundingBox(r1)); |
+ Expect.equals(expected, r1.boundingBox(r0)); |
} |
+} |
+ |
+testContainsRectangle() { |
+ var r = new Rectangle(-10, 0, 20, 10); |
+ Expect.isTrue(r.containsRectangle(r)); |
+ |
+ Expect.isFalse(r.containsRectangle( |
+ new Rectangle(double.NAN, double.NAN, double.NAN, double.NAN))); |
+ |
+ var r2 = new Rectangle(0, 2, 5, 5); |
+ Expect.isTrue(r.containsRectangle(r2)); |
+ Expect.isFalse(r2.containsRectangle(r)); |
+ |
+ r2 = new Rectangle(-11, 2, 5, 5); |
+ Expect.isFalse(r.containsRectangle(r2)); |
+ r2 = new Rectangle(0, 2, 15, 5); |
+ Expect.isFalse(r.containsRectangle(r2)); |
+ r2 = new Rectangle(0, 2, 5, 10); |
+ Expect.isFalse(r.containsRectangle(r2)); |
+ r2 = new Rectangle(0, 0, 5, 10); |
+ Expect.isTrue(r.containsRectangle(r2)); |
+} |
- test("equality with different widths", () { |
- var bignum = 0x80000000000008 + 0.0; |
- var r1 = new Rectangle(bignum, bignum, 1.0, 1.0); |
- var r2 = new Rectangle(bignum, bignum, 2.0, 2.0); |
- expect(r1, r2); |
- expect(r1.hashCode, r2.hashCode); |
- expect(r1.right, r2.right); |
- expect(r1.bottom, r2.bottom); |
- expect(r1.width, 1.0); |
- expect(r2.width, 2.0); |
- }); |
- |
- test('negative lengths', () { |
- // Constructor allows negative lengths, but clamps them to zero. |
- expect(new Rectangle(4, 4, -2, -2), new Rectangle(4, 4, 0, 0)); |
- expect(new MutableRectangle(4, 4, -2, -2), new Rectangle(4, 4, 0, 0)); |
- |
- // Setters clamp negative lengths to zero. |
- var r = new MutableRectangle(0, 0, 1, 1); |
- r.width = -1; |
- r.height = -1; |
- expect(r, new Rectangle(0, 0, 0, 0)); |
- |
- // Test that doubles are clamped to double zero. |
- r = new Rectangle(1.5, 1.5, -2.5, -2.5); |
- expect(identical(r.width, 0.0), isTrue); |
- expect(identical(r.height, 0.0), isTrue); |
- }); |
- |
- // A NaN-value in any rectangle value means the rectange is considered |
- // empty (contains no points, doesn't intersect any other rectangle). |
- const NaN = double.NAN; |
- var isNaN = predicate((x) => x is double && x.isNaN, "NaN"); |
- |
- test('NaN left', () { |
- var rectangles = [ |
- const Rectangle(NaN, 1, 2, 3), |
- new MutableRectangle(NaN, 1, 2, 3), |
- new Rectangle.fromPoints(new Point(NaN, 1), new Point(2, 4)), |
- new MutableRectangle.fromPoints(new Point(NaN, 1), new Point(2, 4)), |
- ]; |
- for (var r in rectangles) { |
- expect(r.containsPoint(new Point(0, 1)), false); |
- expect(r.containsRectangle(new Rectangle(0, 1, 2, 3)), false); |
- expect(r.intersects(new Rectangle(0, 1, 2, 3)), false); |
- expect(r.left, isNaN); |
- expect(r.right, isNaN); |
- } |
- }); |
- |
- test('NaN top', () { |
- var rectangles = [ |
- const Rectangle(0, NaN, 2, 3), |
- new MutableRectangle(0, NaN, 2, 3), |
- new Rectangle.fromPoints(new Point(0, NaN), new Point(2, 4)), |
- new MutableRectangle.fromPoints(new Point(0, NaN), new Point(2, 4)), |
- ]; |
- for (var r in rectangles) { |
- expect(r.containsPoint(new Point(0, 1)), false); |
- expect(r.containsRectangle(new Rectangle(0, 1, 2, 3)), false); |
- expect(r.intersects(new Rectangle(0, 1, 2, 3)), false); |
- expect(r.top, isNaN); |
- expect(r.bottom, isNaN); |
- } |
- }); |
- |
- test('NaN width', () { |
- var rectangles = [ |
- const Rectangle(0, 1, NaN, 3), |
- new MutableRectangle(0, 1, NaN, 3), |
- new Rectangle.fromPoints(new Point(0, 1), new Point(NaN, 4)), |
- new MutableRectangle.fromPoints(new Point(0, 1), new Point(NaN, 4)), |
- ]; |
- for (var r in rectangles) { |
- expect(r.containsPoint(new Point(0, 1)), false); |
- expect(r.containsRectangle(new Rectangle(0, 1, 2, 3)), false); |
- expect(r.intersects(new Rectangle(0, 1, 2, 3)), false); |
- expect(r.right, isNaN); |
- expect(r.width, isNaN); |
- } |
- }); |
- |
- test('NaN heigth', () { |
- var rectangles = [ |
- const Rectangle(0, 1, 2, NaN), |
- new MutableRectangle(0, 1, 2, NaN), |
- new Rectangle.fromPoints(new Point(0, 1), new Point(2, NaN)), |
- new MutableRectangle.fromPoints(new Point(0, 1), new Point(2, NaN)), |
- ]; |
- for (var r in rectangles) { |
- expect(r.containsPoint(new Point(0, 1)), false); |
- expect(r.containsRectangle(new Rectangle(0, 1, 2, 3)), false); |
- expect(r.intersects(new Rectangle(0, 1, 2, 3)), false); |
- expect(r.bottom, isNaN); |
- expect(r.height, isNaN); |
- } |
- }); |
+testContainsPoint() { |
+ var r = new Rectangle(20, 40, 60, 80); |
+ |
+ // Test middle. |
+ Expect.isTrue(r.containsPoint(new Point(50, 80))); |
+ |
+ // Test edges. |
+ Expect.isTrue(r.containsPoint(new Point(20, 40))); |
+ Expect.isTrue(r.containsPoint(new Point(50, 40))); |
+ Expect.isTrue(r.containsPoint(new Point(80, 40))); |
+ Expect.isTrue(r.containsPoint(new Point(80, 80))); |
+ Expect.isTrue(r.containsPoint(new Point(80, 120))); |
+ Expect.isTrue(r.containsPoint(new Point(50, 120))); |
+ Expect.isTrue(r.containsPoint(new Point(20, 120))); |
+ Expect.isTrue(r.containsPoint(new Point(20, 80))); |
+ |
+ // Test outside. |
+ Expect.isFalse(r.containsPoint(new Point(0, 0))); |
+ Expect.isFalse(r.containsPoint(new Point(50, 0))); |
+ Expect.isFalse(r.containsPoint(new Point(100, 0))); |
+ Expect.isFalse(r.containsPoint(new Point(100, 80))); |
+ Expect.isFalse(r.containsPoint(new Point(100, 160))); |
+ Expect.isFalse(r.containsPoint(new Point(50, 160))); |
+ Expect.isFalse(r.containsPoint(new Point(0, 160))); |
+ Expect.isFalse(r.containsPoint(new Point(0, 80))); |
} |
+testHashCode() { |
+ var a = new Rectangle(0, 1, 2, 3); |
+ var b = new Rectangle(0, 1, 2, 3); |
+ Expect.equals(b.hashCode, a.hashCode); |
+ |
+ var c = new Rectangle(1, 0, 2, 3); |
+ Expect.isFalse(a.hashCode == c.hashCode); |
+} |
+ |
+testEdgeCases() { |
+ edgeTest(double a, double l) { |
+ var r = new Rectangle(a, a, l, l); |
+ Expect.equals(r, r.boundingBox(r)); |
+ Expect.equals(r, r.intersection(r)); |
+ } |
+ |
+ var bignum1 = 0x20000000000000 + 0.0; |
+ var bignum2 = 0x20000000000002 + 0.0; |
+ var bignum3 = 0x20000000000004 + 0.0; |
+ edgeTest(1.0, bignum1); |
+ edgeTest(1.0, bignum2); |
+ edgeTest(1.0, bignum3); |
+ edgeTest(bignum1, 1.0); |
+ edgeTest(bignum2, 1.0); |
+ edgeTest(bignum3, 1.0); |
+} |
+ |
+testEquality() { |
+ var bignum = 0x80000000000008 + 0.0; |
+ var r1 = new Rectangle(bignum, bignum, 1.0, 1.0); |
+ var r2 = new Rectangle(bignum, bignum, 2.0, 2.0); |
+ Expect.equals(r2, r1); |
+ Expect.equals(r2.hashCode, r1.hashCode); |
+ Expect.equals(r2.right, r1.right); |
+ Expect.equals(r2.bottom, r1.bottom); |
+ Expect.equals(1.0, r1.width); |
+ Expect.equals(2.0, r2.width); |
+} |
+ |
+testNegativeLengths() { |
+ // Constructor allows negative lengths, but clamps them to zero. |
+ Expect.equals(new Rectangle(4, 4, 0, 0), new Rectangle(4, 4, -2, -2)); |
+ Expect.equals(new Rectangle(4, 4, 0, 0), |
+ new MutableRectangle(4, 4, -2, -2)); |
+ |
+ // Setters clamp negative lengths to zero. |
+ var mutable = new MutableRectangle(0, 0, 1, 1); |
+ mutable.width = -1; |
+ mutable.height = -1; |
+ Expect.equals(new Rectangle(0, 0, 0, 0), mutable); |
+ |
+ // Test that doubles are clamped to double zero. |
+ var rectangle = new Rectangle(1.5, 1.5, -2.5, -2.5); |
+ Expect.isTrue(identical(rectangle.width, 0.0)); |
+ Expect.isTrue(identical(rectangle.height, 0.0)); |
+} |
+ |
+testNaNLeft() { |
+ var rectangles = [ |
+ const Rectangle(double.NAN, 1, 2, 3), |
+ new MutableRectangle(double.NAN, 1, 2, 3), |
+ new Rectangle.fromPoints(new Point(double.NAN, 1), new Point(2, 4)), |
+ new MutableRectangle.fromPoints(new Point(double.NAN, 1), new Point(2, 4)), |
+ ]; |
+ for (var r in rectangles) { |
+ Expect.isFalse(r.containsPoint(new Point(0, 1))); |
+ Expect.isFalse(r.containsRectangle(new Rectangle(0, 1, 2, 3))); |
+ Expect.isFalse(r.intersects(new Rectangle(0, 1, 2, 3))); |
+ Expect.isTrue(r.left.isNaN); |
+ Expect.isTrue(r.right.isNaN); |
+ } |
+} |
+testNaNTop() { |
+ var rectangles = [ |
+ const Rectangle(0, double.NAN, 2, 3), |
+ new MutableRectangle(0, double.NAN, 2, 3), |
+ new Rectangle.fromPoints(new Point(0, double.NAN), new Point(2, 4)), |
+ new MutableRectangle.fromPoints(new Point(0, double.NAN), new Point(2, 4)), |
+ ]; |
+ for (var r in rectangles) { |
+ Expect.isFalse(r.containsPoint(new Point(0, 1))); |
+ Expect.isFalse(r.containsRectangle(new Rectangle(0, 1, 2, 3))); |
+ Expect.isFalse(r.intersects(new Rectangle(0, 1, 2, 3))); |
+ Expect.isTrue(r.top.isNaN); |
+ Expect.isTrue(r.bottom.isNaN); |
+ } |
+} |
+ |
+testNaNWidth() { |
+ var rectangles = [ |
+ const Rectangle(0, 1, double.NAN, 3), |
+ new MutableRectangle(0, 1, double.NAN, 3), |
+ new Rectangle.fromPoints(new Point(0, 1), new Point(double.NAN, 4)), |
+ new MutableRectangle.fromPoints(new Point(0, 1), new Point(double.NAN, 4)), |
+ ]; |
+ for (var r in rectangles) { |
+ Expect.isFalse(r.containsPoint(new Point(0, 1))); |
+ Expect.isFalse(r.containsRectangle(new Rectangle(0, 1, 2, 3))); |
+ Expect.isFalse(r.intersects(new Rectangle(0, 1, 2, 3))); |
+ Expect.isTrue(r.right.isNaN); |
+ Expect.isTrue(r.width.isNaN); |
+ } |
+} |
+ |
+testNaNHeight() { |
+ var rectangles = [ |
+ const Rectangle(0, 1, 2, double.NAN), |
+ new MutableRectangle(0, 1, 2, double.NAN), |
+ new Rectangle.fromPoints(new Point(0, 1), new Point(2, double.NAN)), |
+ new MutableRectangle.fromPoints(new Point(0, 1), new Point(2, double.NAN)), |
+ ]; |
+ for (var r in rectangles) { |
+ Expect.isFalse(r.containsPoint(new Point(0, 1))); |
+ Expect.isFalse(r.containsRectangle(new Rectangle(0, 1, 2, 3))); |
+ Expect.isFalse(r.intersects(new Rectangle(0, 1, 2, 3))); |
+ Expect.isTrue(r.bottom.isNaN); |
+ Expect.isTrue(r.height.isNaN); |
+ } |
+} |