mirror of
https://github.com/gradio-app/gradio.git
synced 2025-01-12 10:34:32 +08:00
26356a623c
* file type fix * add changeset * pdf test * format * test fixes * file test fix * file path fix * new test * format --------- Co-authored-by: gradio-pr-bot <gradio-pr-bot@users.noreply.github.com> Co-authored-by: Hannah <hannahblair@users.noreply.github.com>
74 lines
2.3 KiB
TypeScript
74 lines
2.3 KiB
TypeScript
import { test, expect, drag_and_drop_file } from "@gradio/tootils";
|
|
|
|
test("File component properly dispatches load event for the single file case.", async ({
|
|
page
|
|
}) => {
|
|
await page
|
|
.getByRole("button", { name: "Drop File Here - or - Click to Upload" })
|
|
.first()
|
|
.click();
|
|
const uploader = await page.locator("input[type=file]").first();
|
|
await uploader.setInputFiles(["./test/files/cheetah1.jpg"]);
|
|
|
|
await expect(page.getByLabel("# Load Upload Single File")).toHaveValue("1");
|
|
|
|
const downloadPromise = page.waitForEvent("download");
|
|
await page.getByRole("link").nth(0).click();
|
|
const download = await downloadPromise;
|
|
await expect(download.suggestedFilename()).toBe("cheetah1.jpg");
|
|
});
|
|
|
|
test("File component drag-and-drop uploads a file to the server correctly.", async ({
|
|
page
|
|
}) => {
|
|
const uploader = await page.locator("input[type=file]").nth(1);
|
|
await uploader.setInputFiles(["./test/files/alphabet.txt"]);
|
|
|
|
await expect(
|
|
page.getByLabel("# Load Upload Multiple Files").first()
|
|
).toHaveValue("1");
|
|
});
|
|
|
|
test("File component properly handles drag and drop of image and video files.", async ({
|
|
page
|
|
}) => {
|
|
const uploader = await page.locator("input[type=file]").nth(2);
|
|
await uploader.setInputFiles(["./test/files/cheetah1.jpg"]);
|
|
|
|
// Check that the image file was uploaded
|
|
await expect(
|
|
page.getByLabel("# Load Upload Multiple Files Image/Video")
|
|
).toHaveValue("1");
|
|
|
|
await page.getByLabel("Clear").click();
|
|
|
|
await uploader.setInputFiles(["./test/files/world.mp4"]);
|
|
|
|
// Check that the video file was uploaded
|
|
await expect(
|
|
page.getByLabel("# Load Upload Multiple Files Image/Video")
|
|
).toHaveValue("2");
|
|
});
|
|
|
|
test("File component properly handles drag and drop of pdf file.", async ({
|
|
page
|
|
}) => {
|
|
const uploader = await page.locator("input[type=file]").nth(3);
|
|
await uploader.setInputFiles(["./test/files/contract.pdf"]);
|
|
|
|
// Check that the pdf file was uploaded
|
|
await expect(page.getByLabel("# Load Upload PDF File")).toHaveValue("1");
|
|
});
|
|
|
|
test("File component properly handles invalid file_types.", async ({
|
|
page
|
|
}) => {
|
|
const uploader = await page.locator("input[type=file]").last();
|
|
await uploader.setInputFiles(["./test/files/cheetah1.jpg"]);
|
|
|
|
// Check that the pdf file was uploaded
|
|
await expect(
|
|
page.getByLabel("# Load Upload File with Invalid file_types")
|
|
).toHaveValue("1");
|
|
});
|