| 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"); | |
| }); | |