2023-05-29 23:05:20 +08:00
|
|
|
import { assert, assertEquals } from "../test_deps.ts";
|
|
|
|
import { CollabServer } from "./collab.ts";
|
|
|
|
|
|
|
|
Deno.test("Collab server", async () => {
|
|
|
|
const collabServer = new CollabServer(null as any);
|
|
|
|
console.log("Client 1 joins page 1");
|
|
|
|
assertEquals(collabServer.ping("client1", "page1"), {});
|
|
|
|
assertEquals(collabServer.clients.size, 1);
|
|
|
|
assertEquals(collabServer.pages.size, 1);
|
|
|
|
console.log("Client 1 joins page 2");
|
|
|
|
assertEquals(collabServer.ping("client1", "page2"), {});
|
|
|
|
assertEquals(collabServer.clients.size, 1);
|
|
|
|
assertEquals(collabServer.pages.size, 1);
|
|
|
|
console.log("Client 2 joins to page 2, collab id created");
|
|
|
|
const collabId = collabServer.ping("client2", "page2").collabId;
|
|
|
|
assertEquals(collabServer.clients.size, 2);
|
|
|
|
assert(collabId !== undefined);
|
|
|
|
console.log("Client 2 moves to page 1, collab id destroyed");
|
|
|
|
assertEquals(collabServer.ping("client2", "page1"), {});
|
|
|
|
assertEquals(collabServer.ping("client1", "page2"), {});
|
|
|
|
console.log("Going to cleanup, which should have no effect");
|
|
|
|
collabServer.cleanup(50);
|
|
|
|
assertEquals(collabServer.clients.size, 2);
|
|
|
|
collabServer.ping("client2", "page2");
|
|
|
|
console.log("Going to sleep 20ms");
|
|
|
|
await sleep(20);
|
|
|
|
console.log("Then client 1 pings, but client 2 does not");
|
2023-05-30 23:38:58 +08:00
|
|
|
collabServer.ping("client1", "page2");
|
2023-05-29 23:05:20 +08:00
|
|
|
await sleep(20);
|
|
|
|
console.log("Going to cleanup, which should clean client 2");
|
|
|
|
collabServer.cleanup(35);
|
|
|
|
assertEquals(collabServer.clients.size, 1);
|
|
|
|
assertEquals(collabServer.pages.get("page2")!.collabId, undefined);
|
|
|
|
console.log(collabServer);
|
|
|
|
});
|
|
|
|
|
|
|
|
function sleep(ms: number) {
|
|
|
|
return new Promise((resolve) => setTimeout(resolve, ms));
|
|
|
|
}
|