123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236 |
- // Copyright 2006 The Closure Library Authors. All Rights Reserved.
- //
- // Licensed under the Apache License, Version 2.0 (the "License");
- // you may not use this file except in compliance with the License.
- // You may obtain a copy of the License at
- //
- // http://www.apache.org/licenses/LICENSE-2.0
- //
- // Unless required by applicable law or agreed to in writing, software
- // distributed under the License is distributed on an "AS-IS" BASIS,
- // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- // See the License for the specific language governing permissions and
- // limitations under the License.
- goog.provide('goog.math.Vec2Test');
- goog.setTestOnly('goog.math.Vec2Test');
- goog.require('goog.math.Vec2');
- goog.require('goog.testing.jsunit');
- function assertVectorEquals(a, b) {
- assertTrue(b + ' should be equal to ' + a, goog.math.Vec2.equals(a, b));
- }
- function testVec2() {
- var v = new goog.math.Vec2(3.14, 2.78);
- assertEquals(3.14, v.x);
- assertEquals(2.78, v.y);
- }
- function testRandomUnit() {
- var a = goog.math.Vec2.randomUnit();
- assertRoughlyEquals(1.0, a.magnitude(), 1e-10);
- }
- function testRandom() {
- var a = goog.math.Vec2.random();
- assertTrue(a.magnitude() <= 1.0);
- }
- function testClone() {
- var a = new goog.math.Vec2(1, 2);
- var b = a.clone();
- assertEquals(a.x, b.x);
- assertEquals(a.y, b.y);
- }
- function testMagnitude() {
- var a = new goog.math.Vec2(0, 10);
- var b = new goog.math.Vec2(3, 4);
- assertEquals(10, a.magnitude());
- assertEquals(5, b.magnitude());
- }
- function testSquaredMagnitude() {
- var a = new goog.math.Vec2(-3, -4);
- assertEquals(25, a.squaredMagnitude());
- }
- function testScaleFactor() {
- var a = new goog.math.Vec2(1, 2);
- var scaled = a.scale(0.5);
- assertTrue(
- 'The type of the return value should be goog.math.Vec2',
- scaled instanceof goog.math.Vec2);
- assertVectorEquals(new goog.math.Vec2(0.5, 1), a);
- }
- function testScaleXY() {
- var a = new goog.math.Vec2(10, 15);
- var scaled = a.scale(2, 3);
- assertEquals('The function should return the target instance', a, scaled);
- assertTrue(
- 'The type of the return value should be goog.math.Vec2',
- scaled instanceof goog.math.Vec2);
- assertVectorEquals(new goog.math.Vec2(20, 45), a);
- }
- function testInvert() {
- var a = new goog.math.Vec2(3, 4);
- a.invert();
- assertEquals(-3, a.x);
- assertEquals(-4, a.y);
- }
- function testNormalize() {
- var a = new goog.math.Vec2(5, 5);
- a.normalize();
- assertRoughlyEquals(1.0, a.magnitude(), 1e-10);
- }
- function testAdd() {
- var a = new goog.math.Vec2(1, -1);
- a.add(new goog.math.Vec2(3, 3));
- assertVectorEquals(new goog.math.Vec2(4, 2), a);
- }
- function testSubtract() {
- var a = new goog.math.Vec2(1, -1);
- a.subtract(new goog.math.Vec2(3, 3));
- assertVectorEquals(new goog.math.Vec2(-2, -4), a);
- }
- function testRotate() {
- var a = new goog.math.Vec2(1, -1);
- a.rotate(Math.PI / 2);
- assertRoughlyEquals(1, a.x, 0.000001);
- assertRoughlyEquals(1, a.y, 0.000001);
- a.rotate(-Math.PI);
- assertRoughlyEquals(-1, a.x, 0.000001);
- assertRoughlyEquals(-1, a.y, 0.000001);
- }
- function testRotateAroundPoint() {
- var a = goog.math.Vec2.rotateAroundPoint(
- new goog.math.Vec2(1, -1), new goog.math.Vec2(1, 0), Math.PI / 2);
- assertRoughlyEquals(2, a.x, 0.000001);
- assertRoughlyEquals(0, a.y, 0.000001);
- }
- function testEquals() {
- var a = new goog.math.Vec2(1, 2);
- assertFalse(a.equals(null));
- assertFalse(a.equals({}));
- assertFalse(a.equals(new goog.math.Vec2(1, 3)));
- assertFalse(a.equals(new goog.math.Vec2(2, 2)));
- assertTrue(a.equals(a));
- assertTrue(a.equals(new goog.math.Vec2(1, 2)));
- }
- function testSum() {
- var a = new goog.math.Vec2(0.5, 0.25);
- var b = new goog.math.Vec2(0.5, 0.75);
- var c = goog.math.Vec2.sum(a, b);
- assertVectorEquals(new goog.math.Vec2(1, 1), c);
- }
- function testDifference() {
- var a = new goog.math.Vec2(0.5, 0.25);
- var b = new goog.math.Vec2(0.5, 0.75);
- var c = goog.math.Vec2.difference(a, b);
- assertVectorEquals(new goog.math.Vec2(0, -0.5), c);
- }
- function testDistance() {
- var a = new goog.math.Vec2(3, 4);
- var b = new goog.math.Vec2(-3, -4);
- assertEquals(10, goog.math.Vec2.distance(a, b));
- }
- function testSquaredDistance() {
- var a = new goog.math.Vec2(3, 4);
- var b = new goog.math.Vec2(-3, -4);
- assertEquals(100, goog.math.Vec2.squaredDistance(a, b));
- }
- function testVec2Equals() {
- assertTrue(goog.math.Vec2.equals(null, null));
- assertFalse(goog.math.Vec2.equals(null, new goog.math.Vec2()));
- var a = new goog.math.Vec2(1, 3);
- assertTrue(goog.math.Vec2.equals(a, a));
- assertTrue(goog.math.Vec2.equals(a, new goog.math.Vec2(1, 3)));
- assertFalse(goog.math.Vec2.equals(1, new goog.math.Vec2(3, 1)));
- }
- function testDot() {
- var a = new goog.math.Vec2(0, 5);
- var b = new goog.math.Vec2(3, 0);
- assertEquals(0, goog.math.Vec2.dot(a, b));
- var c = new goog.math.Vec2(-5, -5);
- var d = new goog.math.Vec2(0, 7);
- assertEquals(-35, goog.math.Vec2.dot(c, d));
- }
- function testDeterminant() {
- var a = new goog.math.Vec2(0, 5);
- var b = new goog.math.Vec2(0, 10);
- assertEquals(0, goog.math.Vec2.determinant(a, b));
- var c = new goog.math.Vec2(0, 5);
- var d = new goog.math.Vec2(10, 0);
- assertEquals(-50, goog.math.Vec2.determinant(c, d));
- var e = new goog.math.Vec2(-5, -5);
- var f = new goog.math.Vec2(0, 7);
- assertEquals(-35, goog.math.Vec2.determinant(e, f));
- }
- function testLerp() {
- var a = new goog.math.Vec2(0, 0);
- var b = new goog.math.Vec2(10, 10);
- for (var i = 0; i <= 10; i++) {
- var c = goog.math.Vec2.lerp(a, b, i / 10);
- assertEquals(i, c.x);
- assertEquals(i, c.y);
- }
- }
- function testToString() {
- testEquals('(0, 0)', new goog.math.Vec2(0, 0).toString());
- }
|