2023-12-21 23:27:19 +01:00
|
|
|
import "reflect-metadata";
|
2024-05-21 19:59:04 +02:00
|
|
|
import { Queue } from "@spt/utils/collections/queue/Queue";
|
2024-07-23 17:12:53 +02:00
|
|
|
import { describe, expect, it } from "vitest";
|
2023-12-21 23:27:19 +01:00
|
|
|
|
2024-07-23 17:12:53 +02:00
|
|
|
describe("LinkedList", () => {
|
|
|
|
describe("enqueue", () => {
|
2023-12-21 23:27:19 +01:00
|
|
|
const queue = new Queue<number>();
|
|
|
|
queue.enqueue(420);
|
|
|
|
queue.enqueue(69);
|
|
|
|
queue.enqueue(8008135);
|
|
|
|
queue.enqueue(1337);
|
|
|
|
|
2024-07-23 17:12:53 +02:00
|
|
|
it("adds elements to the end of the queue", () => {
|
2023-12-21 23:27:19 +01:00
|
|
|
expect(queue.peek()).toEqual(420);
|
|
|
|
expect(queue.length).toEqual(4);
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
2024-07-23 17:12:53 +02:00
|
|
|
describe("enqueueAll", () => {
|
2023-12-21 23:27:19 +01:00
|
|
|
const queue = new Queue<number>();
|
|
|
|
queue.enqueueAll([420, 69, 8008135, 1337]);
|
|
|
|
|
2024-07-23 17:12:53 +02:00
|
|
|
it("iterates the array and adds each element to the end of the queue", () => {
|
2023-12-21 23:27:19 +01:00
|
|
|
expect(queue.peek()).toEqual(420);
|
|
|
|
expect(queue.length).toEqual(4);
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
2024-07-23 17:12:53 +02:00
|
|
|
describe("dequeue", () => {
|
2023-12-21 23:27:19 +01:00
|
|
|
const queue = new Queue<number>();
|
|
|
|
queue.enqueueAll([420, 69, 8008135, 1337]);
|
|
|
|
|
2024-07-23 17:12:53 +02:00
|
|
|
it("removes the first element and return it's value", () => {
|
2023-12-21 23:27:19 +01:00
|
|
|
expect(queue.dequeue()).toEqual(420);
|
|
|
|
expect(queue.peek()).toEqual(69);
|
|
|
|
expect(queue.length).toEqual(3);
|
|
|
|
|
|
|
|
expect(queue.dequeue()).toEqual(69);
|
|
|
|
expect(queue.peek()).toEqual(8008135);
|
|
|
|
expect(queue.length).toEqual(2);
|
|
|
|
|
|
|
|
expect(queue.dequeue()).toEqual(8008135);
|
|
|
|
expect(queue.peek()).toEqual(1337);
|
|
|
|
expect(queue.length).toEqual(1);
|
|
|
|
|
|
|
|
expect(queue.dequeue()).toEqual(1337);
|
|
|
|
expect(queue.peek()).toEqual(undefined);
|
|
|
|
expect(queue.length).toEqual(0);
|
|
|
|
|
|
|
|
expect(queue.dequeue()).toEqual(undefined);
|
|
|
|
expect(queue.peek()).toEqual(undefined);
|
|
|
|
expect(queue.length).toEqual(0);
|
|
|
|
});
|
|
|
|
});
|
|
|
|
});
|