import { vi, describe, it, expect, afterEach } from 'vitest'; import { cleanup, render } from 'vitest-browser-svelte'; import { page } from 'vitest/browser'; import type { createPdfRenderer } from '$lib/document/viewer/usePdfRenderer.svelte'; import PdfViewer from './PdfViewer.svelte'; afterEach(cleanup); function makeFakePdfjsLib() { function TextLayerMock() {} TextLayerMock.prototype.render = () => Promise.resolve(); TextLayerMock.prototype.cancel = () => {}; return { GlobalWorkerOptions: { workerSrc: '' }, getDocument: vi.fn().mockReturnValue({ promise: Promise.resolve({ numPages: 2, getPage: vi.fn().mockResolvedValue({ getViewport: vi.fn().mockReturnValue({ width: 595, height: 842 }), render: vi.fn().mockReturnValue({ promise: Promise.resolve() }), streamTextContent: vi.fn().mockReturnValue(new ReadableStream()) }) }) }), TextLayer: TextLayerMock // Partial fake: only the methods used by usePdfRenderer are implemented } as unknown as typeof import('pdfjs-dist'); } function makeFakeLibLoader(): Parameters[0] { const fakePdfjs = makeFakePdfjsLib(); return vi.fn().mockResolvedValue([fakePdfjs, { default: '' }] as const); } describe('PdfViewer', () => { it('shows previous and next page navigation buttons', async () => { render(PdfViewer, { url: '/api/documents/test-id/file', libLoader: makeFakeLibLoader() }); await expect.element(page.getByRole('button', { name: /zurück/i })).toBeInTheDocument(); await expect.element(page.getByRole('button', { name: /weiter/i })).toBeInTheDocument(); }); it('shows zoom controls', async () => { render(PdfViewer, { url: '/api/documents/test-id/file', libLoader: makeFakeLibLoader() }); await expect.element(page.getByRole('button', { name: /vergrößern/i })).toBeInTheDocument(); await expect.element(page.getByRole('button', { name: /verkleinern/i })).toBeInTheDocument(); }); it('displays the page counter once the PDF has loaded', async () => { render(PdfViewer, { url: '/api/documents/test-id/file', libLoader: makeFakeLibLoader() }); // Fake loader resolves synchronously, so "1 / 2" should appear quickly await expect.element(page.getByText(/1\s*\/\s*2/)).toBeInTheDocument(); }); });