|
import { test, expect } from "@gradio/tootils"; |
|
|
|
test("Gallery preview mode displays all images correctly.", async ({ |
|
page |
|
}) => { |
|
await page.getByRole("button", { name: "Run" }).click(); |
|
await page.getByLabel("Thumbnail 2 of 3").click(); |
|
|
|
await expect( |
|
await page.getByTestId("detailed-image").getAttribute("src") |
|
).toEqual("https://gradio-builds.s3.amazonaws.com/assets/lite-logo.png"); |
|
|
|
await expect( |
|
await page.getByTestId("thumbnail 1").getAttribute("src") |
|
).toEqual("https://gradio-builds.s3.amazonaws.com/assets/cheetah-003.jpg"); |
|
}); |
|
|
|
test("Gallery select event returns the right value and the download button works correctly", async ({ |
|
page |
|
}) => { |
|
await page.getByRole("button", { name: "Run" }).click(); |
|
await page.getByLabel("Thumbnail 2 of 3").click(); |
|
await expect(page.getByLabel("Select Data")).toHaveValue( |
|
"https://gradio-builds.s3.amazonaws.com/assets/lite-logo.png" |
|
); |
|
|
|
const downloadPromise = page.waitForEvent("download"); |
|
await page.getByLabel("Download").click(); |
|
const download = await downloadPromise; |
|
expect(download.suggestedFilename()).toBe("lite-logo.png"); |
|
}); |
|
|
|
test("Gallery click-to-upload, upload and change events work correctly", async ({ |
|
page |
|
}) => { |
|
await page |
|
.getByRole("button", { name: "Drop Image(s) Here - or - Click to Upload" }) |
|
.first() |
|
.click(); |
|
const uploader = await page.locator("input[type=file]").first(); |
|
await uploader.setInputFiles([ |
|
"./test/files/cheetah1.jpg", |
|
"./test/files/cheetah1.jpg" |
|
]); |
|
|
|
await expect(page.getByLabel("Num Upload")).toHaveValue("1"); |
|
await page.getByLabel("Clear").first().click(); |
|
await expect(page.getByLabel("Num Change")).toHaveValue("1"); |
|
}); |
|
|