diff options
| author | kj_sh604 | 2026-03-15 16:19:35 -0400 |
|---|---|---|
| committer | kj_sh604 | 2026-03-15 16:19:35 -0400 |
| commit | 6ec259a0e71174651bae95d4628138bf6fd68742 (patch) | |
| tree | 5e33c6a5ec091ecabfcb257fdc7b6a88ed8754ac /packages/excalidraw/components/Sidebar/siderbar.test.helpers.tsx | |
| parent | 16c8578b15c727f22921f8a80a56ee4d4e7f2272 (diff) | |
refactor: packages/
Diffstat (limited to 'packages/excalidraw/components/Sidebar/siderbar.test.helpers.tsx')
| -rw-r--r-- | packages/excalidraw/components/Sidebar/siderbar.test.helpers.tsx | 42 |
1 files changed, 42 insertions, 0 deletions
diff --git a/packages/excalidraw/components/Sidebar/siderbar.test.helpers.tsx b/packages/excalidraw/components/Sidebar/siderbar.test.helpers.tsx new file mode 100644 index 0000000..c2a3743 --- /dev/null +++ b/packages/excalidraw/components/Sidebar/siderbar.test.helpers.tsx @@ -0,0 +1,42 @@ +import React from "react"; +import { Excalidraw } from "../.."; +import { + GlobalTestState, + queryByTestId, + render, + withExcalidrawDimensions, +} from "../../tests/test-utils"; + +export const assertSidebarDockButton = async <T extends boolean>( + hasDockButton: T, +): Promise< + T extends false + ? { dockButton: null; sidebar: HTMLElement } + : { dockButton: HTMLElement; sidebar: HTMLElement } +> => { + const sidebar = + GlobalTestState.renderResult.container.querySelector<HTMLElement>( + ".sidebar", + ); + expect(sidebar).not.toBe(null); + const dockButton = queryByTestId(sidebar!, "sidebar-dock"); + if (hasDockButton) { + expect(dockButton).not.toBe(null); + return { dockButton: dockButton!, sidebar: sidebar! } as any; + } + expect(dockButton).toBe(null); + return { dockButton: null, sidebar: sidebar! } as any; +}; + +export const assertExcalidrawWithSidebar = async ( + sidebar: React.ReactNode, + name: string, + test: () => void, +) => { + await render( + <Excalidraw initialData={{ appState: { openSidebar: { name } } }}> + {sidebar} + </Excalidraw>, + ); + await withExcalidrawDimensions({ width: 1920, height: 1080 }, test); +}; |
