Files
webeditor3d/tests/e2e/world-environment.e2e.ts
Victor Giers 650c36f9ef auto-git:
[change] tests/e2e/world-environment.e2e.ts
2026-04-22 14:04:45 +02:00

64 lines
2.6 KiB
TypeScript

import { expect, test, type Locator } from "@playwright/test";
async function setColorInput(locator: Locator, value: string) {
await locator.evaluate((element, nextValue) => {
const input = element as HTMLInputElement;
input.value = nextValue as string;
input.dispatchEvent(new Event("input", { bubbles: true }));
input.dispatchEvent(new Event("change", { bubbles: true }));
}, value);
}
test("world environment settings persist and carry into the runner", async ({ page }) => {
const pageErrors: string[] = [];
const consoleErrors: string[] = [];
page.on("pageerror", (error) => {
pageErrors.push(error.message);
});
page.on("console", (message) => {
if (message.type() === "error") {
consoleErrors.push(message.text());
}
});
await page.goto("/");
await page.evaluate((storageKey) => {
window.localStorage.removeItem(storageKey);
}, "webeditor3d.scene-document-draft");
await page.reload();
await page.getByTestId("world-background-mode-gradient").click();
await setColorInput(page.getByTestId("world-background-top-color"), "#6a87ab");
await setColorInput(page.getByTestId("world-background-bottom-color"), "#151b23");
await setColorInput(page.getByTestId("world-ambient-color"), "#d4e2ff");
await page.getByTestId("world-ambient-intensity").fill("0.45");
await page.getByTestId("world-ambient-intensity").press("Tab");
await page.getByTestId("world-sun-intensity").fill("2.25");
await page.getByTestId("world-sun-intensity").press("Tab");
await page.getByTestId("world-sun-direction-x").fill("-1");
await page.getByTestId("world-sun-direction-x").press("Tab");
await page.getByTestId("world-show-celestial-bodies").check();
await expect(page.getByTestId("world-background-mode-value")).toContainText("Vertical Gradient");
await expect(page.getByTestId("viewport-canvas-topLeft")).toHaveCSS("background-image", /linear-gradient/);
await page.waitForTimeout(400);
await page.reload();
await expect(page.getByTestId("world-background-mode-value")).toContainText("Vertical Gradient");
await expect(page.getByTestId("world-ambient-intensity")).toHaveValue("0.45");
await expect(page.getByTestId("world-show-celestial-bodies")).toBeChecked();
await expect(page.getByTestId("viewport-canvas-topLeft")).toHaveCSS("background-image", /linear-gradient/);
await page.getByTestId("enter-run-mode").click();
await expect(page.getByTestId("runner-shell")).toBeVisible();
await expect(page.getByTestId("runner-shell")).toHaveCSS("background-image", /linear-gradient/);
expect(pageErrors).toEqual([]);
expect(consoleErrors).toEqual([]);
});