0
Fork 0
mirror of https://github.com/penpot/penpot.git synced 2025-01-24 15:39:50 -05:00

♻️ Refactor MockWebSocket

This commit is contained in:
AzazelN28 2024-05-07 11:18:35 +02:00
parent 3bae6e4661
commit 572c6f02e2
3 changed files with 91 additions and 22 deletions

View file

@ -1,5 +1,72 @@
export class WebSocketManager { export class MockWebSocket extends EventTarget {
static #mocks = new Map();
static async init(page) { static async init(page) {
await page.exposeFunction("MockWebSocket$$constructor", (url, protocols) => {
console.log("MockWebSocket$$constructor", MockWebSocket, url, protocols);
const webSocket = new MockWebSocket(page, url, protocols);
this.#mocks.set(url, webSocket);
});
await page.exposeFunction("MockWebSocket$$spyMessage", (url, data) => {
console.log("MockWebSocket$$spyMessage", url, data);
this.#mocks.get(url).dispatchEvent(new MessageEvent("message", { data }));
});
await page.exposeFunction("MockWebSocket$$spyClose", (url, code, reason) => {
console.log("MockWebSocket$$spyClose", url, code, reason);
this.#mocks.get(url).dispatchEvent(new CloseEvent("close", { code, reason }));
});
await page.addInitScript({ path: "playwright/scripts/MockWebSocket.js" }); await page.addInitScript({ path: "playwright/scripts/MockWebSocket.js" });
} }
static waitForURL(url) {
return new Promise((resolve) => {
const intervalID = setInterval(() => {
for (const [wsURL, ws] of this.#mocks) {
console.log('waitForURL', wsURL);
if (wsURL.includes(url)) {
clearInterval(intervalID);
return resolve(ws);
}
}
}, 30);
});
}
#page = null;
#url;
#protocols;
constructor(page, url, protocols) {
super();
this.#page = page;
this.#url = url;
this.#protocols = protocols;
}
mockOpen(options) {
return this.#page.evaluate(({ url, options }) => {
if (typeof WebSocket.getByURL !== 'function') {
throw new Error('WebSocket.getByURL is not a function. Did you forget to call MockWebSocket.init(page)?')
}
WebSocket.getByURL(url).mockOpen(options);
}, { url: this.#url, options });
}
mockMessage(data) {
return this.#page.evaluate(({ url, data }) => {
if (typeof WebSocket.getByURL !== 'function') {
throw new Error('WebSocket.getByURL is not a function. Did you forget to call MockWebSocket.init(page)?')
}
WebSocket.getByURL(url).mockMessage(data);
}, { url: this.#url, data });
}
mockClose() {
return this.#page.evaluate(({ url }) => {
if (typeof WebSocket.getByURL !== 'function') {
throw new Error('WebSocket.getByURL is not a function. Did you forget to call MockWebSocket.init(page)?')
}
WebSocket.getByURL(url).mockClose();
}, { url: this.#url });
}
} }

View file

@ -11,20 +11,15 @@ window.WebSocket = class MockWebSocket extends EventTarget {
} }
static getByURL(url) { static getByURL(url) {
if (this.#mocks.has(url)) {
return this.#mocks.get(url); return this.#mocks.get(url);
} }
static waitForURL(url) {
return new Promise((resolve) => {
let intervalID = setInterval(() => {
for (const [wsURL, ws] of this.#mocks) { for (const [wsURL, ws] of this.#mocks) {
if (wsURL.includes(url)) { if (wsURL.includes(url)) {
clearInterval(intervalID); return ws;
resolve(ws);
} }
} }
}, 30); return undefined;
});
} }
#url; #url;

View file

@ -1,6 +1,6 @@
import { test, expect } from "@playwright/test"; import { test, expect } from "@playwright/test";
import { interceptRPC, interceptRPCByRegex } from "./helpers/MockAPI"; import { interceptRPC, interceptRPCByRegex } from "./helpers/MockAPI";
import { WebSocketManager } from "./helpers/MockWebSocket"; import { MockWebSocket } from "./helpers/MockWebSocket";
import { presenceFixture } from "./fixtures/workspace/ws-notifications"; import { presenceFixture } from "./fixtures/workspace/ws-notifications";
const anyProjectId = "c7ce0794-0992-8105-8004-38e630f7920b"; const anyProjectId = "c7ce0794-0992-8105-8004-38e630f7920b";
@ -30,7 +30,7 @@ const setupWorkspaceUser = (page) => {
}; };
test.beforeEach(async ({ page }) => { test.beforeEach(async ({ page }) => {
await WebSocketManager.init(page); await MockWebSocket.init(page);
}); });
test("User loads worskpace with empty file", async ({ page }) => { test("User loads worskpace with empty file", async ({ page }) => {
@ -45,13 +45,15 @@ test.only("User receives notifications updates in the workspace", async ({ page
await setupWorkspaceUser(page); await setupWorkspaceUser(page);
await page.goto(`/#/workspace/${anyProjectId}/${anyFileId}?page-id=${anyPageId}`); await page.goto(`/#/workspace/${anyProjectId}/${anyFileId}?page-id=${anyPageId}`);
await page.evaluate(async () => { const ws = await MockWebSocket.waitForURL("ws://0.0.0.0:3500/ws/notifications")
const ws = await WebSocket.waitForURL("ws://0.0.0.0:3500/ws/notifications"); await ws.mockOpen();
ws.mockOpen(); console.log('JEEEEEE', ws)
});
await expect(page.getByTestId("page-name")).toHaveText("Page 1"); await expect(page.getByTestId("page-name")).toHaveText("Page 1");
await ws.mockMessage(JSON.stringify(presenceFixture));
/*
await page.evaluate( await page.evaluate(
async ({ presenceFixture }) => { async ({ presenceFixture }) => {
const ws = await WebSocket.waitForURL("ws://0.0.0.0:3500/ws/notifications"); const ws = await WebSocket.waitForURL("ws://0.0.0.0:3500/ws/notifications");
@ -59,11 +61,16 @@ test.only("User receives notifications updates in the workspace", async ({ page
}, },
{ presenceFixture }, { presenceFixture },
); );
*/
expect(page.getByTestId("active-users-list").getByAltText("Princesa Leia")).toHaveCount(2); await expect(page.getByTestId("active-users-list").getByAltText("Princesa Leia")).toHaveCount(2);
await ws.mockClose();
/*
await page.evaluate(async () => { await page.evaluate(async () => {
const ws = await WebSocket.waitForURL("ws://0.0.0.0:3500/ws/notifications"); const ws = await WebSocket.waitForURL("ws://0.0.0.0:3500/ws/notifications");
ws.mockClose(); ws.mockClose();
}); });
*/
}); });