mirror of
https://github.com/ashim-hq/ashim
synced 2026-04-21 13:37:52 +00:00
- Delete 3 dead files: use-batch-processor.ts, use-i18n.ts, smart-crop.ts (AI package) - Remove dead getJobProgress function and unused runPythonScript wrapper - Remove 6 unused imports across API and web apps - Remove unused shared types (ImageFormat, AppConfig, ApiError, HealthResponse, JobProgress) and constants (SUPPORTED_INPUT_FORMATS/OUTPUT_FORMATS, DEFAULT_OUTPUT_FORMAT) - Remove unused store method (setOriginalBlobUrl) and clean AI package re-exports - Add test infrastructure: vitest config, unit/integration/e2e tests, fixtures, screenshots - Add Docker test infrastructure: Dockerfile.test, docker-compose.test.yml - Add download_models.py for pre-baking AI model weights in Docker - Add filename sanitization utility (apps/api/src/lib/filename.ts) - Update .gitignore to exclude coverage/, *.tsbuildinfo, .superpowers/, test artifacts - Update .dockerignore to exclude test/coverage/IDE artifacts from builds - Update docs: remove smart crop from AI docs (uses Sharp directly), update bridge docs
115 lines
4.4 KiB
TypeScript
115 lines
4.4 KiB
TypeScript
import { test, expect, uploadTestImage, waitForProcessing } from "./helpers";
|
|
|
|
test.describe("Essential Tools", () => {
|
|
// ── Resize ────────────────────────────────────────────────────────────
|
|
test("resize tool page renders correctly", async ({
|
|
loggedInPage: page,
|
|
}) => {
|
|
await page.goto("/resize");
|
|
|
|
// Tool header
|
|
await expect(page.getByText("Resize").first()).toBeVisible();
|
|
|
|
// Should show dropzone when no file uploaded
|
|
await expect(page.getByText("Upload from computer")).toBeVisible();
|
|
});
|
|
|
|
test("resize tool shows settings after upload", async ({
|
|
loggedInPage: page,
|
|
}) => {
|
|
await page.goto("/resize");
|
|
await uploadTestImage(page);
|
|
|
|
// Should show settings panel with width/height inputs
|
|
await expect(page.getByText("Settings").first()).toBeVisible();
|
|
// Should show the image viewer instead of dropzone
|
|
await expect(page.getByText("Upload from computer")).not.toBeVisible();
|
|
});
|
|
|
|
test("resize tool processes an image", async ({ loggedInPage: page }) => {
|
|
await page.goto("/resize");
|
|
await uploadTestImage(page);
|
|
|
|
// Set width (required for resize)
|
|
await page.locator("input[placeholder='Auto']").first().fill("50");
|
|
|
|
await page.getByRole("button", { name: "Resize" }).click();
|
|
await waitForProcessing(page);
|
|
|
|
await expect(
|
|
page.getByRole("link", { name: /download/i }).first(),
|
|
).toBeVisible({ timeout: 15_000 });
|
|
});
|
|
|
|
// ── Crop ──────────────────────────────────────────────────────────────
|
|
test("crop tool page renders correctly", async ({ loggedInPage: page }) => {
|
|
await page.goto("/crop");
|
|
await expect(page.getByText("Crop").first()).toBeVisible();
|
|
await expect(page.getByText("Upload from computer")).toBeVisible();
|
|
});
|
|
|
|
test("crop tool shows settings after upload", async ({
|
|
loggedInPage: page,
|
|
}) => {
|
|
await page.goto("/crop");
|
|
await uploadTestImage(page);
|
|
await expect(page.getByText("Settings").first()).toBeVisible();
|
|
});
|
|
|
|
// ── Rotate & Flip ────────────────────────────────────────────────────
|
|
test("rotate tool page renders correctly", async ({
|
|
loggedInPage: page,
|
|
}) => {
|
|
await page.goto("/rotate");
|
|
await expect(page.getByText("Rotate").first()).toBeVisible();
|
|
await expect(page.getByText("Upload from computer")).toBeVisible();
|
|
});
|
|
|
|
test("rotate tool shows settings after upload", async ({
|
|
loggedInPage: page,
|
|
}) => {
|
|
await page.goto("/rotate");
|
|
await uploadTestImage(page);
|
|
await expect(page.getByText("Settings").first()).toBeVisible();
|
|
});
|
|
|
|
// ── Convert ───────────────────────────────────────────────────────────
|
|
test("convert tool page renders correctly", async ({
|
|
loggedInPage: page,
|
|
}) => {
|
|
await page.goto("/convert");
|
|
await expect(page.getByText("Convert").first()).toBeVisible();
|
|
await expect(page.getByText("Upload from computer")).toBeVisible();
|
|
});
|
|
|
|
test("convert tool shows format selector after upload", async ({
|
|
loggedInPage: page,
|
|
}) => {
|
|
await page.goto("/convert");
|
|
await uploadTestImage(page);
|
|
await expect(page.getByText("Settings").first()).toBeVisible();
|
|
});
|
|
|
|
// ── Compress ──────────────────────────────────────────────────────────
|
|
test("compress tool page renders correctly", async ({
|
|
loggedInPage: page,
|
|
}) => {
|
|
await page.goto("/compress");
|
|
await expect(page.getByText("Compress").first()).toBeVisible();
|
|
await expect(page.getByText("Upload from computer")).toBeVisible();
|
|
});
|
|
|
|
test("compress tool processes an image", async ({ loggedInPage: page }) => {
|
|
await page.goto("/compress");
|
|
await uploadTestImage(page);
|
|
|
|
// Use submit button to avoid matching "Processed:" text
|
|
await page.locator("button[type='submit']").click();
|
|
|
|
await waitForProcessing(page);
|
|
|
|
await expect(
|
|
page.getByRole("link", { name: /download/i }).first(),
|
|
).toBeVisible({ timeout: 15_000 });
|
|
});
|
|
});
|