- import PdfViewer left mid-file from vi.mock hoisting — no longer needed (Sara/Felix) - adds one-line comment explaining as unknown as cast is an intentional partial fake (Felix) Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
55 lines
2.2 KiB
TypeScript
55 lines
2.2 KiB
TypeScript
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<typeof createPdfRenderer>[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();
|
|
});
|
|
});
|