forked from chatml/chatml
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathvitest.setup.ts
More file actions
86 lines (77 loc) · 2.63 KB
/
vitest.setup.ts
File metadata and controls
86 lines (77 loc) · 2.63 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
import '@testing-library/jest-dom/vitest';
import { vi, beforeAll, afterEach, afterAll } from 'vitest';
import { cleanup } from '@testing-library/react';
import { server } from '@/__mocks__/server';
// Polyfill localStorage for jsdom (node's --localstorage-file may not work)
if (typeof globalThis.localStorage === 'undefined' || typeof globalThis.localStorage.setItem !== 'function') {
const store = new Map<string, string>();
const localStorageMock: Storage = {
getItem: (key: string) => store.get(key) ?? null,
setItem: (key: string, value: string) => { store.set(key, String(value)); },
removeItem: (key: string) => { store.delete(key); },
clear: () => { store.clear(); },
get length() { return store.size; },
key: (index: number) => [...store.keys()][index] ?? null,
};
Object.defineProperty(globalThis, 'localStorage', { value: localStorageMock, writable: true });
}
// MSW server lifecycle
beforeAll(() => server.listen({ onUnhandledRequest: 'error' }));
afterEach(() => {
server.resetHandlers();
cleanup();
});
afterAll(() => server.close());
// Mock window.__TAURI__ for Tauri detection
beforeAll(() => {
Object.defineProperty(window, '__TAURI__', {
value: undefined,
writable: true,
});
});
// Mock ResizeObserver (used by many UI components, including react-virtuoso)
global.ResizeObserver = class ResizeObserver {
observe = vi.fn();
unobserve = vi.fn();
disconnect = vi.fn();
// eslint-disable-next-line @typescript-eslint/no-unused-vars
constructor(_cb: ResizeObserverCallback) {}
} as unknown as typeof globalThis.ResizeObserver;
// Mock IntersectionObserver
global.IntersectionObserver = vi.fn().mockImplementation(() => ({
observe: vi.fn(),
unobserve: vi.fn(),
disconnect: vi.fn(),
}));
// Mock matchMedia
Object.defineProperty(window, 'matchMedia', {
writable: true,
value: vi.fn().mockImplementation((query) => ({
matches: false,
media: query,
onchange: null,
addListener: vi.fn(),
removeListener: vi.fn(),
addEventListener: vi.fn(),
removeEventListener: vi.fn(),
dispatchEvent: vi.fn(),
})),
});
// Mock scrollIntoView
Element.prototype.scrollIntoView = vi.fn();
// Suppress known @iconify/react teardown error (fires timers after jsdom window is gone)
process.on('uncaughtException', (err) => {
if (
err instanceof ReferenceError &&
err.message === 'window is not defined' &&
err.stack?.includes('iconify')
) {
// Swallow known @iconify/react teardown error
return;
}
throw err;
});
// Mock crypto.randomUUID
Object.defineProperty(crypto, 'randomUUID', {
value: () => 'test-uuid-' + Math.random().toString(36).slice(2, 11),
});