import { expect, test } from "@playwright/test"; import { handleRunStream, mockLangGraphAPI } from "./utils/mock-api"; test.describe("Chat workspace", () => { test.beforeEach(async ({ page }) => { mockLangGraphAPI(page); }); test("new chat page loads with input box", async ({ page }) => { await page.goto("/workspace/chats/new"); const textarea = page.getByPlaceholder(/how can i assist you/i); await expect(textarea).toBeVisible({ timeout: 15_000 }); }); test("can type a message in the input box", async ({ page }) => { await page.goto("/workspace/chats/new"); const textarea = page.getByPlaceholder(/how can i assist you/i); await expect(textarea).toBeVisible({ timeout: 15_000 }); await textarea.fill("Hello, DeerFlow!"); await expect(textarea).toHaveValue("Hello, DeerFlow!"); }); test("sending a message triggers API call and shows response", async ({ page, }) => { let streamCalled = false; await page.route("**/runs/stream", (route) => { streamCalled = true; return handleRunStream(route); }); await page.goto("/workspace/chats/new"); const textarea = page.getByPlaceholder(/how can i assist you/i); await expect(textarea).toBeVisible({ timeout: 15_000 }); await textarea.fill("Hello"); await textarea.press("Enter"); await expect.poll(() => streamCalled, { timeout: 10_000 }).toBeTruthy(); // The AI response should appear in the chat await expect(page.getByText("Hello from DeerFlow!")).toBeVisible({ timeout: 10_000, }); }); test("keeps attachments visible while upload submit is pending", async ({ page, }) => { let releaseUpload!: () => void; const uploadCanFinish = new Promise((resolve) => { releaseUpload = resolve; }); let uploadStarted!: () => void; const uploadStartedPromise = new Promise((resolve) => { uploadStarted = resolve; }); await page.route("**/api/threads/*/uploads", async (route) => { uploadStarted(); await uploadCanFinish; return route.fulfill({ status: 200, contentType: "application/json", body: JSON.stringify({ success: true, message: "Uploaded", files: [ { filename: "report.docx", size: 12, path: "report.docx", virtual_path: "/mnt/user-data/uploads/report.docx", artifact_url: "/api/threads/test/uploads/report.docx", extension: ".docx", }, ], }), }); }); await page.goto("/workspace/chats/new"); const textarea = page.getByPlaceholder(/how can i assist you/i); await expect(textarea).toBeVisible({ timeout: 15_000 }); const promptForm = page.locator("form").filter({ has: textarea }); await page.getByLabel("Upload files").setInputFiles({ name: "report.docx", mimeType: "application/vnd.openxmlformats-officedocument.wordprocessingml.document", buffer: Buffer.from("fake docx"), }); await expect(promptForm.getByText("report.docx")).toBeVisible(); await textarea.fill("Summarize this document"); await textarea.press("Enter"); await uploadStartedPromise; await expect(promptForm.getByText("report.docx")).toBeVisible(); releaseUpload(); await expect(page.getByText("Hello from DeerFlow!")).toBeVisible({ timeout: 10_000, }); await expect(promptForm.getByText("report.docx")).toBeHidden(); }); });