diff --git a/.env.example b/.env.example index b934687b..f5705bb3 100644 --- a/.env.example +++ b/.env.example @@ -1,2 +1,3 @@ E2E_LOGIN_EMAIL="" E2E_LOGIN_PASSWORD="" +E2E_SCREENSHOTS= "false" diff --git a/.gitignore b/.gitignore index 3a68d400..25a4f2e8 100644 --- a/.gitignore +++ b/.gitignore @@ -47,3 +47,6 @@ Thumbs.db **/assets/plugin.js docs/api + + +apps/e2e/screenshots/*.png diff --git a/apps/e2e/screenshots/.gitkeep b/apps/e2e/screenshots/.gitkeep new file mode 100644 index 00000000..e69de29b diff --git a/apps/e2e/src/__snapshots__/plugins.spec.ts.snap b/apps/e2e/src/__snapshots__/plugins.spec.ts.snap index 6aacaf62..ea39ba33 100644 --- a/apps/e2e/src/__snapshots__/plugins.spec.ts.snap +++ b/apps/e2e/src/__snapshots__/plugins.spec.ts.snap @@ -89,20 +89,20 @@ exports[`Plugins > component library 1`] = ` "parentId": "1", "points": [ { - "x": 0, - "y": 0, + "x": 684, + "y": 540, }, { - "x": 100, - "y": 0, + "x": 784, + "y": 540, }, { - "x": 100, - "y": 100, + "x": 784, + "y": 640, }, { - "x": 0, - "y": 100, + "x": 684, + "y": 640, }, ], "proportion": 1, @@ -113,12 +113,12 @@ exports[`Plugins > component library 1`] = ` "selrect": { "height": 100, "width": 100, - "x": 0, - "x1": 0, - "x2": 100, - "y": 0, - "y1": 0, - "y2": 100, + "x": 684, + "x1": 684, + "x2": 784, + "y": 540, + "y1": 540, + "y2": 640, }, "strokes": [], "transform": { @@ -139,8 +139,8 @@ exports[`Plugins > component library 1`] = ` }, "type": "rect", "width": 100, - "x": 0, - "y": 0, + "x": 684, + "y": 540, }, ] `; @@ -195,8 +195,8 @@ exports[`Plugins > create board - text - rectable 1`] = ` }, "shapes": [ "2", - "3", "4", + "5", ], "strokes": [], "transform": { @@ -221,6 +221,81 @@ exports[`Plugins > create board - text - rectable 1`] = ` "y": 0, }, { + "fills": [ + { + "fillColor": "#FFFFFF", + "fillOpacity": 1, + }, + ], + "flipX": null, + "flipY": null, + "frameId": "1", + "height": 300, + "hideFillOnExport": false, + "id": "2", + "name": "Board name", + "parentId": "1", + "points": [ + { + "x": 684, + "y": 540, + }, + { + "x": 984, + "y": 540, + }, + { + "x": 984, + "y": 840, + }, + { + "x": 684, + "y": 840, + }, + ], + "proportion": 1, + "proportionLock": false, + "rotation": 0, + "rx": 8, + "ry": 8, + "selrect": { + "height": 300, + "width": 300, + "x": 684, + "x1": 684, + "x2": 984, + "y": 540, + "y1": 540, + "y2": 840, + }, + "shapes": [ + "3", + ], + "strokes": [], + "transform": { + "a": 1, + "b": 0, + "c": 0, + "d": 1, + "e": 0, + "f": 0, + }, + "transformInverse": { + "a": 1, + "b": 0, + "c": 0, + "d": 1, + "e": 0, + "f": 0, + }, + "type": "frame", + "width": 300, + "x": 684, + "y": 540, + }, + { + "constraintsH": "left", + "constraintsV": "top", "content": { "children": [ { @@ -242,7 +317,7 @@ exports[`Plugins > create board - text - rectable 1`] = ` "fontWeight": "400", "letterSpacing": "0", "lineHeight": "1.2", - "text": "Hello from plugin", + "text": "Hello from board", "textAlign": "left", "textDecoration": "none", "textTransform": "none", @@ -279,28 +354,28 @@ exports[`Plugins > create board - text - rectable 1`] = ` }, "flipX": null, "flipY": null, - "frameId": "1", + "frameId": "2", "growType": "auto-width", "height": 17, - "id": "2", + "id": "3", "name": "Text", - "parentId": "1", + "parentId": "2", "points": [ { - "x": 684, - "y": 540, + "x": 10, + "y": 10, }, { - "x": 786, - "y": 540, + "x": 110, + "y": 10, }, { - "x": 786, - "y": 557, + "x": 110, + "y": 27, }, { - "x": 684, - "y": 557, + "x": 10, + "y": 27, }, ], "positionData": [ @@ -318,14 +393,14 @@ exports[`Plugins > create board - text - rectable 1`] = ` "fontWeight": "400", "height": 18, "letterSpacing": "normal", - "text": "Hello from plugin", + "text": "Hello from board", "textDecoration": "none solid rgb(0, 0, 0)", "textTransform": "none", - "width": 101.53125, - "x": 684, + "width": 99.234375, + "x": 10, "x1": 0, - "x2": 101.53125, - "y": 557, + "x2": 99.234375, + "y": 27, "y1": -1, "y2": 17, }, @@ -333,13 +408,13 @@ exports[`Plugins > create board - text - rectable 1`] = ` "rotation": 0, "selrect": { "height": 17, - "width": 102, - "x": 684, - "x1": 684, - "x2": 786, - "y": 540, - "y1": 540, - "y2": 557, + "width": 100, + "x": 10, + "x1": 10, + "x2": 110, + "y": 10, + "y1": 10, + "y2": 27, }, "transform": { "a": 1, @@ -358,9 +433,9 @@ exports[`Plugins > create board - text - rectable 1`] = ` "f": 0, }, "type": "text", - "width": 102, - "x": 684, - "y": 540, + "width": 100, + "x": 10, + "y": 10, }, { "fills": [ @@ -373,7 +448,7 @@ exports[`Plugins > create board - text - rectable 1`] = ` "flipY": null, "frameId": "1", "height": 200, - "id": "3", + "id": "4", "name": "Rectangle", "parentId": "1", "pluginData": { @@ -437,81 +512,6 @@ exports[`Plugins > create board - text - rectable 1`] = ` "y": 540, }, { - "fills": [ - { - "fillColor": "#FFFFFF", - "fillOpacity": 1, - }, - ], - "flipX": null, - "flipY": null, - "frameId": "1", - "height": 300, - "hideFillOnExport": false, - "id": "4", - "name": "Board name", - "parentId": "1", - "points": [ - { - "x": 684, - "y": 540, - }, - { - "x": 984, - "y": 540, - }, - { - "x": 984, - "y": 840, - }, - { - "x": 684, - "y": 840, - }, - ], - "proportion": 1, - "proportionLock": false, - "rotation": 0, - "rx": 8, - "ry": 8, - "selrect": { - "height": 300, - "width": 300, - "x": 684, - "x1": 684, - "x2": 984, - "y": 540, - "y1": 540, - "y2": 840, - }, - "shapes": [ - "5", - ], - "strokes": [], - "transform": { - "a": 1, - "b": 0, - "c": 0, - "d": 1, - "e": 0, - "f": 0, - }, - "transformInverse": { - "a": 1, - "b": 0, - "c": 0, - "d": 1, - "e": 0, - "f": 0, - }, - "type": "frame", - "width": 300, - "x": 684, - "y": 540, - }, - { - "constraintsH": "left", - "constraintsV": "top", "content": { "children": [ { @@ -533,7 +533,7 @@ exports[`Plugins > create board - text - rectable 1`] = ` "fontWeight": "400", "letterSpacing": "0", "lineHeight": "1.2", - "text": "Hello from board", + "text": "Hello from plugin", "textAlign": "left", "textDecoration": "none", "textTransform": "none", @@ -570,28 +570,28 @@ exports[`Plugins > create board - text - rectable 1`] = ` }, "flipX": null, "flipY": null, - "frameId": "4", + "frameId": "1", "growType": "auto-width", "height": 17, "id": "5", "name": "Text", - "parentId": "4", + "parentId": "1", "points": [ { - "x": 10, - "y": 10, + "x": 684, + "y": 540, }, { - "x": 110, - "y": 10, + "x": 786, + "y": 540, }, { - "x": 110, - "y": 27, + "x": 786, + "y": 557, }, { - "x": 10, - "y": 27, + "x": 684, + "y": 557, }, ], "positionData": [ @@ -609,14 +609,14 @@ exports[`Plugins > create board - text - rectable 1`] = ` "fontWeight": "400", "height": 18, "letterSpacing": "normal", - "text": "Hello from board", + "text": "Hello from plugin", "textDecoration": "none solid rgb(0, 0, 0)", "textTransform": "none", - "width": 99.234375, - "x": 10, + "width": 101.53125, + "x": 684, "x1": 0, - "x2": 99.234375, - "y": 27, + "x2": 101.53125, + "y": 557, "y1": -1, "y2": 17, }, @@ -624,13 +624,13 @@ exports[`Plugins > create board - text - rectable 1`] = ` "rotation": 0, "selrect": { "height": 17, - "width": 100, - "x": 10, - "x1": 10, - "x2": 110, - "y": 10, - "y1": 10, - "y2": 27, + "width": 102, + "x": 684, + "x1": 684, + "x2": 786, + "y": 540, + "y1": 540, + "y2": 557, }, "transform": { "a": 1, @@ -649,9 +649,9 @@ exports[`Plugins > create board - text - rectable 1`] = ` "f": 0, }, "type": "text", - "width": 100, - "x": 10, - "y": 10, + "width": 102, + "x": 684, + "y": 540, }, ] `; @@ -739,7 +739,7 @@ exports[`Plugins > create flex layout 1`] = ` "flipX": null, "flipY": null, "frameId": "1", - "height": 110.00000000000001, + "height": 110, "hideFillOnExport": false, "id": "2", "layout": "flex", @@ -767,34 +767,34 @@ exports[`Plugins > create flex layout 1`] = ` "parentId": "1", "points": [ { - "x": 0, - "y": 0, + "x": 684, + "y": 540, }, { - "x": 210, - "y": 0, + "x": 894, + "y": 540, }, { - "x": 210, - "y": 110.00000000000001, + "x": 894, + "y": 650, }, { - "x": 0, - "y": 110.00000000000001, + "x": 684, + "y": 650, }, ], "proportion": 1, "proportionLock": false, "rotation": 0, "selrect": { - "height": 110.00000000000001, + "height": 110, "width": 210, - "x": 0, - "x1": 0, - "x2": 210, - "y": 0, - "y1": 0, - "y2": 110.00000000000001, + "x": 684, + "x1": 684, + "x2": 894, + "y": 540, + "y1": 540, + "y2": 650, }, "shapes": [ "4", @@ -819,8 +819,8 @@ exports[`Plugins > create flex layout 1`] = ` }, "type": "frame", "width": 210, - "x": 0, - "y": 0, + "x": 684, + "y": 540, }, { "constraintsH": "left", @@ -840,20 +840,20 @@ exports[`Plugins > create flex layout 1`] = ` "parentId": "2", "points": [ { - "x": 5, - "y": 5.000000000000007, + "x": 689, + "y": 545, }, { - "x": 105, - "y": 5.000000000000007, + "x": 789, + "y": 545, }, { - "x": 105, - "y": 105, + "x": 789, + "y": 645, }, { - "x": 5, - "y": 105, + "x": 689, + "y": 645, }, ], "proportion": 1, @@ -864,12 +864,12 @@ exports[`Plugins > create flex layout 1`] = ` "selrect": { "height": 100, "width": 100, - "x": 5, - "x1": 5, - "x2": 105, - "y": 5.000000000000007, - "y1": 5.000000000000007, - "y2": 105, + "x": 689, + "x1": 689, + "x2": 789, + "y": 545, + "y1": 545, + "y2": 645, }, "strokes": [], "transform": { @@ -890,8 +890,8 @@ exports[`Plugins > create flex layout 1`] = ` }, "type": "rect", "width": 100, - "x": 5, - "y": 5.000000000000007, + "x": 689, + "y": 545, }, { "constraintsH": "left", @@ -911,20 +911,20 @@ exports[`Plugins > create flex layout 1`] = ` "parentId": "2", "points": [ { - "x": 105, - "y": 5.000000000000007, + "x": 789, + "y": 545, }, { - "x": 205, - "y": 5.000000000000007, + "x": 889, + "y": 545, }, { - "x": 205, - "y": 105, + "x": 889, + "y": 645, }, { - "x": 105, - "y": 105, + "x": 789, + "y": 645, }, ], "proportion": 1, @@ -933,12 +933,12 @@ exports[`Plugins > create flex layout 1`] = ` "selrect": { "height": 100, "width": 100, - "x": 105, - "x1": 105, - "x2": 205, - "y": 5.000000000000007, - "y1": 5.000000000000007, - "y2": 105, + "x": 789, + "x1": 789, + "x2": 889, + "y": 545, + "y1": 545, + "y2": 645, }, "strokes": [], "transform": { @@ -959,8 +959,8 @@ exports[`Plugins > create flex layout 1`] = ` }, "type": "circle", "width": 100, - "x": 105, - "y": 5.000000000000007, + "x": 789, + "y": 545, }, ] `; @@ -1139,20 +1139,20 @@ exports[`Plugins > create grid layout 1`] = ` "parentId": "1", "points": [ { - "x": 0, - "y": 0, + "x": 684, + "y": 540, }, { - "x": 100, - "y": 0, + "x": 784, + "y": 540, }, { - "x": 100, - "y": 100, + "x": 784, + "y": 640, }, { - "x": 0, - "y": 100, + "x": 684, + "y": 640, }, ], "proportion": 1, @@ -1161,12 +1161,12 @@ exports[`Plugins > create grid layout 1`] = ` "selrect": { "height": 100, "width": 100, - "x": 0, - "x1": 0, - "x2": 100, - "y": 0, - "y1": 0, - "y2": 100, + "x": 684, + "x1": 684, + "x2": 784, + "y": 540, + "y1": 540, + "y2": 640, }, "shapes": [], "strokes": [], @@ -1188,8 +1188,8 @@ exports[`Plugins > create grid layout 1`] = ` }, "type": "frame", "width": 100, - "x": 0, - "y": 0, + "x": 684, + "y": 540, }, ] `; @@ -1283,20 +1283,20 @@ exports[`Plugins > group and ungroup 1`] = ` "parentId": "4", "points": [ { - "x": 0, - "y": 0, + "x": 684, + "y": 540, }, { - "x": 100, - "y": 0, + "x": 784, + "y": 540, }, { - "x": 100, - "y": 100, + "x": 784, + "y": 640, }, { - "x": 0, - "y": 100, + "x": 684, + "y": 640, }, ], "proportion": 1, @@ -1307,12 +1307,12 @@ exports[`Plugins > group and ungroup 1`] = ` "selrect": { "height": 100, "width": 100, - "x": 0, - "x1": 0, - "x2": 100, - "y": 0, - "y1": 0, - "y2": 100, + "x": 684, + "x1": 684, + "x2": 784, + "y": 540, + "y1": 540, + "y2": 640, }, "strokes": [], "transform": { @@ -1333,8 +1333,8 @@ exports[`Plugins > group and ungroup 1`] = ` }, "type": "rect", "width": 100, - "x": 0, - "y": 0, + "x": 684, + "y": 540, }, { "fills": [ @@ -1352,20 +1352,20 @@ exports[`Plugins > group and ungroup 1`] = ` "parentId": "4", "points": [ { - "x": 0, - "y": 0, + "x": 784, + "y": 640, }, { - "x": 100, - "y": 0, + "x": 884, + "y": 640, }, { - "x": 100, - "y": 100, + "x": 884, + "y": 740, }, { - "x": 0, - "y": 100, + "x": 784, + "y": 740, }, ], "proportion": 1, @@ -1376,12 +1376,12 @@ exports[`Plugins > group and ungroup 1`] = ` "selrect": { "height": 100, "width": 100, - "x": 0, - "x1": 0, - "x2": 100, - "y": 0, - "y1": 0, - "y2": 100, + "x": 784, + "x1": 784, + "x2": 884, + "y": 640, + "y1": 640, + "y2": 740, }, "strokes": [], "transform": { @@ -1402,49 +1402,49 @@ exports[`Plugins > group and ungroup 1`] = ` }, "type": "rect", "width": 100, - "x": 0, - "y": 0, + "x": 784, + "y": 640, }, { "fills": [], "flipX": null, "flipY": null, "frameId": "1", - "height": 100, + "height": 200, "id": "4", "index": 2, "name": "Group", "parentId": "1", "points": [ { - "x": 0, - "y": 0, + "x": 684, + "y": 540, }, { - "x": 100, - "y": 0, + "x": 884, + "y": 540, }, { - "x": 100, - "y": 100, + "x": 884, + "y": 740, }, { - "x": 0, - "y": 100, + "x": 684, + "y": 740, }, ], "proportion": 1, "proportionLock": false, "rotation": 0, "selrect": { - "height": 100, - "width": 100, - "x": 0, - "x1": 0, - "x2": 100, - "y": 0, - "y1": 0, - "y2": 100, + "height": 200, + "width": 200, + "x": 684, + "x1": 684, + "x2": 884, + "y": 540, + "y1": 540, + "y2": 740, }, "shapes": [ "2", @@ -1468,9 +1468,9 @@ exports[`Plugins > group and ungroup 1`] = ` "f": 0, }, "type": "group", - "width": 100, - "x": 0, - "y": 0, + "width": 200, + "x": 684, + "y": 540, }, ] `; @@ -2169,20 +2169,20 @@ exports[`Plugins > text and textrange 1`] = ` "parentId": "1", "points": [ { - "x": 0, - "y": 0, + "x": 684, + "y": 540, }, { - "x": 214, - "y": 0, + "x": 898, + "y": 540, }, { - "x": 214, - "y": 48, + "x": 898, + "y": 588, }, { - "x": 0, - "y": 48, + "x": 684, + "y": 588, }, ], "positionData": [ @@ -2204,10 +2204,10 @@ exports[`Plugins > text and textrange 1`] = ` "textDecoration": "underline solid rgb(255, 111, 224)", "textTransform": "uppercase", "width": 129.03125, - "x": 0, + "x": 684, "x1": 0, "x2": 129.03125, - "y": 47, + "y": 587, "y1": 0, "y2": 47, }, @@ -2229,10 +2229,10 @@ exports[`Plugins > text and textrange 1`] = ` "textDecoration": "underline solid rgb(0, 0, 0)", "textTransform": "uppercase", "width": 84.375, - "x": 129.03125, + "x": 813.03125, "x1": 129.03125, "x2": 213.40625, - "y": 42, + "y": 582, "y1": 18, "y2": 42, }, @@ -2241,12 +2241,12 @@ exports[`Plugins > text and textrange 1`] = ` "selrect": { "height": 48, "width": 214, - "x": 0, - "x1": 0, - "x2": 214, - "y": 0, - "y1": 0, - "y2": 48, + "x": 684, + "x1": 684, + "x2": 898, + "y": 540, + "y1": 540, + "y2": 588, }, "transform": { "a": 1, @@ -2266,8 +2266,8 @@ exports[`Plugins > text and textrange 1`] = ` }, "type": "text", "width": 214, - "x": 0, - "y": 0, + "x": 684, + "y": 540, }, ] `; diff --git a/apps/e2e/src/plugins.spec.ts b/apps/e2e/src/plugins.spec.ts index ba42e06d..979ac8e0 100644 --- a/apps/e2e/src/plugins.spec.ts +++ b/apps/e2e/src/plugins.spec.ts @@ -11,31 +11,41 @@ import { Agent } from './utils/agent'; describe('Plugins', () => { it('create board - text - rectable', async () => { const agent = await Agent(); - const result = await agent.runCode(testingPlugin.toString()); + const result = await agent.runCode(testingPlugin.toString(), { + screenshot: 'create-board-text-rect', + }); expect(result).toMatchSnapshot(); }); it('create flex layout', async () => { const agent = await Agent(); - const result = await agent.runCode(flex.toString()); + const result = await agent.runCode(flex.toString(), { + screenshot: 'create-flexlayout', + }); expect(result).toMatchSnapshot(); }); it('create grid layout', async () => { const agent = await Agent(); - const result = await agent.runCode(grid.toString()); + const result = await agent.runCode(grid.toString(), { + screenshot: 'create-gridlayout', + }); expect(result).toMatchSnapshot(); }); it('group and ungroup', async () => { const agent = await Agent(); - const result = await agent.runCode(group.toString()); + const result = await agent.runCode(group.toString(), { + screenshot: 'group-ungroup', + }); expect(result).toMatchSnapshot(); }); it('insert svg', async () => { const agent = await Agent(); - const result = await agent.runCode(insertSvg.toString()); + const result = await agent.runCode(insertSvg.toString(), { + screenshot: 'insert-svg', + }); expect(result).toMatchSnapshot(); }); @@ -47,13 +57,17 @@ describe('Plugins', () => { it('component library', async () => { const agent = await Agent(); - const result = await agent.runCode(componentLibrary.toString()); + const result = await agent.runCode(componentLibrary.toString(), { + screenshot: 'component-library', + }); expect(result).toMatchSnapshot(); }); it('text and textrange', async () => { const agent = await Agent(); - const result = await agent.runCode(createText.toString()); + const result = await agent.runCode(createText.toString(), { + screenshot: 'create-text', + }); expect(result).toMatchSnapshot(); }); }); diff --git a/apps/e2e/src/plugins/component-library.ts b/apps/e2e/src/plugins/component-library.ts index b7429f04..02fa4837 100644 --- a/apps/e2e/src/plugins/component-library.ts +++ b/apps/e2e/src/plugins/component-library.ts @@ -1,7 +1,10 @@ export default function () { const rectangle = penpot.createRectangle(); + rectangle.x = penpot.viewport.center.x; + rectangle.y = penpot.viewport.center.y; + const shape = penpot.getPage()?.getShapeById(rectangle.id); if (shape) { - penpot.library.local.createComponent(shape); + penpot.library.local.createComponent([shape]); } } diff --git a/apps/e2e/src/plugins/create-board-text-rect.ts b/apps/e2e/src/plugins/create-board-text-rect.ts index 1dd2e678..62d34a7a 100644 --- a/apps/e2e/src/plugins/create-board-text-rect.ts +++ b/apps/e2e/src/plugins/create-board-text-rect.ts @@ -32,8 +32,6 @@ export default function () { board.name = 'Board name'; - console.log(penpot.viewport.center.x); - board.x = penpot.viewport.center.x; board.y = penpot.viewport.center.y; @@ -54,7 +52,7 @@ export default function () { return board; } - createText('Hello from plugin'); - createRectangle(); createBoard(); + createRectangle(); + createText('Hello from plugin'); } diff --git a/apps/e2e/src/plugins/create-flexlayout.ts b/apps/e2e/src/plugins/create-flexlayout.ts index 46abbc16..c24b48e7 100644 --- a/apps/e2e/src/plugins/create-flexlayout.ts +++ b/apps/e2e/src/plugins/create-flexlayout.ts @@ -4,6 +4,9 @@ export default function () { board.horizontalSizing = 'auto'; board.verticalSizing = 'auto'; + board.x = penpot.viewport.center.x; + board.y = penpot.viewport.center.y; + const flex = board.addFlexLayout(); flex.dir = 'column'; diff --git a/apps/e2e/src/plugins/create-gridlayout.ts b/apps/e2e/src/plugins/create-gridlayout.ts index c31ef4c0..41205ee9 100644 --- a/apps/e2e/src/plugins/create-gridlayout.ts +++ b/apps/e2e/src/plugins/create-gridlayout.ts @@ -1,6 +1,8 @@ export default function () { function createGridLayout(): void { const board = penpot.createBoard(); + board.x = penpot.viewport.center.x; + board.y = penpot.viewport.center.y; const grid = board.addGridLayout(); diff --git a/apps/e2e/src/plugins/create-text.ts b/apps/e2e/src/plugins/create-text.ts index d6c68d48..ccd2069e 100644 --- a/apps/e2e/src/plugins/create-text.ts +++ b/apps/e2e/src/plugins/create-text.ts @@ -1,22 +1,23 @@ export default function () { - function createText(): void { - const text = penpot.createText('Hello World!'); + function createText(): void { + const text = penpot.createText('Hello World!'); - if (text) { - text.growType = 'auto-width'; - text.textTransform = 'uppercase'; - text.textDecoration = 'underline'; - text.fontId = 'gfont-work-sans'; - text.fontStyle = 'italic'; - text.fontSize = '20'; - text.fontWeight = '500'; - - const textRange = text.getRange(0, 5); - textRange.fontSize = '40'; - textRange.fills = [{ fillColor: '#ff6fe0', fillOpacity: 1 }]; - } + if (text) { + text.x = penpot.viewport.center.x; + text.y = penpot.viewport.center.y; + text.growType = 'auto-width'; + text.textTransform = 'uppercase'; + text.textDecoration = 'underline'; + text.fontId = 'gfont-work-sans'; + text.fontStyle = 'italic'; + text.fontSize = '20'; + text.fontWeight = '500'; + + const textRange = text.getRange(0, 5); + textRange.fontSize = '40'; + textRange.fills = [{ fillColor: '#ff6fe0', fillOpacity: 1 }]; } - - createText(); } - \ No newline at end of file + + createText(); +} diff --git a/apps/e2e/src/plugins/group.ts b/apps/e2e/src/plugins/group.ts index 8c6be376..a8e189df 100644 --- a/apps/e2e/src/plugins/group.ts +++ b/apps/e2e/src/plugins/group.ts @@ -16,7 +16,11 @@ export default function () { } const rectangle = penpot.createRectangle(); + rectangle.x = penpot.viewport.center.x; + rectangle.y = penpot.viewport.center.y; const rectangle2 = penpot.createRectangle(); + rectangle2.x = penpot.viewport.center.x + 100; + rectangle2.y = penpot.viewport.center.y + 100; penpot.selection = [rectangle, rectangle2]; diff --git a/apps/e2e/src/utils/agent.ts b/apps/e2e/src/utils/agent.ts index 5a344383..83244d4c 100644 --- a/apps/e2e/src/utils/agent.ts +++ b/apps/e2e/src/utils/agent.ts @@ -4,6 +4,8 @@ import { getFileUrl } from './get-file-url'; import { idObjectToArray } from './clean-id'; import { Shape } from '../models/shape.model'; +const screenshotsEnable = process.env['E2E_SCREENSHOTS'] === 'true'; + function replaceIds(shapes: Shape[]) { let id = 1; @@ -96,6 +98,8 @@ export async function Agent() { autoFinish: true, } ) { + const autoFinish = options.autoFinish ?? true; + console.log('Running plugin code...'); await page.evaluate((testingPlugin) => { (globalThis as any).ɵloadPlugin({ @@ -119,9 +123,11 @@ export async function Agent() { ); console.log('Save status found.'); - if (options.screenshot) { + if (options.screenshot && screenshotsEnable) { console.log('Taking screenshot:', options.screenshot); - await page.screenshot({ path: options.screenshot }); + await page.screenshot({ + path: 'screenshots/' + options.screenshot + '.png', + }); } return new Promise((resolve) => { @@ -137,7 +143,7 @@ export async function Agent() { resolve(result); - if (options.autoFinish) { + if (autoFinish) { console.log('Auto finish enabled. Cleaning up...'); finish(); } diff --git a/docs/test-e2e.md b/docs/test-e2e.md index 1a16d2fd..692e862a 100644 --- a/docs/test-e2e.md +++ b/docs/test-e2e.md @@ -9,6 +9,7 @@ ```env E2E_LOGIN_EMAIL="test@penpot.app" E2E_LOGIN_PASSWORD="123123123" + E2E_SCREENSHOTS= "true" ``` 2. **Run E2E Tests** @@ -57,7 +58,7 @@ ```ts const result = await agent.runCode(testingPlugin.toString(), { autoFinish: false, // default: true - screenshot: 'capture.png', // default: '' + screenshot: 'test-name', // default: '' }); // Finish will close the browser & delete the file