chromium/third_party/google-closure-library/closure/goog/math/line_test.js

/**
 * @license
 * Copyright The Closure Library Authors.
 * SPDX-License-Identifier: Apache-2.0
 */

goog.module('goog.math.LineTest');
goog.setTestOnly();

const Coordinate = goog.require('goog.math.Coordinate');
const Line = goog.require('goog.math.Line');
const testSuite = goog.require('goog.testing.testSuite');

testSuite({
  testEquals() {
    const input = new Line(1, 2, 3, 4);

    assert(input.equals(input));
  },

  testClone() {
    const input = new Line(1, 2, 3, 4);

    assertNotEquals('Clone returns a new object', input, input.clone());
    assertTrue('Contents of clone match original', input.equals(input.clone()));
  },

  testGetLength() {
    const input = new Line(0, 0, Math.sqrt(2), Math.sqrt(2));
    assertRoughlyEquals(input.getSegmentLengthSquared(), 4, 1e-10);
    assertRoughlyEquals(input.getSegmentLength(), 2, 1e-10);
  },

  testGetClosestPoint() {
    const input = new Line(0, 1, 1, 2);

    const point = input.getClosestPoint(0, 3);
    assertRoughlyEquals(point.x, 1, 1e-10);
    assertRoughlyEquals(point.y, 2, 1e-10);
  },

  testGetClosestSegmentPoint() {
    const input = new Line(0, 1, 2, 3);

    let point = input.getClosestSegmentPoint(4, 4);
    assertRoughlyEquals(point.x, 2, 1e-10);
    assertRoughlyEquals(point.y, 3, 1e-10);

    point = input.getClosestSegmentPoint(new Coordinate(-1, -10));
    assertRoughlyEquals(point.x, 0, 1e-10);
    assertRoughlyEquals(point.y, 1, 1e-10);
  },
});