-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathjest.setup.js
More file actions
76 lines (70 loc) · 1.85 KB
/
jest.setup.js
File metadata and controls
76 lines (70 loc) · 1.85 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
// Add custom jest matchers from jest-dom
import '@testing-library/jest-dom'
// Mock next/navigation for testing
jest.mock('next/navigation', () => ({
useRouter: () => ({
push: jest.fn(),
replace: jest.fn(),
prefetch: jest.fn(),
back: jest.fn(),
forward: jest.fn(),
refresh: jest.fn(),
}),
useSearchParams: () => ({
get: jest.fn(),
}),
usePathname: () => '',
}))
// Mock framer-motion to avoid animation issues in tests
jest.mock('framer-motion', () => ({
motion: {
div: 'div',
button: 'button',
span: 'span',
p: 'p',
h1: 'h1',
h2: 'h2',
h3: 'h3',
},
AnimatePresence: ({ children }) => children,
}))
// Mock next-themes
jest.mock('next-themes', () => ({
useTheme: () => ({
theme: 'light',
setTheme: jest.fn(),
systemTheme: 'light',
themes: ['light', 'dark'],
}),
ThemeProvider: ({ children }) => children,
}))
// Mock CodeHighlighter to avoid react-syntax-highlighter issues
jest.mock('@/components/ui/code-highlighter', () => ({
CodeHighlighter: ({ code, title, explanation }) => (
<div data-testid="code-highlighter">
{title && <div data-testid="code-title">{title}</div>}
<pre data-testid="code-content">{code}</pre>
{explanation && <div data-testid="code-explanation">{explanation}</div>}
</div>
),
}))
// Setup global test utilities
global.ResizeObserver = jest.fn().mockImplementation(() => ({
observe: jest.fn(),
unobserve: jest.fn(),
disconnect: jest.fn(),
}))
// Mock window.matchMedia
Object.defineProperty(window, 'matchMedia', {
writable: true,
value: jest.fn().mockImplementation(query => ({
matches: false,
media: query,
onchange: null,
addListener: jest.fn(), // deprecated
removeListener: jest.fn(), // deprecated
addEventListener: jest.fn(),
removeEventListener: jest.fn(),
dispatchEvent: jest.fn(),
})),
})