// Copyright 2008 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.LineTest'); goog.setTestOnly('goog.math.LineTest'); goog.require('goog.math.Coordinate'); goog.require('goog.math.Line'); goog.require('goog.testing.jsunit'); function testEquals() { var input = new goog.math.Line(1, 2, 3, 4); assert(input.equals(input)); } function testClone() { var input = new goog.math.Line(1, 2, 3, 4); assertNotEquals('Clone returns a new object', input, input.clone()); assertTrue('Contents of clone match original', input.equals(input.clone())); } function testGetLength() { var input = new goog.math.Line(0, 0, Math.sqrt(2), Math.sqrt(2)); assertRoughlyEquals(input.getSegmentLengthSquared(), 4, 1e-10); assertRoughlyEquals(input.getSegmentLength(), 2, 1e-10); } function testGetClosestPoint() { var input = new goog.math.Line(0, 1, 1, 2); var point = input.getClosestPoint(0, 3); assertRoughlyEquals(point.x, 1, 1e-10); assertRoughlyEquals(point.y, 2, 1e-10); } function testGetClosestSegmentPoint() { var input = new goog.math.Line(0, 1, 2, 3); var point = input.getClosestSegmentPoint(4, 4); assertRoughlyEquals(point.x, 2, 1e-10); assertRoughlyEquals(point.y, 3, 1e-10); point = input.getClosestSegmentPoint(new goog.math.Coordinate(-1, -10)); assertRoughlyEquals(point.x, 0, 1e-10); assertRoughlyEquals(point.y, 1, 1e-10); }