|
import { describe, it, expect } from "vitest"; |
|
import { RangeList } from "./RangeList"; |
|
|
|
describe("RangeList", () => { |
|
it("should add a single range", () => { |
|
const rangeList = new RangeList(); |
|
rangeList.add(1, 100); |
|
|
|
const ranges = rangeList.getAllRanges(); |
|
expect(ranges).toHaveLength(1); |
|
expect(ranges[0]).toEqual({ |
|
start: 1, |
|
end: 100, |
|
refCount: 1, |
|
data: null, |
|
}); |
|
}); |
|
|
|
it("should handle overlapping ranges", () => { |
|
const rangeList = new RangeList(); |
|
rangeList.add(1, 100); |
|
rangeList.add(30, 50); |
|
|
|
const ranges = rangeList.getAllRanges(); |
|
expect(ranges).toHaveLength(3); |
|
expect(ranges).toEqual([ |
|
{ start: 1, end: 30, refCount: 1, data: null }, |
|
{ start: 30, end: 50, refCount: 2, data: null }, |
|
{ start: 50, end: 100, refCount: 1, data: null }, |
|
]); |
|
}); |
|
|
|
it("should remove a range at existing boundaries", () => { |
|
const rangeList = new RangeList(); |
|
rangeList.add(1, 100); |
|
rangeList.add(30, 50); |
|
rangeList.remove(30, 50); |
|
|
|
const ranges = rangeList.getAllRanges(); |
|
expect(ranges).toHaveLength(3); |
|
expect(ranges).toEqual([ |
|
{ start: 1, end: 30, refCount: 1, data: null }, |
|
{ start: 30, end: 50, refCount: 1, data: null }, |
|
{ start: 50, end: 100, refCount: 1, data: null }, |
|
]); |
|
}); |
|
|
|
it("should throw error when removing range at non-existing boundaries", () => { |
|
const rangeList = new RangeList(); |
|
rangeList.add(1, 100); |
|
rangeList.add(30, 50); |
|
|
|
expect(() => rangeList.remove(2, 50)).toThrow("Range boundaries must match existing boundaries"); |
|
}); |
|
|
|
it("should get ranges within boundaries", () => { |
|
const rangeList = new RangeList(); |
|
rangeList.add(1, 100); |
|
rangeList.add(30, 50); |
|
|
|
const ranges = rangeList.getRanges(30, 100); |
|
expect(ranges).toHaveLength(2); |
|
expect(ranges).toEqual([ |
|
{ start: 30, end: 50, refCount: 2, data: null }, |
|
{ start: 50, end: 100, refCount: 1, data: null }, |
|
]); |
|
}); |
|
|
|
it("should throw error when end is less than or equal to start", () => { |
|
const rangeList = new RangeList(); |
|
|
|
expect(() => rangeList.add(100, 1)).toThrow("End must be greater than start"); |
|
expect(() => rangeList.add(1, 1)).toThrow("End must be greater than start"); |
|
expect(() => rangeList.remove(100, 1)).toThrow("End must be greater than start"); |
|
expect(() => rangeList.remove(1, 1)).toThrow("End must be greater than start"); |
|
expect(() => rangeList.getRanges(100, 1)).toThrow("End must be greater than start"); |
|
expect(() => rangeList.getRanges(1, 1)).toThrow("End must be greater than start"); |
|
}); |
|
|
|
it("should handle multiple overlapping ranges", () => { |
|
const rangeList = new RangeList(); |
|
rangeList.add(1, 100); |
|
rangeList.add(30, 50); |
|
rangeList.add(40, 60); |
|
|
|
const ranges = rangeList.getAllRanges(); |
|
expect(ranges).toHaveLength(5); |
|
expect(ranges).toEqual([ |
|
{ start: 1, end: 30, refCount: 1, data: null }, |
|
{ start: 30, end: 40, refCount: 2, data: null }, |
|
{ start: 40, end: 50, refCount: 3, data: null }, |
|
{ start: 50, end: 60, refCount: 2, data: null }, |
|
{ start: 60, end: 100, refCount: 1, data: null }, |
|
]); |
|
}); |
|
}); |
|
|