From da63fc68d76a44e441f74924337df5c4926b07c0 Mon Sep 17 00:00:00 2001 From: Kevin Viglucci Date: Fri, 14 Jun 2024 22:11:30 -0500 Subject: [PATCH] test: additional server WebsocketDuplexConnection tests --- .../WebsocketDuplexConnection.spec.ts | 141 ++++++++---------- 1 file changed, 65 insertions(+), 76 deletions(-) diff --git a/packages/rsocket-websocket-server/src/__tests__/WebsocketDuplexConnection.spec.ts b/packages/rsocket-websocket-server/src/__tests__/WebsocketDuplexConnection.spec.ts index 89ab70d..c6462d4 100644 --- a/packages/rsocket-websocket-server/src/__tests__/WebsocketDuplexConnection.spec.ts +++ b/packages/rsocket-websocket-server/src/__tests__/WebsocketDuplexConnection.spec.ts @@ -1,20 +1,23 @@ import { mock } from "jest-mock-extended"; -import { - Demultiplexer, - Deserializer, - Flags, - Frame, - FrameHandler, - FrameTypes, - Multiplexer, - serializeFrame, - SetupFrame, -} from "rsocket-core"; +import { Demultiplexer, Frame, FrameHandler, Multiplexer } from "rsocket-core"; import { WebsocketDuplexConnection } from "../WebsocketDuplexConnection"; -// import { MockSocket } from "../__mocks__/ws"; import { Duplex } from "stream"; -// const deserializer = mock(); +function makeDuplexStub() { + const listeners = { + close: [], + }; + return mock({ + on(event, cb) { + listeners[event]?.push(cb); + return this; + }, + destroy(error?: Error) { + listeners.close.forEach((cb) => cb(error)); + return this; + }, + }); +} describe("WebsocketDuplexConnection", function () { describe("when closed", () => { @@ -125,69 +128,55 @@ describe("WebsocketDuplexConnection", function () { expect(onCloseCallback).toBeCalledTimes(1); expect(onCloseCallback).toBeCalledWith(error); }); - // - // it("subsequent calls to close result in only a single invocation of onClose", () => { - // const socketStub = mock(); - // const multiplexerDemultiplexer = mock< - // Multiplexer & Demultiplexer & FrameHandler - // >(); - // const connection = new WebsocketDuplexConnection( - // socketStub, - // deserializer, - // () => multiplexerDemultiplexer - // ); - // const onCloseCallback = jest.fn(); - // const error = new Error(); - // connection.onClose(onCloseCallback); - // connection.close(error); - // connection.close(error); - // - // expect(onCloseCallback).toBeCalledTimes(1); - // expect(onCloseCallback).toBeCalledWith(error); - // }); - // - // it("the onClose callback is called with an error when the socket is closed unexpectedly", () => { - // const socket = new MockSocket() as unknown as WebSocket; - // const multiplexerDemultiplexer = mock< - // Multiplexer & Demultiplexer & FrameHandler - // >(); - // const connection = new WebsocketDuplexConnection( - // socket, - // deserializer, - // () => multiplexerDemultiplexer - // ); - // const onCloseCallback = jest.fn(); - // - // connection.onClose(onCloseCallback); - // (socket as unknown as MockSocket).mock.close({}); - // - // expect(onCloseCallback).toBeCalledTimes(1); - // expect(onCloseCallback).toHaveBeenCalledWith( - // new Error("WebsocketDuplexConnection: Socket closed unexpectedly.") - // ); - // }); - // - // it("the onClose callback is called with an error when the socket is closed with an error", () => { - // const socket = new MockSocket() as unknown as WebSocket; - // const multiplexerDemultiplexer = mock< - // Multiplexer & Demultiplexer & FrameHandler - // >(); - // const connection = new WebsocketDuplexConnection( - // socket, - // deserializer, - // () => multiplexerDemultiplexer - // ); - // const onCloseCallback = jest.fn(); - // const expectedError = new Error( - // "WebsocketDuplexConnection: Test error 1" - // ); - // - // connection.onClose(onCloseCallback); - // (socket as unknown as MockSocket).mock.error({ error: expectedError }); - // - // expect(onCloseCallback).toBeCalledTimes(1); - // expect(onCloseCallback).toHaveBeenCalledWith(expectedError); - // }); + + it("subsequent calls to close result in only a single invocation of onClose", () => { + // arrange + const socketStub = mock(); + const multiplexerDemultiplexer = mock< + Multiplexer & Demultiplexer & FrameHandler + >(); + const frame = mock(); + const connection = new WebsocketDuplexConnection( + socketStub, + frame, + () => multiplexerDemultiplexer + ); + const onCloseCallback = jest.fn(); + const error = new Error(); + connection.onClose(onCloseCallback); + + // act + connection.close(error); + connection.close(error); + + // assert + expect(onCloseCallback).toBeCalledTimes(1); + expect(onCloseCallback).toBeCalledWith(error); + }); + + it("the onClose callback is called with an error when the socket is destroyed unexpectedly", () => { + // arrange + + const socketStub = makeDuplexStub(); + const multiplexerDemultiplexer = mock< + Multiplexer & Demultiplexer & FrameHandler + >(); + const frame = mock(); + const connection = new WebsocketDuplexConnection( + socketStub, + frame, + () => multiplexerDemultiplexer + ); + const onCloseCallback = jest.fn(); + + connection.onClose(onCloseCallback); + (socketStub as unknown as Duplex).destroy(new Error("simulated error")); + + expect(onCloseCallback).toBeCalledTimes(1); + expect(onCloseCallback).toHaveBeenCalledWith( + new Error("WebsocketDuplexConnection: Socket closed unexpectedly.") + ); + }); }); // describe("send()", () => {