From 3d39dcc6582383f9c075a3a1b024f4df5c84b237 Mon Sep 17 00:00:00 2001 From: KnorpelSenf Date: Wed, 13 Nov 2024 18:22:30 +0100 Subject: [PATCH] test: cover prefixes and custom session keys --- test/convenience/session.test.ts | 44 ++++++++++++++++++++++++++++++++ 1 file changed, 44 insertions(+) diff --git a/test/convenience/session.test.ts b/test/convenience/session.test.ts index 8f9108ff..2e76eea3 100644 --- a/test/convenience/session.test.ts +++ b/test/convenience/session.test.ts @@ -126,6 +126,50 @@ describe("session", () => { assertEquals(storage.delete.calls[0].args, ["42"]); }); + it("should work with custom session keys", async () => { + let val: number | undefined = 0; + const storage = { + read: spy((_key: string) => val), + write: spy((_key: string, value: number) => { + val = value; + }), + delete: spy((_key: string) => { + val = undefined; + }), + }; + type C = Context & SessionFlavor; + const composer = new Composer(); + let ctx = { chatId: 42 } as C; + composer.use( + session({ + prefix: "xyz", + getSessionKey: (ctx) => + ctx.chatId ? (ctx.chatId ** 2).toString() : undefined, + storage, + }), + ) + .use((ctx) => { + if (ctx.session === 0) ctx.session = 1; + else ctx.session = null; + }); + + await composer.middleware()(ctx, next); + ctx = { chatId: 42 } as C; + await composer.middleware()(ctx, next); + + assertEquals(storage.read.calls.length, 2); + assertEquals(storage.read.calls[0].args, ["xyz-1764"]); + assertEquals(storage.read.calls[1].args, ["xyz-1764"]); + assertEquals(storage.read.calls[0].returned, 0); + assertEquals(storage.read.calls[1].returned, 1); + + assertEquals(storage.write.calls.length, 1); + assertEquals(storage.write.calls[0].args, ["xyz-1764", 1]); + + assertEquals(storage.delete.calls.length, 1); + assertEquals(storage.delete.calls[0].args, ["xyz-1764"]); + }); + it("should do IO with objects", async () => { let val: Record | undefined; const storage = {