2024-05-07 13:12:58 +02:00
|
|
|
import { test, expect } from "@playwright/test";
|
2024-05-08 14:22:18 +02:00
|
|
|
import { WorkspacePage } from "../pages/WorkspacePage";
|
2024-05-07 13:12:58 +02:00
|
|
|
import { presenceFixture } from "../../data/workspace/ws-notifications";
|
|
|
|
|
|
|
|
test.beforeEach(async ({ page }) => {
|
2024-05-08 14:22:18 +02:00
|
|
|
await WorkspacePage.init(page);
|
2024-05-07 13:12:58 +02:00
|
|
|
});
|
|
|
|
|
2024-05-14 15:13:11 +02:00
|
|
|
test("User loads worskpace with empty file", async ({ page }) => {
|
2024-05-08 14:22:18 +02:00
|
|
|
const workspacePage = new WorkspacePage(page);
|
|
|
|
await workspacePage.setupEmptyFile(page);
|
2024-05-07 13:12:58 +02:00
|
|
|
|
2024-05-08 14:22:18 +02:00
|
|
|
await workspacePage.goToWorkspace();
|
2024-05-07 13:12:58 +02:00
|
|
|
|
2024-05-08 14:22:18 +02:00
|
|
|
await expect(workspacePage.pageName).toHaveText("Page 1");
|
2024-05-07 13:12:58 +02:00
|
|
|
});
|
|
|
|
|
2024-07-01 10:28:40 +02:00
|
|
|
test("User receives presence notifications updates in the workspace", async ({
|
|
|
|
page,
|
|
|
|
}) => {
|
2024-05-08 14:22:18 +02:00
|
|
|
const workspacePage = new WorkspacePage(page);
|
|
|
|
await workspacePage.setupEmptyFile();
|
|
|
|
|
|
|
|
await workspacePage.goToWorkspace();
|
|
|
|
await workspacePage.sendPresenceMessage(presenceFixture);
|
2024-05-07 13:12:58 +02:00
|
|
|
|
2024-07-01 10:28:40 +02:00
|
|
|
await expect(
|
|
|
|
page.getByTestId("active-users-list").getByAltText("Princesa Leia"),
|
|
|
|
).toHaveCount(2);
|
2024-05-07 13:12:58 +02:00
|
|
|
});
|
2024-05-09 12:57:51 +02:00
|
|
|
|
2024-05-14 15:13:11 +02:00
|
|
|
test("User draws a rect", async ({ page }) => {
|
2024-05-09 12:57:51 +02:00
|
|
|
const workspacePage = new WorkspacePage(page);
|
|
|
|
await workspacePage.setupEmptyFile();
|
2024-07-01 10:28:40 +02:00
|
|
|
await workspacePage.mockRPC(
|
|
|
|
"update-file?id=*",
|
|
|
|
"workspace/update-file-create-rect.json",
|
|
|
|
);
|
2024-05-09 12:57:51 +02:00
|
|
|
|
|
|
|
await workspacePage.goToWorkspace();
|
|
|
|
await workspacePage.rectShapeButton.click();
|
|
|
|
await workspacePage.clickWithDragViewportAt(128, 128, 200, 100);
|
|
|
|
|
|
|
|
const shape = await workspacePage.rootShape.locator("rect");
|
2024-05-13 17:17:16 +02:00
|
|
|
await expect(shape).toHaveAttribute("width", "200");
|
|
|
|
await expect(shape).toHaveAttribute("height", "100");
|
2024-05-09 12:57:51 +02:00
|
|
|
});
|
2024-06-06 12:28:41 +02:00
|
|
|
|
2024-06-11 09:59:35 +02:00
|
|
|
test("User makes a group", async ({ page }) => {
|
|
|
|
const workspacePage = new WorkspacePage(page);
|
|
|
|
await workspacePage.setupEmptyFile();
|
2024-07-01 10:28:40 +02:00
|
|
|
await workspacePage.mockRPC(
|
|
|
|
/get\-file\?/,
|
|
|
|
"workspace/get-file-not-empty.json",
|
|
|
|
);
|
|
|
|
await workspacePage.mockRPC(
|
|
|
|
"update-file?id=*",
|
|
|
|
"workspace/update-file-create-rect.json",
|
|
|
|
);
|
2024-06-11 09:59:35 +02:00
|
|
|
|
2024-06-11 15:43:28 +02:00
|
|
|
await workspacePage.goToWorkspace({
|
|
|
|
fileId: "6191cd35-bb1f-81f7-8004-7cc63d087374",
|
|
|
|
pageId: "6191cd35-bb1f-81f7-8004-7cc63d087375",
|
2024-06-11 09:59:35 +02:00
|
|
|
});
|
|
|
|
await workspacePage.clickLeafLayer("Rectangle");
|
2024-06-26 17:02:24 +02:00
|
|
|
await workspacePage.page.keyboard.press("Control+g");
|
2024-06-11 09:59:35 +02:00
|
|
|
await workspacePage.expectSelectedLayer("Group");
|
|
|
|
});
|
2024-06-12 13:12:58 +02:00
|
|
|
|
2024-07-01 10:28:40 +02:00
|
|
|
test("Bug 7654 - Toolbar keeps toggling on and off on spacebar press", async ({
|
|
|
|
page,
|
|
|
|
}) => {
|
2024-06-12 13:12:58 +02:00
|
|
|
const workspacePage = new WorkspacePage(page);
|
|
|
|
await workspacePage.setupEmptyFile();
|
|
|
|
await workspacePage.goToWorkspace();
|
|
|
|
|
|
|
|
await workspacePage.toggleToolbarButton.click();
|
|
|
|
await workspacePage.page.keyboard.press("Backspace");
|
|
|
|
await workspacePage.page.keyboard.press("Enter");
|
|
|
|
await workspacePage.expectHiddenToolbarOptions();
|
|
|
|
});
|
2024-06-12 12:02:12 +02:00
|
|
|
|
2024-07-01 10:28:40 +02:00
|
|
|
test("Bug 7525 - User moves a scrollbar and no selciont rectangle appears", async ({
|
|
|
|
page,
|
|
|
|
}) => {
|
2024-06-12 12:02:12 +02:00
|
|
|
const workspacePage = new WorkspacePage(page);
|
|
|
|
await workspacePage.setupEmptyFile();
|
2024-07-01 10:28:40 +02:00
|
|
|
await workspacePage.mockRPC(
|
|
|
|
/get\-file\?/,
|
|
|
|
"workspace/get-file-not-empty.json",
|
|
|
|
);
|
|
|
|
await workspacePage.mockRPC(
|
|
|
|
"update-file?id=*",
|
|
|
|
"workspace/update-file-create-rect.json",
|
|
|
|
);
|
2024-06-12 12:02:12 +02:00
|
|
|
|
|
|
|
await workspacePage.goToWorkspace({
|
|
|
|
fileId: "6191cd35-bb1f-81f7-8004-7cc63d087374",
|
|
|
|
pageId: "6191cd35-bb1f-81f7-8004-7cc63d087375",
|
|
|
|
});
|
|
|
|
|
|
|
|
// Move created rect to a corner, in orther to get scrollbars
|
|
|
|
await workspacePage.panOnViewportAt(128, 128, 300, 300);
|
|
|
|
|
|
|
|
// Check scrollbars appear
|
|
|
|
const horizontalScrollbar = workspacePage.horizontalScrollbar;
|
|
|
|
await expect(horizontalScrollbar).toBeVisible();
|
|
|
|
|
|
|
|
// Grab scrollbar and move
|
2024-07-01 10:28:40 +02:00
|
|
|
const { x, y } = await horizontalScrollbar.boundingBox();
|
2024-06-12 12:02:12 +02:00
|
|
|
await page.waitForTimeout(100);
|
|
|
|
await workspacePage.viewport.hover({ position: { x: x, y: y + 5 } });
|
|
|
|
await page.mouse.down();
|
|
|
|
await workspacePage.viewport.hover({ position: { x: x - 130, y: y - 95 } });
|
|
|
|
|
|
|
|
await expect(workspacePage.selectionRect).not.toBeInViewport();
|
|
|
|
});
|
2024-06-06 12:28:41 +02:00
|
|
|
|
2024-07-01 10:28:40 +02:00
|
|
|
test("User adds a library and its automatically selected in the color palette", async ({
|
|
|
|
page,
|
|
|
|
}) => {
|
2024-06-06 12:28:41 +02:00
|
|
|
const workspacePage = new WorkspacePage(page);
|
|
|
|
await workspacePage.setupEmptyFile();
|
2024-07-01 10:28:40 +02:00
|
|
|
await workspacePage.mockRPC(
|
|
|
|
"link-file-to-library",
|
|
|
|
"workspace/link-file-to-library.json",
|
|
|
|
);
|
|
|
|
await workspacePage.mockRPC(
|
|
|
|
"unlink-file-from-library",
|
|
|
|
"workspace/unlink-file-from-library.json",
|
|
|
|
);
|
|
|
|
await workspacePage.mockRPC(
|
|
|
|
"get-team-shared-files?team-id=*",
|
|
|
|
"workspace/get-team-shared-libraries-non-empty.json",
|
|
|
|
);
|
|
|
|
|
2024-06-06 12:28:41 +02:00
|
|
|
await workspacePage.goToWorkspace();
|
|
|
|
|
|
|
|
// Add Testing library 1
|
|
|
|
await workspacePage.clickColorPalette();
|
|
|
|
await workspacePage.clickAssets();
|
|
|
|
// Now the get-file call should return a library
|
|
|
|
await workspacePage.mockRPC(/get\-file\?/, "workspace/get-file-library.json");
|
|
|
|
await workspacePage.openLibrariesModal();
|
2024-07-01 10:28:40 +02:00
|
|
|
await workspacePage.clickLibrary("Testing library 1");
|
|
|
|
await workspacePage.closeLibrariesModal();
|
2024-06-06 12:28:41 +02:00
|
|
|
|
2024-07-01 10:28:40 +02:00
|
|
|
await expect(
|
|
|
|
workspacePage.palette.getByRole("button", { name: "test-color-187cd5" }),
|
|
|
|
).toBeVisible();
|
2024-06-06 12:28:41 +02:00
|
|
|
|
|
|
|
// Remove Testing library 1
|
|
|
|
await workspacePage.openLibrariesModal();
|
2024-07-01 10:28:40 +02:00
|
|
|
await workspacePage.clickLibrary("Testing library 1");
|
2024-06-06 12:28:41 +02:00
|
|
|
await workspacePage.closeLibrariesModal();
|
|
|
|
|
2024-07-01 10:28:40 +02:00
|
|
|
await expect(
|
|
|
|
workspacePage.palette.getByText(
|
|
|
|
"There are no color styles in your library yet",
|
|
|
|
),
|
|
|
|
).toBeVisible();
|
2024-06-06 12:28:41 +02:00
|
|
|
});
|
2024-06-13 12:55:04 +02:00
|
|
|
|
2024-07-01 10:28:40 +02:00
|
|
|
test("Bug 7489 - Workspace-palette items stay hidden when opening with keyboard-shortcut", async ({
|
|
|
|
page,
|
|
|
|
}) => {
|
2024-06-13 12:55:04 +02:00
|
|
|
const workspacePage = new WorkspacePage(page);
|
|
|
|
await workspacePage.setupEmptyFile();
|
|
|
|
await workspacePage.goToWorkspace();
|
|
|
|
|
|
|
|
await workspacePage.clickTogglePalettesVisibility();
|
|
|
|
await workspacePage.page.keyboard.press("Alt+t");
|
|
|
|
|
2024-07-01 10:28:40 +02:00
|
|
|
await expect(
|
|
|
|
workspacePage.palette.getByText(
|
|
|
|
"There are no typography styles in your library yet",
|
|
|
|
),
|
|
|
|
).toBeVisible();
|
2024-06-13 12:55:04 +02:00
|
|
|
});
|
2024-09-17 16:29:02 +02:00
|
|
|
|
|
|
|
test("Bug 8784 - Use keyboard arrow to move inside a text input does not change tabs", async ({
|
|
|
|
page,
|
|
|
|
}) => {
|
|
|
|
const workspacePage = new WorkspacePage(page);
|
|
|
|
await workspacePage.setupEmptyFile();
|
|
|
|
await workspacePage.goToWorkspace();
|
|
|
|
await workspacePage.pageName.click();
|
|
|
|
await page.keyboard.press("ArrowLeft");
|
|
|
|
|
|
|
|
await expect(workspacePage.pageName).toHaveText("Page 1");
|
|
|
|
});
|
2024-10-22 16:12:58 +02:00
|
|
|
|
|
|
|
test("Bug 9066 - Problem with grid layout", async ({ page }) => {
|
|
|
|
const workspacePage = new WorkspacePage(page);
|
|
|
|
await workspacePage.setupEmptyFile(page);
|
|
|
|
await workspacePage.mockRPC(/get\-file\?/, "workspace/get-file-9066.json");
|
|
|
|
await workspacePage.mockRPC(
|
|
|
|
"get-file-fragment?file-id=*&fragment-id=e179d9df-de35-80bf-8005-2861e849b3f7",
|
|
|
|
"workspace/get-file-fragment-9066-1.json",
|
|
|
|
);
|
|
|
|
await workspacePage.mockRPC(
|
|
|
|
"get-file-fragment?file-id=*&fragment-id=e179d9df-de35-80bf-8005-2861e849785e",
|
|
|
|
"workspace/get-file-fragment-9066-2.json",
|
|
|
|
);
|
|
|
|
|
|
|
|
await workspacePage.mockRPC(
|
|
|
|
"update-file?id=*",
|
|
|
|
"workspace/update-file-create-rect.json",
|
|
|
|
);
|
|
|
|
|
|
|
|
await workspacePage.goToWorkspace({
|
|
|
|
fileId: "e179d9df-de35-80bf-8005-283bbd5516b0",
|
|
|
|
pageId: "e179d9df-de35-80bf-8005-283bbd5516b1",
|
|
|
|
});
|
|
|
|
|
|
|
|
await workspacePage.clickToggableLayer("Board");
|
|
|
|
await workspacePage.clickToggableLayer("Group");
|
|
|
|
await page.getByText("A", { exact: true }).click();
|
|
|
|
|
|
|
|
await workspacePage.rightSidebar.getByTestId("swap-component-btn").click();
|
|
|
|
|
|
|
|
await page.getByTitle("C", { exact: true }).click();
|
|
|
|
|
|
|
|
await expect(
|
|
|
|
page.getByTestId("children-6ad3e6b9-c5a0-80cf-8005-283bbe378bcb"),
|
|
|
|
).toHaveText(["CBCDEF"]);
|
|
|
|
});
|
2024-11-15 17:47:28 +01:00
|
|
|
|
|
|
|
test("User have toolbar", async ({ page }) => {
|
|
|
|
const workspacePage = new WorkspacePage(page);
|
|
|
|
await workspacePage.setupEmptyFile(page);
|
|
|
|
await workspacePage.goToWorkspace();
|
|
|
|
|
|
|
|
await expect(page.getByTitle("toggle toolbar")).toBeVisible();
|
|
|
|
await expect(page.getByTitle("design")).toBeVisible();
|
|
|
|
});
|
|
|
|
|
|
|
|
test("User have edition menu entries", async ({ page }) => {
|
|
|
|
const workspacePage = new WorkspacePage(page);
|
|
|
|
await workspacePage.setupEmptyFile(page);
|
|
|
|
await workspacePage.goToWorkspace();
|
|
|
|
|
|
|
|
await page.getByTitle("Main menu").click();
|
|
|
|
await page.getByText("file").last().click();
|
|
|
|
|
|
|
|
await expect(page.getByText("Add as Shared Library")).toBeVisible();
|
|
|
|
|
|
|
|
await page.getByText("edit").click();
|
|
|
|
|
|
|
|
await expect(page.getByText("Undo")).toBeVisible();
|
|
|
|
await expect(page.getByText("Redo")).toBeVisible();
|
|
|
|
});
|
2025-01-10 11:50:32 +01:00
|
|
|
|
|
|
|
test("Copy/paste properties", async ({ page, context }) => {
|
|
|
|
const workspacePage = new WorkspacePage(page);
|
|
|
|
await workspacePage.setupEmptyFile(page);
|
|
|
|
await workspacePage.mockRPC(
|
|
|
|
/get\-file\?/,
|
|
|
|
"workspace/get-file-copy-paste.json",
|
|
|
|
);
|
|
|
|
await workspacePage.mockRPC(
|
|
|
|
"get-file-fragment?file-id=*&fragment-id=*",
|
|
|
|
"workspace/get-file-copy-paste-fragment.json",
|
|
|
|
);
|
|
|
|
|
|
|
|
await workspacePage.goToWorkspace({
|
|
|
|
fileId: "870f9f10-87b5-8137-8005-934804124660",
|
|
|
|
pageId: "870f9f10-87b5-8137-8005-934804124661",
|
|
|
|
});
|
|
|
|
|
|
|
|
// Access to the read/write clipboard necesary for this functionality
|
|
|
|
await context.grantPermissions(["clipboard-read", "clipboard-write"]);
|
|
|
|
|
|
|
|
await page.getByTestId("layer-item").getByRole("button").first().click();
|
|
|
|
await page
|
|
|
|
.getByTestId("children-0eef4dd0-b39b-807a-8005-934805578f93")
|
|
|
|
.getByText("Rectangle")
|
|
|
|
.click({ button: "right" });
|
|
|
|
await page.getByText("Copy/Paste as").hover();
|
|
|
|
await page.getByText("Copy properties").click();
|
|
|
|
|
|
|
|
await page
|
|
|
|
.getByTestId("layer-item")
|
|
|
|
.getByText("Uno dos tres cuatro")
|
|
|
|
.click({ button: "right" });
|
|
|
|
await page.getByText("Copy/Paste as").hover();
|
|
|
|
await page.getByText("Paste properties").click();
|
|
|
|
|
|
|
|
await page.getByText("Rectangle").first().click({ button: "right" });
|
|
|
|
await page.getByText("Copy/Paste as").hover();
|
|
|
|
await page.getByText("Paste properties").click();
|
|
|
|
|
|
|
|
await page.getByText("Board").nth(2).click({ button: "right" });
|
|
|
|
await page.getByText("Copy/Paste as").hover();
|
|
|
|
await page.getByText("Paste properties").click();
|
|
|
|
|
|
|
|
await page
|
|
|
|
.getByTestId("layer-item")
|
|
|
|
.locator("div")
|
|
|
|
.filter({ hasText: "Path" })
|
|
|
|
.nth(1)
|
|
|
|
.click({ button: "right" });
|
|
|
|
await page.getByText("Copy/Paste as").hover();
|
|
|
|
await page.getByText("Paste properties").click();
|
|
|
|
|
|
|
|
await page.getByText("Ellipse").click({ button: "right" });
|
|
|
|
await page.getByText("Copy/Paste as").hover();
|
|
|
|
await page.getByText("Paste properties").click();
|
|
|
|
});
|