From b8e3af6ccc03dc94b6d582c897b113e55dc6a2b7 Mon Sep 17 00:00:00 2001 From: hasundue Date: Fri, 22 Mar 2024 15:42:09 +0900 Subject: [PATCH] test(std/watch): add tests for closing streams --- std/watch_test.ts | 18 ++++++++++++++++++ 1 file changed, 18 insertions(+) diff --git a/std/watch_test.ts b/std/watch_test.ts index 2b242f8..bf01542 100644 --- a/std/watch_test.ts +++ b/std/watch_test.ts @@ -41,6 +41,15 @@ describe("watch - websockets", () => { assertEquals(value.type, "message"); assertEquals(value.data, "test"); }); + + it("should remove the event listener when the stream is canceled", async () => { + const stream = watch(ws)("message"); + const reader = stream.getReader(); + reader.cancel(); + ws.dispatchEvent(new MessageEvent("message", { data: "test" })); + const { done } = await reader.read(); + assertEquals(done, true); + }); }); describe("watch - relays", () => { @@ -85,4 +94,13 @@ describe("watch - relays", () => { assertEquals(value.type, "receive"); assertEquals(value.data, ["NOTICE", "test"]); }); + + it("should remove the event listener when the stream is canceled", async () => { + const stream = watch(relay)("receive"); + const reader = stream.getReader(); + reader.cancel(); + relay.dispatch("receive", ["NOTICE", "test"]); + const { done } = await reader.read(); + assertEquals(done, true); + }); });