92 lines
3.6 KiB
TypeScript
92 lines
3.6 KiB
TypeScript
import { expect, test } from "@playwright/test";
|
|
|
|
import { clickViewport, setViewportCreationPreview } from "./viewport-test-helpers";
|
|
|
|
for (const navigationMode of [
|
|
{
|
|
buttonLabel: "First Person",
|
|
name: "first-person"
|
|
},
|
|
{
|
|
buttonLabel: "Third Person",
|
|
name: "third-person"
|
|
}
|
|
] as const) {
|
|
test(`Interactable click prompt can teleport the player in ${navigationMode.name} run mode`, 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("outliner-add-button").click();
|
|
await page.getByTestId("add-menu-entities").click();
|
|
await page.getByTestId("add-menu-player-start").click();
|
|
await setViewportCreationPreview(page, "topLeft", { kind: "entity", entityKind: "playerStart", audioAssetId: null }, { x: 0, y: 0, z: 0 });
|
|
await clickViewport(page, "topLeft");
|
|
await page
|
|
.getByTestId("player-start-navigation-mode")
|
|
.selectOption(
|
|
navigationMode.buttonLabel === "First Person"
|
|
? "firstPerson"
|
|
: "thirdPerson"
|
|
);
|
|
await page.getByTestId("outliner-add-button").click();
|
|
await page.getByTestId("add-menu-entities").click();
|
|
await page.getByTestId("add-menu-interactable").click();
|
|
await setViewportCreationPreview(page, "topLeft", { kind: "entity", entityKind: "interactable", audioAssetId: null }, { x: 0, y: 0, z: 0 });
|
|
await clickViewport(page, "topLeft");
|
|
await page.getByTestId("interactable-position-y").fill("1");
|
|
await page.getByTestId("interactable-position-y").press("Tab");
|
|
await page.getByTestId("interactable-position-z").fill("1");
|
|
await page.getByTestId("interactable-position-z").press("Tab");
|
|
await page.getByTestId("interactable-radius").fill("4");
|
|
await page.getByTestId("interactable-radius").press("Tab");
|
|
await page.getByTestId("interactable-prompt").fill("Use Console");
|
|
await page.getByTestId("interactable-prompt").press("Tab");
|
|
|
|
await page.getByTestId("outliner-add-button").click();
|
|
await page.getByTestId("add-menu-entities").click();
|
|
await page.getByTestId("add-menu-teleport-target").click();
|
|
await setViewportCreationPreview(page, "topLeft", { kind: "entity", entityKind: "teleportTarget", audioAssetId: null }, { x: 0, y: 0, z: 0 });
|
|
await clickViewport(page, "topLeft");
|
|
await page.getByTestId("teleportTarget-position-x").fill("6");
|
|
await page.getByTestId("teleportTarget-position-x").press("Tab");
|
|
|
|
await page
|
|
.locator('[data-testid^="outliner-entity-"]')
|
|
.filter({ hasText: "Interactable" })
|
|
.first()
|
|
.click();
|
|
|
|
await page.getByTestId("add-interactable-teleport-link").click();
|
|
await page.getByTestId("enter-run-mode").click();
|
|
|
|
await expect(page.getByTestId("runner-shell")).toBeVisible();
|
|
await expect(page.getByTestId("runner-interaction-state")).toContainText(
|
|
"Ready"
|
|
);
|
|
await expect(page.getByTestId("runner-interaction-prompt")).toBeVisible();
|
|
await expect(page.getByTestId("runner-interaction-prompt-text")).toContainText("Use Console");
|
|
|
|
await page.locator('[data-testid="runner-shell"] canvas').click();
|
|
await expect(page.getByTestId("runner-player-position")).toContainText("6.00,");
|
|
|
|
expect(pageErrors).toEqual([]);
|
|
expect(consoleErrors).toEqual([]);
|
|
});
|
|
}
|