-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathjest.setup.js
110 lines (99 loc) · 2.16 KB
/
jest.setup.js
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
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
// Learn more: https://github.com/testing-library/jest-dom
import '@testing-library/jest-dom'
// Mock chrome API
global.chrome = {
storage: {
local: {
get: jest.fn(),
set: jest.fn(),
remove: jest.fn(),
clear: jest.fn()
},
sync: {
get: jest.fn(),
set: jest.fn(),
remove: jest.fn(),
clear: jest.fn()
}
},
runtime: {
id: 'test-extension-id',
getManifest: jest.fn(() => ({
version: '1.0.0'
})),
connect: jest.fn(),
sendMessage: jest.fn(),
onMessage: {
addListener: jest.fn(),
removeListener: jest.fn(),
hasListener: jest.fn()
},
onConnect: {
addListener: jest.fn(),
removeListener: jest.fn(),
hasListener: jest.fn()
}
}
}
// Mock window.crypto for UUID generation
Object.defineProperty(global, 'crypto', {
value: {
randomUUID: () => 'test-uuid'
}
})
// Mock IntersectionObserver
class IntersectionObserver {
constructor(callback, options) {}
observe() {}
unobserve() {}
disconnect() {}
}
Object.defineProperty(global, 'IntersectionObserver', {
value: IntersectionObserver
})
// Mock ResizeObserver
class ResizeObserver {
constructor(callback) {}
observe() {}
unobserve() {}
disconnect() {}
}
Object.defineProperty(global, 'ResizeObserver', {
value: ResizeObserver
})
// Mock fetch
global.fetch = 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(),
removeListener: jest.fn(),
addEventListener: jest.fn(),
removeEventListener: jest.fn(),
dispatchEvent: jest.fn(),
})),
})
// Suppress console errors during tests
const originalError = console.error
beforeAll(() => {
console.error = (...args) => {
if (
typeof args[0] === 'string' &&
args[0].includes('Warning: ReactDOM.render is no longer supported')
) {
return
}
originalError.call(console, ...args)
}
})
afterAll(() => {
console.error = originalError
})
// Clear all mocks after each test
afterEach(() => {
jest.clearAllMocks()
})