test(mocks): switch $app/navigation factory mocks to shared __mocks__ stub
Some checks failed
CI / Unit & Component Tests (pull_request) Failing after 2m51s
CI / OCR Service Tests (pull_request) Successful in 21s
CI / Backend Unit Tests (pull_request) Successful in 3m43s
CI / fail2ban Regex (pull_request) Failing after 42s
CI / Semgrep Security Scan (pull_request) Successful in 20s
CI / Compose Bucket Idempotency (pull_request) Successful in 1m1s
Some checks failed
CI / Unit & Component Tests (pull_request) Failing after 2m51s
CI / OCR Service Tests (pull_request) Successful in 21s
CI / Backend Unit Tests (pull_request) Successful in 3m43s
CI / fail2ban Regex (pull_request) Failing after 42s
CI / Semgrep Security Scan (pull_request) Successful in 20s
CI / Compose Bucket Idempotency (pull_request) Successful in 1m1s
Migrates 36 of the remaining 37 vi.mock('$app/navigation', factory) call
sites in frontend/src/**/*.svelte.{spec,test}.ts to
vi.mock('$app/navigation') (no factory), so they all resolve to the
shared src/__mocks__/$app/navigation.ts stub introduced in commit
aea37250.
Special handling:
- DropZone.svelte.spec.ts: removed vi.hoisted invalidateAllMock; test
body now imports invalidateAll from $app/navigation and uses
vi.mocked(invalidateAll) for assertions.
- documents/bulk-edit/page.svelte.test.ts: removed the module-scope
const gotoSpy = vi.fn() that was injected into the factory; test
body now imports goto from $app/navigation and uses
vi.mocked(goto) for assertions and mockClear().
Deferred: src/lib/shared/hooks/useUnsavedWarning.svelte.test.ts uses a
non-trivial beforeNavigate wrapper that captures the callback into
module-scope state (registeredBeforeNavigate) so tests can simulate
navigation events. That hybrid factory cannot be replaced with the
plain-vi.fn() shared stub without redesigning the test; it is left in
place and will be addressed separately.
Per ADR-012: eliminating factory bodies removes 36 birpc teardown-race
surface points. The shared mock keeps every nav export as a vi.fn().
Refs #560.
Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
This commit is contained in:
@@ -4,7 +4,7 @@ import { cleanup, render } from 'vitest-browser-svelte';
|
|||||||
import { page, userEvent } from 'vitest/browser';
|
import { page, userEvent } from 'vitest/browser';
|
||||||
import BulkDocumentEditLayout from './BulkDocumentEditLayout.svelte';
|
import BulkDocumentEditLayout from './BulkDocumentEditLayout.svelte';
|
||||||
|
|
||||||
vi.mock('$app/navigation', () => ({ goto: vi.fn() }));
|
vi.mock('$app/navigation');
|
||||||
|
|
||||||
afterEach(() => {
|
afterEach(() => {
|
||||||
cleanup();
|
cleanup();
|
||||||
|
|||||||
@@ -5,7 +5,7 @@ import { goto } from '$app/navigation';
|
|||||||
import BulkSelectionBar from './BulkSelectionBar.svelte';
|
import BulkSelectionBar from './BulkSelectionBar.svelte';
|
||||||
import { bulkSelectionStore } from '$lib/document/bulkSelection.svelte';
|
import { bulkSelectionStore } from '$lib/document/bulkSelection.svelte';
|
||||||
|
|
||||||
vi.mock('$app/navigation', () => ({ goto: vi.fn() }));
|
vi.mock('$app/navigation');
|
||||||
|
|
||||||
afterEach(() => {
|
afterEach(() => {
|
||||||
cleanup();
|
cleanup();
|
||||||
|
|||||||
@@ -2,19 +2,7 @@ import { describe, it, expect, vi, afterEach } from 'vitest';
|
|||||||
import { cleanup, render } from 'vitest-browser-svelte';
|
import { cleanup, render } from 'vitest-browser-svelte';
|
||||||
import { page } from 'vitest/browser';
|
import { page } from 'vitest/browser';
|
||||||
|
|
||||||
vi.mock('$app/navigation', () => ({
|
vi.mock('$app/navigation');
|
||||||
beforeNavigate: () => {},
|
|
||||||
afterNavigate: () => {},
|
|
||||||
goto: vi.fn(),
|
|
||||||
invalidate: vi.fn(),
|
|
||||||
invalidateAll: vi.fn(),
|
|
||||||
preloadCode: vi.fn(),
|
|
||||||
preloadData: vi.fn(),
|
|
||||||
pushState: vi.fn(),
|
|
||||||
replaceState: vi.fn(),
|
|
||||||
disableScrollHandling: vi.fn(),
|
|
||||||
onNavigate: () => () => {}
|
|
||||||
}));
|
|
||||||
|
|
||||||
const { default: DocumentRow } = await import('./DocumentRow.svelte');
|
const { default: DocumentRow } = await import('./DocumentRow.svelte');
|
||||||
|
|
||||||
|
|||||||
@@ -3,7 +3,7 @@ import { cleanup, render } from 'vitest-browser-svelte';
|
|||||||
import type { NotificationItem } from '$lib/notification/notifications';
|
import type { NotificationItem } from '$lib/notification/notifications';
|
||||||
import NotificationBell from './NotificationBell.svelte';
|
import NotificationBell from './NotificationBell.svelte';
|
||||||
|
|
||||||
vi.mock('$app/navigation', () => ({ goto: vi.fn(), beforeNavigate: vi.fn() }));
|
vi.mock('$app/navigation');
|
||||||
vi.mock('$app/forms', () => ({
|
vi.mock('$app/forms', () => ({
|
||||||
enhance(node: HTMLFormElement, submit?: (opts: { formData: FormData }) => unknown) {
|
enhance(node: HTMLFormElement, submit?: (opts: { formData: FormData }) => unknown) {
|
||||||
const handler = (e: Event) => {
|
const handler = (e: Event) => {
|
||||||
|
|||||||
@@ -4,7 +4,7 @@ import { page } from 'vitest/browser';
|
|||||||
import { goto } from '$app/navigation';
|
import { goto } from '$app/navigation';
|
||||||
import NotificationDropdown from './NotificationDropdown.svelte';
|
import NotificationDropdown from './NotificationDropdown.svelte';
|
||||||
|
|
||||||
vi.mock('$app/navigation', () => ({ goto: vi.fn() }));
|
vi.mock('$app/navigation');
|
||||||
|
|
||||||
// Configurable result for the enhance mock — tests that need failure set
|
// Configurable result for the enhance mock — tests that need failure set
|
||||||
// mockFormResult.type = 'failure' before clicking.
|
// mockFormResult.type = 'failure' before clicking.
|
||||||
|
|||||||
@@ -3,7 +3,7 @@ import { cleanup, render } from 'vitest-browser-svelte';
|
|||||||
import { page } from 'vitest/browser';
|
import { page } from 'vitest/browser';
|
||||||
import StammbaumSidePanel from './StammbaumSidePanel.svelte';
|
import StammbaumSidePanel from './StammbaumSidePanel.svelte';
|
||||||
|
|
||||||
vi.mock('$app/navigation', () => ({ invalidateAll: vi.fn() }));
|
vi.mock('$app/navigation');
|
||||||
vi.mock('$app/forms', () => ({ enhance: () => () => {} }));
|
vi.mock('$app/forms', () => ({ enhance: () => () => {} }));
|
||||||
vi.mock('$lib/person/PersonTypeahead.svelte', () => ({ default: () => null }));
|
vi.mock('$lib/person/PersonTypeahead.svelte', () => ({ default: () => null }));
|
||||||
|
|
||||||
|
|||||||
@@ -3,19 +3,7 @@ import { cleanup, render } from 'vitest-browser-svelte';
|
|||||||
import { page } from 'vitest/browser';
|
import { page } from 'vitest/browser';
|
||||||
import StammbaumSidePanel from './StammbaumSidePanel.svelte';
|
import StammbaumSidePanel from './StammbaumSidePanel.svelte';
|
||||||
|
|
||||||
vi.mock('$app/navigation', () => ({
|
vi.mock('$app/navigation');
|
||||||
beforeNavigate: () => {},
|
|
||||||
afterNavigate: () => {},
|
|
||||||
goto: vi.fn(),
|
|
||||||
invalidate: vi.fn(),
|
|
||||||
invalidateAll: vi.fn(),
|
|
||||||
preloadCode: vi.fn(),
|
|
||||||
preloadData: vi.fn(),
|
|
||||||
pushState: vi.fn(),
|
|
||||||
replaceState: vi.fn(),
|
|
||||||
disableScrollHandling: vi.fn(),
|
|
||||||
onNavigate: () => () => {}
|
|
||||||
}));
|
|
||||||
|
|
||||||
afterEach(cleanup);
|
afterEach(cleanup);
|
||||||
|
|
||||||
|
|||||||
@@ -4,7 +4,7 @@ import { page } from 'vitest/browser';
|
|||||||
import DocumentList from './DocumentList.svelte';
|
import DocumentList from './DocumentList.svelte';
|
||||||
import type { components } from '$lib/generated/api';
|
import type { components } from '$lib/generated/api';
|
||||||
|
|
||||||
vi.mock('$app/navigation', () => ({ goto: vi.fn() }));
|
vi.mock('$app/navigation');
|
||||||
|
|
||||||
afterEach(() => cleanup());
|
afterEach(() => cleanup());
|
||||||
|
|
||||||
|
|||||||
@@ -2,19 +2,7 @@ import { describe, it, expect, vi, afterEach } from 'vitest';
|
|||||||
import { cleanup, render } from 'vitest-browser-svelte';
|
import { cleanup, render } from 'vitest-browser-svelte';
|
||||||
import { page } from 'vitest/browser';
|
import { page } from 'vitest/browser';
|
||||||
|
|
||||||
vi.mock('$app/navigation', () => ({
|
vi.mock('$app/navigation');
|
||||||
beforeNavigate: () => {},
|
|
||||||
afterNavigate: () => {},
|
|
||||||
goto: vi.fn(),
|
|
||||||
invalidate: vi.fn(),
|
|
||||||
invalidateAll: vi.fn(),
|
|
||||||
preloadCode: vi.fn(),
|
|
||||||
preloadData: vi.fn(),
|
|
||||||
pushState: vi.fn(),
|
|
||||||
replaceState: vi.fn(),
|
|
||||||
disableScrollHandling: vi.fn(),
|
|
||||||
onNavigate: () => () => {}
|
|
||||||
}));
|
|
||||||
|
|
||||||
const { default: DocumentList } = await import('./DocumentList.svelte');
|
const { default: DocumentList } = await import('./DocumentList.svelte');
|
||||||
|
|
||||||
|
|||||||
@@ -1,13 +1,11 @@
|
|||||||
import { describe, it, expect, afterEach, vi } from 'vitest';
|
import { describe, it, expect, afterEach, vi } from 'vitest';
|
||||||
import { cleanup, render } from 'vitest-browser-svelte';
|
import { cleanup, render } from 'vitest-browser-svelte';
|
||||||
import { page } from 'vitest/browser';
|
import { page } from 'vitest/browser';
|
||||||
|
import { invalidateAll } from '$app/navigation';
|
||||||
|
|
||||||
import DropZone from './DropZone.svelte';
|
import DropZone from './DropZone.svelte';
|
||||||
|
|
||||||
// vi.hoisted lets the mock fn reference survive vi.mock's hoisting so tests
|
vi.mock('$app/navigation');
|
||||||
// can assert on it from below while the factory remains self-contained.
|
|
||||||
const { invalidateAllMock } = vi.hoisted(() => ({ invalidateAllMock: vi.fn(async () => {}) }));
|
|
||||||
vi.mock('$app/navigation', () => ({ invalidateAll: invalidateAllMock }));
|
|
||||||
|
|
||||||
afterEach(() => {
|
afterEach(() => {
|
||||||
cleanup();
|
cleanup();
|
||||||
@@ -68,7 +66,7 @@ describe('DropZone onUploadComplete', () => {
|
|||||||
// invalidateAll is the last async step of the upload handler — once it
|
// invalidateAll is the last async step of the upload handler — once it
|
||||||
// has been called, the callback decision has already been made.
|
// has been called, the callback decision has already been made.
|
||||||
await vi.waitFor(() => {
|
await vi.waitFor(() => {
|
||||||
expect(invalidateAllMock).toHaveBeenCalled();
|
expect(vi.mocked(invalidateAll)).toHaveBeenCalled();
|
||||||
});
|
});
|
||||||
expect(onUploadComplete).not.toHaveBeenCalled();
|
expect(onUploadComplete).not.toHaveBeenCalled();
|
||||||
});
|
});
|
||||||
|
|||||||
@@ -2,19 +2,7 @@ import { describe, it, expect, vi, afterEach } from 'vitest';
|
|||||||
import { cleanup, render } from 'vitest-browser-svelte';
|
import { cleanup, render } from 'vitest-browser-svelte';
|
||||||
import { page } from 'vitest/browser';
|
import { page } from 'vitest/browser';
|
||||||
|
|
||||||
vi.mock('$app/navigation', () => ({
|
vi.mock('$app/navigation');
|
||||||
beforeNavigate: () => {},
|
|
||||||
afterNavigate: () => {},
|
|
||||||
goto: vi.fn(),
|
|
||||||
invalidate: vi.fn(),
|
|
||||||
invalidateAll: vi.fn(),
|
|
||||||
preloadCode: vi.fn(),
|
|
||||||
preloadData: vi.fn(),
|
|
||||||
pushState: vi.fn(),
|
|
||||||
replaceState: vi.fn(),
|
|
||||||
disableScrollHandling: vi.fn(),
|
|
||||||
onNavigate: () => () => {}
|
|
||||||
}));
|
|
||||||
|
|
||||||
const { default: DropZone } = await import('./DropZone.svelte');
|
const { default: DropZone } = await import('./DropZone.svelte');
|
||||||
|
|
||||||
|
|||||||
@@ -5,7 +5,7 @@ import Page from './+page.svelte';
|
|||||||
import { createConfirmService, CONFIRM_KEY } from '$lib/shared/services/confirm.svelte.js';
|
import { createConfirmService, CONFIRM_KEY } from '$lib/shared/services/confirm.svelte.js';
|
||||||
|
|
||||||
vi.mock('$app/forms', () => ({ enhance: () => () => {} }));
|
vi.mock('$app/forms', () => ({ enhance: () => () => {} }));
|
||||||
vi.mock('$app/navigation', () => ({ beforeNavigate: vi.fn(), goto: vi.fn() }));
|
vi.mock('$app/navigation');
|
||||||
|
|
||||||
import { beforeNavigate, goto } from '$app/navigation';
|
import { beforeNavigate, goto } from '$app/navigation';
|
||||||
|
|
||||||
|
|||||||
@@ -11,7 +11,7 @@ vi.mock('$app/forms', () => ({
|
|||||||
return { destroy: vi.fn() };
|
return { destroy: vi.fn() };
|
||||||
}
|
}
|
||||||
}));
|
}));
|
||||||
vi.mock('$app/navigation', () => ({ beforeNavigate: vi.fn(), goto: vi.fn() }));
|
vi.mock('$app/navigation');
|
||||||
|
|
||||||
import { beforeNavigate, goto } from '$app/navigation';
|
import { beforeNavigate, goto } from '$app/navigation';
|
||||||
|
|
||||||
|
|||||||
@@ -2,19 +2,7 @@ import { describe, it, expect, vi, afterEach } from 'vitest';
|
|||||||
import { cleanup, render } from 'vitest-browser-svelte';
|
import { cleanup, render } from 'vitest-browser-svelte';
|
||||||
import { page } from 'vitest/browser';
|
import { page } from 'vitest/browser';
|
||||||
|
|
||||||
vi.mock('$app/navigation', () => ({
|
vi.mock('$app/navigation');
|
||||||
beforeNavigate: () => {},
|
|
||||||
afterNavigate: () => {},
|
|
||||||
goto: vi.fn(),
|
|
||||||
invalidate: vi.fn(),
|
|
||||||
invalidateAll: vi.fn(),
|
|
||||||
preloadCode: vi.fn(),
|
|
||||||
preloadData: vi.fn(),
|
|
||||||
pushState: vi.fn(),
|
|
||||||
replaceState: vi.fn(),
|
|
||||||
disableScrollHandling: vi.fn(),
|
|
||||||
onNavigate: () => () => {}
|
|
||||||
}));
|
|
||||||
|
|
||||||
const { default: AdminGroupNewPage } = await import('./+page.svelte');
|
const { default: AdminGroupNewPage } = await import('./+page.svelte');
|
||||||
|
|
||||||
|
|||||||
@@ -8,7 +8,7 @@ import { cleanup, render } from 'vitest-browser-svelte';
|
|||||||
import { page } from 'vitest/browser';
|
import { page } from 'vitest/browser';
|
||||||
import Page from './+page.svelte';
|
import Page from './+page.svelte';
|
||||||
|
|
||||||
vi.mock('$app/navigation', () => ({ goto: vi.fn() }));
|
vi.mock('$app/navigation');
|
||||||
|
|
||||||
const fullData = {
|
const fullData = {
|
||||||
userCount: 4,
|
userCount: 4,
|
||||||
|
|||||||
@@ -2,19 +2,7 @@ import { describe, it, expect, vi, afterEach } from 'vitest';
|
|||||||
import { cleanup, render } from 'vitest-browser-svelte';
|
import { cleanup, render } from 'vitest-browser-svelte';
|
||||||
import { page } from 'vitest/browser';
|
import { page } from 'vitest/browser';
|
||||||
|
|
||||||
vi.mock('$app/navigation', () => ({
|
vi.mock('$app/navigation');
|
||||||
beforeNavigate: () => {},
|
|
||||||
afterNavigate: () => {},
|
|
||||||
goto: vi.fn(),
|
|
||||||
invalidate: vi.fn(),
|
|
||||||
invalidateAll: vi.fn(),
|
|
||||||
preloadCode: vi.fn(),
|
|
||||||
preloadData: vi.fn(),
|
|
||||||
pushState: vi.fn(),
|
|
||||||
replaceState: vi.fn(),
|
|
||||||
disableScrollHandling: vi.fn(),
|
|
||||||
onNavigate: () => () => {}
|
|
||||||
}));
|
|
||||||
|
|
||||||
const { default: AdminEntryPage } = await import('./+page.svelte');
|
const { default: AdminEntryPage } = await import('./+page.svelte');
|
||||||
|
|
||||||
|
|||||||
@@ -5,11 +5,7 @@ import Page from './+page.svelte';
|
|||||||
import { createConfirmService, CONFIRM_KEY } from '$lib/shared/services/confirm.svelte.js';
|
import { createConfirmService, CONFIRM_KEY } from '$lib/shared/services/confirm.svelte.js';
|
||||||
|
|
||||||
vi.mock('$app/forms', () => ({ enhance: () => () => {} }));
|
vi.mock('$app/forms', () => ({ enhance: () => () => {} }));
|
||||||
vi.mock('$app/navigation', () => ({
|
vi.mock('$app/navigation');
|
||||||
beforeNavigate: vi.fn(),
|
|
||||||
goto: vi.fn(),
|
|
||||||
replaceState: vi.fn()
|
|
||||||
}));
|
|
||||||
vi.mock('$app/stores', () => ({
|
vi.mock('$app/stores', () => ({
|
||||||
page: {
|
page: {
|
||||||
subscribe: (fn: (v: { url: URL }) => void) => {
|
subscribe: (fn: (v: { url: URL }) => void) => {
|
||||||
|
|||||||
@@ -17,19 +17,7 @@ vi.mock('$lib/shared/services/confirm.svelte', () => ({
|
|||||||
getConfirmService: () => ({ confirm: async () => false })
|
getConfirmService: () => ({ confirm: async () => false })
|
||||||
}));
|
}));
|
||||||
|
|
||||||
vi.mock('$app/navigation', () => ({
|
vi.mock('$app/navigation');
|
||||||
beforeNavigate: () => {},
|
|
||||||
afterNavigate: () => {},
|
|
||||||
goto: vi.fn(),
|
|
||||||
invalidate: vi.fn(),
|
|
||||||
invalidateAll: vi.fn(),
|
|
||||||
preloadCode: vi.fn(),
|
|
||||||
preloadData: vi.fn(),
|
|
||||||
pushState: vi.fn(),
|
|
||||||
replaceState: vi.fn(),
|
|
||||||
disableScrollHandling: vi.fn(),
|
|
||||||
onNavigate: () => () => {}
|
|
||||||
}));
|
|
||||||
|
|
||||||
const { default: AdminTagEditPage } = await import('./+page.svelte');
|
const { default: AdminTagEditPage } = await import('./+page.svelte');
|
||||||
|
|
||||||
|
|||||||
@@ -15,7 +15,7 @@ vi.mock('$app/forms', () => ({
|
|||||||
return () => {};
|
return () => {};
|
||||||
}
|
}
|
||||||
}));
|
}));
|
||||||
vi.mock('$app/navigation', () => ({ beforeNavigate: vi.fn(), goto: vi.fn() }));
|
vi.mock('$app/navigation');
|
||||||
|
|
||||||
import { beforeNavigate, goto } from '$app/navigation';
|
import { beforeNavigate, goto } from '$app/navigation';
|
||||||
|
|
||||||
|
|||||||
@@ -11,7 +11,7 @@ vi.mock('$app/forms', () => ({
|
|||||||
return { destroy: vi.fn() };
|
return { destroy: vi.fn() };
|
||||||
}
|
}
|
||||||
}));
|
}));
|
||||||
vi.mock('$app/navigation', () => ({ beforeNavigate: vi.fn(), goto: vi.fn() }));
|
vi.mock('$app/navigation');
|
||||||
|
|
||||||
import { beforeNavigate, goto } from '$app/navigation';
|
import { beforeNavigate, goto } from '$app/navigation';
|
||||||
|
|
||||||
|
|||||||
@@ -2,19 +2,7 @@ import { describe, it, expect, vi, afterEach } from 'vitest';
|
|||||||
import { cleanup, render } from 'vitest-browser-svelte';
|
import { cleanup, render } from 'vitest-browser-svelte';
|
||||||
import { page } from 'vitest/browser';
|
import { page } from 'vitest/browser';
|
||||||
|
|
||||||
vi.mock('$app/navigation', () => ({
|
vi.mock('$app/navigation');
|
||||||
beforeNavigate: () => {},
|
|
||||||
afterNavigate: () => {},
|
|
||||||
goto: vi.fn(),
|
|
||||||
invalidate: vi.fn(),
|
|
||||||
invalidateAll: vi.fn(),
|
|
||||||
preloadCode: vi.fn(),
|
|
||||||
preloadData: vi.fn(),
|
|
||||||
pushState: vi.fn(),
|
|
||||||
replaceState: vi.fn(),
|
|
||||||
disableScrollHandling: vi.fn(),
|
|
||||||
onNavigate: () => () => {}
|
|
||||||
}));
|
|
||||||
|
|
||||||
const { default: AdminUserNewPage } = await import('./+page.svelte');
|
const { default: AdminUserNewPage } = await import('./+page.svelte');
|
||||||
|
|
||||||
|
|||||||
@@ -14,19 +14,7 @@ vi.mock('$app/state', () => ({
|
|||||||
}
|
}
|
||||||
}));
|
}));
|
||||||
|
|
||||||
vi.mock('$app/navigation', () => ({
|
vi.mock('$app/navigation');
|
||||||
beforeNavigate: () => {},
|
|
||||||
afterNavigate: () => {},
|
|
||||||
goto: vi.fn(),
|
|
||||||
invalidate: vi.fn(),
|
|
||||||
invalidateAll: vi.fn(),
|
|
||||||
preloadCode: vi.fn(),
|
|
||||||
preloadData: vi.fn(),
|
|
||||||
pushState: vi.fn(),
|
|
||||||
replaceState: vi.fn(),
|
|
||||||
disableScrollHandling: vi.fn(),
|
|
||||||
onNavigate: () => () => {}
|
|
||||||
}));
|
|
||||||
|
|
||||||
vi.mock('$lib/notification/notifications.svelte', () => ({
|
vi.mock('$lib/notification/notifications.svelte', () => ({
|
||||||
notificationStore: {
|
notificationStore: {
|
||||||
|
|||||||
@@ -3,7 +3,7 @@ import { cleanup, render } from 'vitest-browser-svelte';
|
|||||||
import { page } from 'vitest/browser';
|
import { page } from 'vitest/browser';
|
||||||
import CorrespondenzHero from './CorrespondenzHero.svelte';
|
import CorrespondenzHero from './CorrespondenzHero.svelte';
|
||||||
|
|
||||||
vi.mock('$app/navigation', () => ({ goto: vi.fn() }));
|
vi.mock('$app/navigation');
|
||||||
|
|
||||||
afterEach(cleanup);
|
afterEach(cleanup);
|
||||||
|
|
||||||
|
|||||||
@@ -3,7 +3,7 @@ import { cleanup, render } from 'vitest-browser-svelte';
|
|||||||
import { page } from 'vitest/browser';
|
import { page } from 'vitest/browser';
|
||||||
import Page from './+page.svelte';
|
import Page from './+page.svelte';
|
||||||
|
|
||||||
vi.mock('$app/navigation', () => ({ goto: vi.fn() }));
|
vi.mock('$app/navigation');
|
||||||
|
|
||||||
afterEach(cleanup);
|
afterEach(cleanup);
|
||||||
|
|
||||||
|
|||||||
@@ -2,19 +2,7 @@ import { describe, it, expect, vi, afterEach } from 'vitest';
|
|||||||
import { cleanup, render } from 'vitest-browser-svelte';
|
import { cleanup, render } from 'vitest-browser-svelte';
|
||||||
import { page } from 'vitest/browser';
|
import { page } from 'vitest/browser';
|
||||||
|
|
||||||
vi.mock('$app/navigation', () => ({
|
vi.mock('$app/navigation');
|
||||||
beforeNavigate: () => {},
|
|
||||||
afterNavigate: () => {},
|
|
||||||
goto: vi.fn(),
|
|
||||||
invalidate: vi.fn(),
|
|
||||||
invalidateAll: vi.fn(),
|
|
||||||
preloadCode: vi.fn(),
|
|
||||||
preloadData: vi.fn(),
|
|
||||||
pushState: vi.fn(),
|
|
||||||
replaceState: vi.fn(),
|
|
||||||
disableScrollHandling: vi.fn(),
|
|
||||||
onNavigate: () => () => {}
|
|
||||||
}));
|
|
||||||
|
|
||||||
const { default: BriefwechselPage } = await import('./+page.svelte');
|
const { default: BriefwechselPage } = await import('./+page.svelte');
|
||||||
|
|
||||||
|
|||||||
@@ -13,19 +13,7 @@ vi.mock('$app/state', () => ({
|
|||||||
}
|
}
|
||||||
}));
|
}));
|
||||||
|
|
||||||
vi.mock('$app/navigation', () => ({
|
vi.mock('$app/navigation');
|
||||||
beforeNavigate: () => {},
|
|
||||||
afterNavigate: () => {},
|
|
||||||
goto: vi.fn(),
|
|
||||||
invalidate: vi.fn(),
|
|
||||||
invalidateAll: vi.fn(),
|
|
||||||
preloadCode: vi.fn(),
|
|
||||||
preloadData: vi.fn(),
|
|
||||||
pushState: vi.fn(),
|
|
||||||
replaceState: vi.fn(),
|
|
||||||
disableScrollHandling: vi.fn(),
|
|
||||||
onNavigate: () => () => {}
|
|
||||||
}));
|
|
||||||
|
|
||||||
vi.mock('$lib/shared/services/confirm.svelte', () => ({
|
vi.mock('$lib/shared/services/confirm.svelte', () => ({
|
||||||
getConfirmService: () => ({ confirm: async () => false })
|
getConfirmService: () => ({ confirm: async () => false })
|
||||||
|
|||||||
@@ -1,21 +1,9 @@
|
|||||||
import { describe, it, expect, vi, afterEach } from 'vitest';
|
import { describe, it, expect, vi, afterEach } from 'vitest';
|
||||||
import { cleanup, render } from 'vitest-browser-svelte';
|
import { cleanup, render } from 'vitest-browser-svelte';
|
||||||
import { page } from 'vitest/browser';
|
import { page } from 'vitest/browser';
|
||||||
|
import { goto } from '$app/navigation';
|
||||||
|
|
||||||
const gotoSpy = vi.fn();
|
vi.mock('$app/navigation');
|
||||||
vi.mock('$app/navigation', () => ({
|
|
||||||
beforeNavigate: () => {},
|
|
||||||
afterNavigate: () => {},
|
|
||||||
goto: gotoSpy,
|
|
||||||
invalidate: vi.fn(),
|
|
||||||
invalidateAll: vi.fn(),
|
|
||||||
preloadCode: vi.fn(),
|
|
||||||
preloadData: vi.fn(),
|
|
||||||
pushState: vi.fn(),
|
|
||||||
replaceState: vi.fn(),
|
|
||||||
disableScrollHandling: vi.fn(),
|
|
||||||
onNavigate: () => () => {}
|
|
||||||
}));
|
|
||||||
|
|
||||||
const { bulkSelectionStore } = await import('$lib/document/bulkSelection.svelte');
|
const { bulkSelectionStore } = await import('$lib/document/bulkSelection.svelte');
|
||||||
const { default: BulkEditPage } = await import('./+page.svelte');
|
const { default: BulkEditPage } = await import('./+page.svelte');
|
||||||
@@ -23,14 +11,14 @@ const { default: BulkEditPage } = await import('./+page.svelte');
|
|||||||
afterEach(() => {
|
afterEach(() => {
|
||||||
cleanup();
|
cleanup();
|
||||||
bulkSelectionStore.clear();
|
bulkSelectionStore.clear();
|
||||||
gotoSpy.mockClear();
|
vi.mocked(goto).mockClear();
|
||||||
});
|
});
|
||||||
|
|
||||||
describe('documents/bulk-edit page', () => {
|
describe('documents/bulk-edit page', () => {
|
||||||
it('redirects to /documents when no documents are selected', async () => {
|
it('redirects to /documents when no documents are selected', async () => {
|
||||||
render(BulkEditPage, { props: {} });
|
render(BulkEditPage, { props: {} });
|
||||||
|
|
||||||
await vi.waitFor(() => expect(gotoSpy).toHaveBeenCalledWith('/documents'));
|
await vi.waitFor(() => expect(vi.mocked(goto)).toHaveBeenCalledWith('/documents'));
|
||||||
});
|
});
|
||||||
|
|
||||||
it('shows the loading spinner while fetching batch metadata', async () => {
|
it('shows the loading spinner while fetching batch metadata', async () => {
|
||||||
|
|||||||
@@ -2,7 +2,7 @@ import { afterEach, beforeEach, describe, expect, it, vi } from 'vitest';
|
|||||||
import { cleanup, render } from 'vitest-browser-svelte';
|
import { cleanup, render } from 'vitest-browser-svelte';
|
||||||
import { page } from 'vitest/browser';
|
import { page } from 'vitest/browser';
|
||||||
|
|
||||||
vi.mock('$app/navigation', () => ({ goto: vi.fn() }));
|
vi.mock('$app/navigation');
|
||||||
vi.mock('$app/state', () => ({ navigating: { to: null } }));
|
vi.mock('$app/state', () => ({ navigating: { to: null } }));
|
||||||
|
|
||||||
import Page from './+page.svelte';
|
import Page from './+page.svelte';
|
||||||
|
|||||||
@@ -4,19 +4,7 @@ import { page } from 'vitest/browser';
|
|||||||
|
|
||||||
const mockNavigating = { to: null };
|
const mockNavigating = { to: null };
|
||||||
|
|
||||||
vi.mock('$app/navigation', () => ({
|
vi.mock('$app/navigation');
|
||||||
beforeNavigate: () => {},
|
|
||||||
afterNavigate: () => {},
|
|
||||||
goto: vi.fn(),
|
|
||||||
invalidate: vi.fn(),
|
|
||||||
invalidateAll: vi.fn(),
|
|
||||||
preloadCode: vi.fn(),
|
|
||||||
preloadData: vi.fn(),
|
|
||||||
pushState: vi.fn(),
|
|
||||||
replaceState: vi.fn(),
|
|
||||||
disableScrollHandling: vi.fn(),
|
|
||||||
onNavigate: () => () => {}
|
|
||||||
}));
|
|
||||||
|
|
||||||
vi.mock('$app/state', () => ({
|
vi.mock('$app/state', () => ({
|
||||||
get navigating() {
|
get navigating() {
|
||||||
|
|||||||
@@ -2,19 +2,7 @@ import { describe, it, expect, vi, afterEach } from 'vitest';
|
|||||||
import { cleanup, render } from 'vitest-browser-svelte';
|
import { cleanup, render } from 'vitest-browser-svelte';
|
||||||
import { page } from 'vitest/browser';
|
import { page } from 'vitest/browser';
|
||||||
|
|
||||||
vi.mock('$app/navigation', () => ({
|
vi.mock('$app/navigation');
|
||||||
beforeNavigate: () => {},
|
|
||||||
afterNavigate: () => {},
|
|
||||||
goto: vi.fn(),
|
|
||||||
invalidate: vi.fn(),
|
|
||||||
invalidateAll: vi.fn(),
|
|
||||||
preloadCode: vi.fn(),
|
|
||||||
preloadData: vi.fn(),
|
|
||||||
pushState: vi.fn(),
|
|
||||||
replaceState: vi.fn(),
|
|
||||||
disableScrollHandling: vi.fn(),
|
|
||||||
onNavigate: () => () => {}
|
|
||||||
}));
|
|
||||||
|
|
||||||
const { default: GeschichtenEditPage } = await import('./+page.svelte');
|
const { default: GeschichtenEditPage } = await import('./+page.svelte');
|
||||||
|
|
||||||
|
|||||||
@@ -2,19 +2,7 @@ import { describe, it, expect, vi, afterEach } from 'vitest';
|
|||||||
import { cleanup, render } from 'vitest-browser-svelte';
|
import { cleanup, render } from 'vitest-browser-svelte';
|
||||||
import { page } from 'vitest/browser';
|
import { page } from 'vitest/browser';
|
||||||
|
|
||||||
vi.mock('$app/navigation', () => ({
|
vi.mock('$app/navigation');
|
||||||
beforeNavigate: () => {},
|
|
||||||
afterNavigate: () => {},
|
|
||||||
goto: vi.fn(),
|
|
||||||
invalidate: vi.fn(),
|
|
||||||
invalidateAll: vi.fn(),
|
|
||||||
preloadCode: vi.fn(),
|
|
||||||
preloadData: vi.fn(),
|
|
||||||
pushState: vi.fn(),
|
|
||||||
replaceState: vi.fn(),
|
|
||||||
disableScrollHandling: vi.fn(),
|
|
||||||
onNavigate: () => () => {}
|
|
||||||
}));
|
|
||||||
|
|
||||||
const { default: GeschichtenNewPage } = await import('./+page.svelte');
|
const { default: GeschichtenNewPage } = await import('./+page.svelte');
|
||||||
|
|
||||||
|
|||||||
@@ -2,7 +2,7 @@ import { afterEach, describe, expect, it, vi } from 'vitest';
|
|||||||
import { cleanup, render } from 'vitest-browser-svelte';
|
import { cleanup, render } from 'vitest-browser-svelte';
|
||||||
import { page } from 'vitest/browser';
|
import { page } from 'vitest/browser';
|
||||||
|
|
||||||
vi.mock('$app/navigation', () => ({ goto: vi.fn() }));
|
vi.mock('$app/navigation');
|
||||||
vi.mock('$app/state', () => ({ navigating: { to: null } }));
|
vi.mock('$app/state', () => ({ navigating: { to: null } }));
|
||||||
|
|
||||||
import Page from './+page.svelte';
|
import Page from './+page.svelte';
|
||||||
|
|||||||
@@ -2,19 +2,7 @@ import { describe, it, expect, vi, afterEach } from 'vitest';
|
|||||||
import { cleanup, render } from 'vitest-browser-svelte';
|
import { cleanup, render } from 'vitest-browser-svelte';
|
||||||
import { page } from 'vitest/browser';
|
import { page } from 'vitest/browser';
|
||||||
|
|
||||||
vi.mock('$app/navigation', () => ({
|
vi.mock('$app/navigation');
|
||||||
beforeNavigate: () => {},
|
|
||||||
afterNavigate: () => {},
|
|
||||||
goto: vi.fn(),
|
|
||||||
invalidate: vi.fn(),
|
|
||||||
invalidateAll: vi.fn(),
|
|
||||||
preloadCode: vi.fn(),
|
|
||||||
preloadData: vi.fn(),
|
|
||||||
pushState: vi.fn(),
|
|
||||||
replaceState: vi.fn(),
|
|
||||||
disableScrollHandling: vi.fn(),
|
|
||||||
onNavigate: () => () => {}
|
|
||||||
}));
|
|
||||||
|
|
||||||
const { default: GeschichtenListPage } = await import('./+page.svelte');
|
const { default: GeschichtenListPage } = await import('./+page.svelte');
|
||||||
|
|
||||||
|
|||||||
@@ -8,7 +8,7 @@ type User = components['schemas']['AppUser'];
|
|||||||
|
|
||||||
afterEach(cleanup);
|
afterEach(cleanup);
|
||||||
|
|
||||||
vi.mock('$app/navigation', () => ({ goto: vi.fn(), invalidateAll: vi.fn() }));
|
vi.mock('$app/navigation');
|
||||||
|
|
||||||
const baseUser: User = {
|
const baseUser: User = {
|
||||||
id: 'u1',
|
id: 'u1',
|
||||||
|
|||||||
@@ -5,7 +5,7 @@ import Page from './+page.svelte';
|
|||||||
|
|
||||||
const tick = () => new Promise((r) => setTimeout(r, 0));
|
const tick = () => new Promise((r) => setTimeout(r, 0));
|
||||||
|
|
||||||
vi.mock('$app/navigation', () => ({ goto: vi.fn() }));
|
vi.mock('$app/navigation');
|
||||||
|
|
||||||
const makePerson = (overrides = {}) => ({
|
const makePerson = (overrides = {}) => ({
|
||||||
id: '1',
|
id: '1',
|
||||||
|
|||||||
@@ -2,19 +2,7 @@ import { describe, it, expect, vi, afterEach } from 'vitest';
|
|||||||
import { cleanup, render } from 'vitest-browser-svelte';
|
import { cleanup, render } from 'vitest-browser-svelte';
|
||||||
import { page } from 'vitest/browser';
|
import { page } from 'vitest/browser';
|
||||||
|
|
||||||
vi.mock('$app/navigation', () => ({
|
vi.mock('$app/navigation');
|
||||||
beforeNavigate: () => {},
|
|
||||||
afterNavigate: () => {},
|
|
||||||
goto: vi.fn(),
|
|
||||||
invalidate: vi.fn(),
|
|
||||||
invalidateAll: vi.fn(),
|
|
||||||
preloadCode: vi.fn(),
|
|
||||||
preloadData: vi.fn(),
|
|
||||||
pushState: vi.fn(),
|
|
||||||
replaceState: vi.fn(),
|
|
||||||
disableScrollHandling: vi.fn(),
|
|
||||||
onNavigate: () => () => {}
|
|
||||||
}));
|
|
||||||
|
|
||||||
const { default: PersonsListPage } = await import('./+page.svelte');
|
const { default: PersonsListPage } = await import('./+page.svelte');
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user