tests_math_roi.test.js

import {describe, test, assert} from 'vitest';
import {Point2D} from '../../src/math/point.js';
import {ROI} from '../../src/math/roi.js';

/**
 * Tests for the 'math/roi.js' file.
 */

describe('math', () => {

  /**
   * Tests for {@link ROI}.
   *
   * @function module:tests/math~roi-class
   */
  test('ROI class - #DWV-REQ-UI-07-008 Draw ROI', () => {
    const r0 = new ROI();
    const points0 = [
      new Point2D(0, 0),
      new Point2D(0, -4)
    ];
    // getLength
    assert.equal(r0.getLength(), 0, 'getLength #0');
    // add a point
    r0.addPoint(points0[0]);
    // getLength
    assert.equal(r0.getLength(), 1, 'getLength #1');
    // add another point
    r0.addPoint(points0[1]);
    // getPoint first
    assert.equal(r0.getPoint(0), points0[0], 'getPoint first');
    // getPoint second
    assert.equal(r0.getPoint(1), points0[1], 'getPoint second');
    // getPoints
    assert.deepEqual(r0.getPoints(), points0, 'getPoints');
    // add multiple points
    r0.addPoints([
      new Point2D(4, -4),
      new Point2D(4, 0)
    ]);
    // getLength
    assert.equal(r0.getLength(), 4, 'getLength #2');
    // get centroid
    const theoCentroid = new Point2D(2, -2);
    assert.ok(r0.getCentroid().equals(theoCentroid), 'getCentroid');
  });

});