Skip to content

Commit

Permalink
chore: add library e2e tests
Browse files Browse the repository at this point in the history
  • Loading branch information
gkuzin13 committed Feb 26, 2024
1 parent 1939f89 commit 371f1e2
Show file tree
Hide file tree
Showing 5 changed files with 164 additions and 125 deletions.
145 changes: 145 additions & 0 deletions apps/client/e2e/tests/library.spec.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,145 @@
import { test, expect } from '@playwright/test';
import { LOCAL_STORAGE_LIBRARY_KEY } from '@/constants/app';
import { DRAWING_CANVAS } from '@/constants/canvas';
import { createNode } from '@/utils/node';
import { drawShape, getDrawingCanvas } from 'e2e/utils/canvas';
import type Konva from 'konva';
import type { Library } from '@/constants/app';

test.describe('library', async () => {
const ellipse = createNode('ellipse', [600, 600]);
ellipse.nodeProps.width = 50;
ellipse.nodeProps.height = 50;

const rect = createNode('rectangle', [400, 400]);
rect.nodeProps.width = 50;
rect.nodeProps.height = 50;

const library: Library = {
items: [
{ id: '1', created: Date.now(), elements: [ellipse] },
{ id: '2', created: Date.now(), elements: [rect] },
],
};

const preloadedLibrary = {
key: LOCAL_STORAGE_LIBRARY_KEY,
value: JSON.stringify(library),
};

test.beforeEach(async ({ page }) => {
await page.addInitScript(
({ key, value }) => localStorage.setItem(key, value),
preloadedLibrary,
);

await page.goto('/');
});

test('loads library state from localStorage', async ({ page }) => {
await page.getByTestId('library-drawer-trigger').click();

await expect(page.getByTestId('library-item').first()).toBeVisible();
await expect(page.getByTestId('library-item').nth(1)).toBeVisible();
await expect(page.getByTestId('library-item')).toHaveCount(2);
});

test('adds items to the library', async ({ page }) => {
await drawShape(
page,
[
[500, 500],
[550, 550],
],
{ type: 'rectangle' },
);

// open context menu
await getDrawingCanvas(page).click({
button: 'right',
position: { x: 500, y: 500 },
});

await page.getByText('Add To Library').click();

await page.getByTestId('library-drawer-trigger').click();

const storedLibrary: Library = await page.evaluate(
(key) => JSON.parse(window.localStorage.getItem(key) as string),
LOCAL_STORAGE_LIBRARY_KEY,
);

expect(storedLibrary.items).toHaveLength(3);
await expect(page.getByTestId('library-item').first()).toBeVisible();
await expect(page.getByTestId('library-item').nth(1)).toBeVisible();
await expect(page.getByTestId('library-item').nth(2)).toBeVisible();
await expect(page.getByTestId('library-item')).toHaveCount(3);
await expect(page.getByText('Empty here...')).toBeHidden();
});

test('removes items from library', async ({ page }) => {
await page.getByTestId('library-drawer-trigger').click();

for (const item of await page.getByTestId('library-item').all()) {
await item.hover();
await item.getByRole('checkbox').check();
}

await page.getByTestId('remove-library-items-button').click();


const storedLibrary: Library = await page.evaluate(
(key) => JSON.parse(window.localStorage.getItem(key) as string),
LOCAL_STORAGE_LIBRARY_KEY,
);

expect(storedLibrary.items).toHaveLength(0);
await expect(page.getByText('Empty here...')).toBeVisible();
await expect(page.getByTestId('library-item')).toHaveCount(0);
await expect(page.getByTestId('library-item')).toBeHidden();
});

// [TODO]: need better way to get all shapes
test('drag-n-drop items to canvas', async ({ page }) => {
await page.getByTestId('library-drawer-trigger').click();

await page
.getByTestId('library-item')
.first()
.dragTo(getDrawingCanvas(page), { targetPosition: { x: 200, y: 200 } });

await page
.getByTestId('library-item')
.nth(1)
.dragTo(getDrawingCanvas(page), { targetPosition: { x: 400, y: 400 } });

const shapes = await page.evaluate((name) => {
const drawingCanvas = window.Konva.stages.find(
(stage) => stage.name() === name,
);

// eslint-disable-next-line playwright/no-unsafe-references
return drawingCanvas?.find((node: Konva.Node) => Boolean(node.id()));
}, DRAWING_CANVAS.NAME);

expect(shapes).toHaveLength(2);
});

test('adds items to canvas on click', async ({ page }) => {
await page.getByTestId('library-drawer-trigger').click();

await page.getByTestId('library-item').first().click();
await page.getByTestId('library-item').nth(1).click();

const shapes = await page.evaluate((name) => {
const drawingCanvas = window.Konva.stages.find(
(stage) => stage.name() === name,
);

// eslint-disable-next-line playwright/no-unsafe-references
return drawingCanvas?.find((node: Konva.Node) => Boolean(node.id()));
}, DRAWING_CANVAS.NAME);

expect(shapes).toHaveLength(2);
});
});
5 changes: 3 additions & 2 deletions apps/client/e2e/utils/canvas.ts
Original file line number Diff line number Diff line change
Expand Up @@ -4,17 +4,18 @@ import type { NodeType, Point } from 'shared';

type DrawPoints = [start: Point, end: Point];
type DrawShapeOptions = {
type: Omit<NodeType, 'text'>;
type: Exclude<NodeType, 'text'>;
unselect?: boolean;
};
type CreateTextOptions = {
text: string;
unselect?: boolean;
};

export async function draw(page: Page, [start, end]: DrawPoints) {
await page.mouse.move(start[0], start[1]);
await page.mouse.down();
await page.mouse.move(end[0], end[1]);
await page.mouse.move(end[0], end[1], { steps: 2 });
await page.mouse.up();
}

Expand Down
120 changes: 0 additions & 120 deletions apps/client/src/__tests__/library.test.tsx

This file was deleted.

Original file line number Diff line number Diff line change
Expand Up @@ -28,7 +28,6 @@ const LibraryDrawer = ({ items }: Props) => {
const stageConfig = useAppSelector(selectConfig);
const themeColors = useThemeColors();


const selectedItemsCount = Object.keys(selectedItemsIds).length;
const hasItems = Boolean(items.length);
const hasSelectedItems = Boolean(selectedItemsCount);
Expand Down Expand Up @@ -67,7 +66,13 @@ const LibraryDrawer = ({ items }: Props) => {

return (
<Drawer modal={false}>
<Drawer.Trigger align="between" color="secondary" size="sm" gap="sm">
<Drawer.Trigger
align="between"
color="secondary"
size="sm"
gap="sm"
data-testid="library-drawer-trigger"
>
<Icon name="book" />
<Text size="sm">Library</Text>
</Drawer.Trigger>
Expand All @@ -93,7 +98,7 @@ const LibraryDrawer = ({ items }: Props) => {
disabled={!hasSelectedItems}
onClick={handleRemoveSelectedItems}
squared
data-testid="remove-selected-items-button"
data-testid="remove-library-items-button"
>
<Icon name="trash" />
</Button>
Expand Down
8 changes: 8 additions & 0 deletions apps/client/src/types/global.d.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,8 @@
import type Konva from 'konva';

declare global {
interface Window {
// eslint-disable-next-line @typescript-eslint/naming-convention
Konva: typeof Konva;
}
}

0 comments on commit 371f1e2

Please sign in to comment.