range.test.ts 1.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051
  1. import { rangeInclusive, rangeIntersection, rangesOverlap } from "./range";
  2. describe("range overlap", () => {
  3. const range1_4 = rangeInclusive(1, 4);
  4. it("should overlap when range a contains range b", () => {
  5. expect(rangesOverlap(range1_4, rangeInclusive(2, 3))).toBe(true);
  6. expect(rangesOverlap(range1_4, range1_4)).toBe(true);
  7. expect(rangesOverlap(range1_4, rangeInclusive(1, 3))).toBe(true);
  8. expect(rangesOverlap(range1_4, rangeInclusive(2, 4))).toBe(true);
  9. });
  10. it("should overlap when range b contains range a", () => {
  11. expect(rangesOverlap(rangeInclusive(2, 3), range1_4)).toBe(true);
  12. expect(rangesOverlap(rangeInclusive(1, 3), range1_4)).toBe(true);
  13. expect(rangesOverlap(rangeInclusive(2, 4), range1_4)).toBe(true);
  14. });
  15. it("should overlap when range a and b intersect", () => {
  16. expect(rangesOverlap(range1_4, rangeInclusive(2, 5))).toBe(true);
  17. });
  18. });
  19. describe("range intersection", () => {
  20. const range1_4 = rangeInclusive(1, 4);
  21. it("should intersect completely with itself", () => {
  22. expect(rangeIntersection(range1_4, range1_4)).toEqual(range1_4);
  23. });
  24. it("should intersect irrespective of order", () => {
  25. expect(rangeIntersection(range1_4, rangeInclusive(2, 3))).toEqual([2, 3]);
  26. expect(rangeIntersection(rangeInclusive(2, 3), range1_4)).toEqual([2, 3]);
  27. expect(rangeIntersection(range1_4, rangeInclusive(3, 5))).toEqual(
  28. rangeInclusive(3, 4),
  29. );
  30. expect(rangeIntersection(rangeInclusive(3, 5), range1_4)).toEqual(
  31. rangeInclusive(3, 4),
  32. );
  33. });
  34. it("should intersect at the edge", () => {
  35. expect(rangeIntersection(range1_4, rangeInclusive(4, 5))).toEqual(
  36. rangeInclusive(4, 4),
  37. );
  38. });
  39. it("should not intersect", () => {
  40. expect(rangeIntersection(range1_4, rangeInclusive(5, 7))).toEqual(null);
  41. });
  42. });