2023-07-18 01:22:47 +08:00
|
|
|
import { test, expect } from "@gradio/tootils";
|
|
|
|
|
|
|
|
test("chatinterface works with streaming functions and all buttons behave as expected", async ({
|
|
|
|
page
|
|
|
|
}) => {
|
2023-10-03 01:29:20 +08:00
|
|
|
const submit_button = await page.getByRole("button", { name: "Submit" });
|
|
|
|
const retry_button = await page.getByRole("button", { name: "🔄 Retry" });
|
|
|
|
const undo_button = await page.getByRole("button", { name: "↩️ Undo" });
|
|
|
|
const clear_button = await page.getByRole("button", { name: "🗑️ Clear" });
|
|
|
|
const textbox = await page.getByPlaceholder("Type a message...");
|
2023-07-18 01:22:47 +08:00
|
|
|
|
|
|
|
await textbox.fill("hello");
|
|
|
|
await submit_button.click();
|
|
|
|
await expect(textbox).toHaveValue("");
|
2023-10-03 01:29:20 +08:00
|
|
|
const bot_message_0 = await page.locator(".bot.message").nth(0);
|
2023-07-18 01:22:47 +08:00
|
|
|
await expect(bot_message_0).toContainText("You typed: hello");
|
|
|
|
|
|
|
|
await textbox.fill("hi");
|
|
|
|
await submit_button.click();
|
|
|
|
await expect(textbox).toHaveValue("");
|
2023-10-03 01:29:20 +08:00
|
|
|
const bot_message_1 = await page.locator(".bot").nth(1);
|
2023-07-18 01:22:47 +08:00
|
|
|
await expect(bot_message_1).toContainText("You typed: hi");
|
|
|
|
|
|
|
|
await retry_button.click();
|
|
|
|
await expect(textbox).toHaveValue("");
|
2023-12-15 04:40:36 +08:00
|
|
|
await expect(page.locator(".bot").nth(1)).toContainText("You typed: hi");
|
2023-07-18 01:22:47 +08:00
|
|
|
|
|
|
|
await undo_button.click();
|
2023-12-23 04:00:42 +08:00
|
|
|
await expect
|
|
|
|
.poll(async () => page.locator(".message.bot").count(), { timeout: 5000 })
|
|
|
|
.toBe(1);
|
2023-07-18 01:22:47 +08:00
|
|
|
await expect(textbox).toHaveValue("hi");
|
|
|
|
|
|
|
|
await textbox.fill("salaam");
|
|
|
|
await submit_button.click();
|
|
|
|
await expect(textbox).toHaveValue("");
|
2023-12-15 04:40:36 +08:00
|
|
|
await expect(page.locator(".bot").nth(1)).toContainText("You typed: salaam");
|
2023-07-18 01:22:47 +08:00
|
|
|
|
|
|
|
await clear_button.click();
|
2023-12-23 04:00:42 +08:00
|
|
|
await expect
|
|
|
|
.poll(async () => page.locator(".bot.message").count(), { timeout: 5000 })
|
|
|
|
.toBe(0);
|
2023-07-18 01:22:47 +08:00
|
|
|
});
|