gradio/js/app/test/test_chatinterface.reload.spec.ts
Freddy Boulton 7fc0f5149b
Fix reload mode by implementing close on the client (#8548)
* Fix reload mode

* add changeset

* reload test

* add changeset

---------

Co-authored-by: gradio-pr-bot <gradio-pr-bot@users.noreply.github.com>
2024-06-13 17:35:33 -04:00

82 lines
1.7 KiB
TypeScript

import { test, expect } from "@playwright/test";
import { spawnSync } from "node:child_process";
import { launch_app_background, kill_process } from "./utils";
import { join } from "path";
let _process;
const demo_file = "chat_demo.py";
test.beforeAll(() => {
const demo = `
import gradio as gr
def greet(msg, history):
return "Hello"
demo = gr.ChatInterface(fn=greet)
if __name__ == "__main__":
demo.launch()
`;
spawnSync(`echo '${demo}' > ${join(process.cwd(), demo_file)}`, {
shell: true,
stdio: "pipe",
env: {
...process.env,
PYTHONUNBUFFERED: "true"
}
});
});
test.afterAll(() => {
if (_process) kill_process(_process);
spawnSync(`rm ${join(process.cwd(), demo_file)}`, {
shell: true,
stdio: "pipe",
env: {
...process.env,
PYTHONUNBUFFERED: "true"
}
});
});
test("gradio dev mode correctly reloads a stateful ChatInterface demo", async ({
page
}) => {
test.setTimeout(20 * 1000);
try {
const port = 7890;
const { _process: server_process } = await launch_app_background(
`GRADIO_SERVER_PORT=${port} gradio ${join(process.cwd(), demo_file)}`,
process.cwd()
);
_process = server_process;
console.log("Connected to port", port);
const demo = `
import gradio as gr
def greet(msg, history):
return "Hello"
demo = gr.ChatInterface(fn=greet, textbox=gr.Textbox(label="foo"))
if __name__ == "__main__":
demo.launch()
`;
await page.goto(`http://localhost:${port}`);
spawnSync(`echo '${demo}' > ${join(process.cwd(), demo_file)}`, {
shell: true,
stdio: "pipe",
env: {
...process.env,
PYTHONUNBUFFERED: "true"
}
});
await expect(page.getByLabel("foo")).toBeVisible();
} finally {
if (_process) kill_process(_process);
}
});