2024-06-05 15:52:38 +02:00
|
|
|
import { test, expect } from "@playwright/test";
|
|
|
|
import { WorkspacePage } from "../pages/WorkspacePage";
|
|
|
|
|
|
|
|
test.beforeEach(async ({ page }) => {
|
|
|
|
await WorkspacePage.init(page);
|
|
|
|
});
|
|
|
|
|
|
|
|
const multipleConstraintsFileId = `03bff843-920f-81a1-8004-756365e1eb6a`;
|
|
|
|
const multipleConstraintsPageId = `03bff843-920f-81a1-8004-756365e1eb6b`;
|
2024-06-10 11:02:17 +02:00
|
|
|
const multipleAttributesFileId = `1795a568-0df0-8095-8004-7ba741f56be2`;
|
|
|
|
const multipleAttributesPageId = `1795a568-0df0-8095-8004-7ba741f56be3`;
|
2024-06-05 15:52:38 +02:00
|
|
|
|
|
|
|
const setupFileWithMultipeConstraints = async (workspace) => {
|
|
|
|
await workspace.setupEmptyFile();
|
2024-07-01 10:28:40 +02:00
|
|
|
await workspace.mockRPC(
|
|
|
|
/get\-file\?/,
|
|
|
|
"design/get-file-multiple-constraints.json",
|
|
|
|
);
|
2024-06-05 15:52:38 +02:00
|
|
|
await workspace.mockRPC(
|
|
|
|
"get-file-object-thumbnails?file-id=*",
|
|
|
|
"design/get-file-object-thumbnails-multiple-constraints.json",
|
|
|
|
);
|
|
|
|
await workspace.mockRPC(
|
|
|
|
"get-file-fragment?file-id=*",
|
|
|
|
"design/get-file-fragment-multiple-constraints.json",
|
|
|
|
);
|
|
|
|
};
|
|
|
|
|
2024-06-10 11:02:17 +02:00
|
|
|
const setupFileWithMultipeAttributes = async (workspace) => {
|
|
|
|
await workspace.setupEmptyFile();
|
2024-07-01 10:28:40 +02:00
|
|
|
await workspace.mockRPC(
|
|
|
|
/get\-file\?/,
|
|
|
|
"design/get-file-multiple-attributes.json",
|
|
|
|
);
|
2024-06-10 11:02:17 +02:00
|
|
|
await workspace.mockRPC(
|
|
|
|
"get-file-object-thumbnails?file-id=*",
|
|
|
|
"design/get-file-object-thumbnails-multiple-attributes.json",
|
|
|
|
);
|
|
|
|
};
|
|
|
|
|
2024-06-05 15:52:38 +02:00
|
|
|
test.describe("Constraints", () => {
|
|
|
|
test("Constraint dropdown shows 'Mixed' when multiple layers are selected with different constraints", async ({
|
|
|
|
page,
|
|
|
|
}) => {
|
|
|
|
const workspace = new WorkspacePage(page);
|
|
|
|
await setupFileWithMultipeConstraints(workspace);
|
|
|
|
await workspace.goToWorkspace({
|
|
|
|
fileId: multipleConstraintsFileId,
|
|
|
|
pageId: multipleConstraintsPageId,
|
|
|
|
});
|
|
|
|
|
|
|
|
await workspace.clickToggableLayer("Board");
|
|
|
|
await workspace.clickLeafLayer("Ellipse");
|
|
|
|
await workspace.clickLeafLayer("Rectangle", { modifiers: ["Shift"] });
|
|
|
|
|
2024-07-01 10:28:40 +02:00
|
|
|
const constraintVDropdown = workspace.page.getByTestId(
|
|
|
|
"constraint-v-select",
|
|
|
|
);
|
2024-06-05 15:52:38 +02:00
|
|
|
await expect(constraintVDropdown).toContainText("Mixed");
|
2024-07-01 10:28:40 +02:00
|
|
|
const constraintHDropdown = workspace.page.getByTestId(
|
|
|
|
"constraint-h-select",
|
|
|
|
);
|
2024-06-05 15:52:38 +02:00
|
|
|
await expect(constraintHDropdown).toContainText("Mixed");
|
|
|
|
|
|
|
|
expect(false);
|
|
|
|
});
|
|
|
|
});
|
2024-06-10 11:02:17 +02:00
|
|
|
|
|
|
|
test.describe("Multiple shapes attributes", () => {
|
2024-07-01 10:28:40 +02:00
|
|
|
test("User selects multiple shapes with sames fills, strokes, shadows and blur", async ({
|
|
|
|
page,
|
|
|
|
}) => {
|
2024-06-10 11:02:17 +02:00
|
|
|
const workspace = new WorkspacePage(page);
|
|
|
|
await setupFileWithMultipeConstraints(workspace);
|
|
|
|
await workspace.goToWorkspace({
|
|
|
|
fileId: multipleConstraintsFileId,
|
|
|
|
pageId: multipleConstraintsPageId,
|
|
|
|
});
|
|
|
|
|
|
|
|
await workspace.clickToggableLayer("Board");
|
|
|
|
await workspace.clickLeafLayer("Ellipse");
|
|
|
|
await workspace.clickLeafLayer("Rectangle", { modifiers: ["Shift"] });
|
|
|
|
|
|
|
|
await expect(workspace.page.getByTestId("add-fill")).toBeVisible();
|
|
|
|
await expect(workspace.page.getByTestId("add-stroke")).toBeVisible();
|
|
|
|
await expect(workspace.page.getByTestId("add-shadow")).toBeVisible();
|
|
|
|
await expect(workspace.page.getByTestId("add-blur")).toBeVisible();
|
|
|
|
});
|
|
|
|
|
2024-07-01 10:28:40 +02:00
|
|
|
test("User selects multiple shapes with different fills, strokes, shadows and blur", async ({
|
|
|
|
page,
|
|
|
|
}) => {
|
2024-06-10 11:02:17 +02:00
|
|
|
const workspace = new WorkspacePage(page);
|
|
|
|
await setupFileWithMultipeAttributes(workspace);
|
|
|
|
await workspace.goToWorkspace({
|
|
|
|
fileId: multipleAttributesFileId,
|
|
|
|
pageId: multipleAttributesPageId,
|
|
|
|
});
|
|
|
|
|
|
|
|
await workspace.clickLeafLayer("Ellipse");
|
|
|
|
await workspace.clickLeafLayer("Rectangle", { modifiers: ["Shift"] });
|
|
|
|
|
|
|
|
await expect(workspace.page.getByTestId("add-fill")).toBeHidden();
|
|
|
|
await expect(workspace.page.getByTestId("add-stroke")).toBeHidden();
|
|
|
|
await expect(workspace.page.getByTestId("add-shadow")).toBeHidden();
|
|
|
|
await expect(workspace.page.getByTestId("add-blur")).toBeHidden();
|
|
|
|
});
|
|
|
|
});
|
2024-06-10 16:03:07 +02:00
|
|
|
|
2024-07-01 10:28:40 +02:00
|
|
|
test("BUG 7760 - Layout losing properties when changing parents", async ({
|
|
|
|
page,
|
|
|
|
}) => {
|
2024-06-10 16:03:07 +02:00
|
|
|
const workspacePage = new WorkspacePage(page);
|
|
|
|
await workspacePage.setupEmptyFile();
|
|
|
|
await workspacePage.mockRPC(/get\-file\?/, "workspace/get-file-7760.json");
|
|
|
|
await workspacePage.mockRPC(
|
|
|
|
"get-file-fragment?file-id=*&fragment-id=*",
|
|
|
|
"workspace/get-file-fragment-7760.json",
|
|
|
|
);
|
2024-07-01 10:28:40 +02:00
|
|
|
await workspacePage.mockRPC(
|
|
|
|
"update-file?id=*",
|
|
|
|
"workspace/update-file-create-rect.json",
|
|
|
|
);
|
2024-06-10 16:03:07 +02:00
|
|
|
|
|
|
|
await workspacePage.goToWorkspace({
|
|
|
|
fileId: "cd90e028-326a-80b4-8004-7cdec16ffad5",
|
|
|
|
pageId: "cd90e028-326a-80b4-8004-7cdec16ffad6",
|
|
|
|
});
|
|
|
|
|
|
|
|
// Select the flex board and drag it into the other container board
|
|
|
|
await workspacePage.clickLeafLayer("Flex Board");
|
|
|
|
|
|
|
|
// Move the first board into the second
|
|
|
|
const hAuto = await workspacePage.page.getByTitle("Fit content (Horizontal)");
|
|
|
|
const vAuto = await workspacePage.page.getByTitle("Fit content (Vertical)");
|
|
|
|
|
|
|
|
await expect(vAuto.locator("input")).toBeChecked();
|
|
|
|
await expect(hAuto.locator("input")).toBeChecked();
|
|
|
|
|
|
|
|
await workspacePage.moveSelectionToShape("Container Board");
|
|
|
|
|
|
|
|
// The first board properties should still be auto width/height
|
|
|
|
await expect(vAuto.locator("input")).toBeChecked();
|
|
|
|
await expect(hAuto.locator("input")).toBeChecked();
|
|
|
|
});
|
2025-01-10 12:14:22 +01:00
|
|
|
|
|
|
|
test("BUG 9061 - Group blur visibility toggle icon not updating", async ({
|
|
|
|
page,
|
|
|
|
}) => {
|
|
|
|
const workspace = new WorkspacePage(page);
|
|
|
|
await workspace.setupEmptyFile();
|
|
|
|
await workspace.mockRPC(/get\-file\?/, "design/get-file-9061.json");
|
|
|
|
await workspace.mockRPC(
|
|
|
|
"get-file-fragment?file-id=*&fragment-id=*",
|
|
|
|
"design/get-file-fragment-9061.json",
|
|
|
|
);
|
|
|
|
await workspace.mockRPC("update-file?id=*", "design/update-file-9061.json");
|
|
|
|
|
|
|
|
await workspace.goToWorkspace({
|
|
|
|
fileId: "61cfa81d-8cb2-81df-8005-8f3005841116",
|
|
|
|
pageId: "61cfa81d-8cb2-81df-8005-8f3005841117",
|
|
|
|
});
|
|
|
|
|
|
|
|
await workspace.clickLeafLayer("Group");
|
|
|
|
|
|
|
|
const blurButton = workspace.page.getByRole("button", {
|
|
|
|
name: "Toggle blur",
|
|
|
|
});
|
|
|
|
const blurIcon = blurButton.locator("svg use");
|
|
|
|
await expect(blurIcon).toHaveAttribute("href", "#icon-shown");
|
|
|
|
|
|
|
|
await blurButton.click();
|
|
|
|
await expect(blurIcon).toHaveAttribute("href", "#icon-hide");
|
|
|
|
});
|