summaryrefslogtreecommitdiffstats
path: root/packages/math/line.test.ts
blob: 0e6bb1cc8f40d1cb5f75f0c19a99c5d38922846f (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
import { line, linesIntersectAt } from "./line";
import { pointFrom } from "./point";

describe("line-line intersections", () => {
  it("should correctly detect intersection at origin", () => {
    expect(
      linesIntersectAt(
        line(pointFrom(-5, -5), pointFrom(5, 5)),
        line(pointFrom(5, -5), pointFrom(-5, 5)),
      ),
    ).toEqual(pointFrom(0, 0));
  });

  it("should correctly detect intersection at non-origin", () => {
    expect(
      linesIntersectAt(
        line(pointFrom(0, 0), pointFrom(10, 10)),
        line(pointFrom(10, 0), pointFrom(0, 10)),
      ),
    ).toEqual(pointFrom(5, 5));
  });

  it("should correctly detect parallel lines", () => {
    expect(
      linesIntersectAt(
        line(pointFrom(0, 0), pointFrom(0, 10)),
        line(pointFrom(10, 0), pointFrom(10, 10)),
      ),
    ).toBe(null);
  });
});