gradio/js/spa/test/test_chatinterface_examples.spec.ts
Abubakar Abid db162bfc59
enable lazy caching for chatinterface (#10015)
* lazy chat

* add changeset

* lazy caching

* lazy caching

* revert

* fix this

* changes

* changes

* format

* changes

* add env variable

* revert

* add changeset

* lazy

* fix

* chat interface

* fix test

---------

Co-authored-by: gradio-pr-bot <gradio-pr-bot@users.noreply.github.com>
2024-11-23 20:24:55 +00:00

51 lines
1.7 KiB
TypeScript

import { test, expect, go_to_testcase } from "@self/tootils";
const cases = [
"messages",
"tuples_examples",
"multimodal_tuples_examples",
"multimodal_messages_examples",
"eager_caching_examples",
"lazy_caching_examples"
];
for (const test_case of cases) {
test(`case ${test_case}: clicked example is added to history and passed to chat function`, async ({
page
}) => {
if (cases.slice(1).includes(test_case)) {
await go_to_testcase(page, test_case);
}
// Click on an example and the input/response are correct
await page.getByRole("button", { name: "Hey" }).click();
await expect(page.locator(".user p")).toContainText("Hey");
await expect(page.locator(".bot p")).toContainText("Hey");
// Clear the chat and click on a different example, the input/response are correct
await page.getByLabel("Clear").click();
await page
.getByRole("button", { name: "Can you explain briefly to me" })
.click();
await expect(page.locator(".user p")).toContainText(
"Can you explain briefly to me what is the Python programming language?"
);
await expect(page.locator(".bot p")).toContainText(
"Can you explain briefly to me what is the Python programming language?"
);
// Retry button works
await page.getByLabel("Retry").click();
await expect(page.locator(".user p")).toContainText(
"Can you explain briefly to me what is the Python programming language?"
);
await expect(page.locator(".bot p")).toContainText(
"Can you explain briefly to me what is the Python programming language?"
);
// Undo message resets to the examples view
await page.getByLabel("Undo", { exact: true }).click();
await expect(page.getByRole("button", { name: "Hey" })).toBeVisible();
});
}