-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathjest.setup.js
More file actions
101 lines (90 loc) · 2.22 KB
/
Copy pathjest.setup.js
File metadata and controls
101 lines (90 loc) · 2.22 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
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
// Learn more: https://github.com/testing-library/jest-dom
import '@testing-library/jest-dom';
// Polyfill for Request and Response in test environment
if (typeof global.Request === 'undefined') {
global.Request = class Request {
constructor(input, init) {
this.url = typeof input === 'string' ? input : input.url;
this.method = init?.method || 'GET';
this.headers = init?.headers || {};
this._body = init?.body;
}
async json() {
return JSON.parse(this._body);
}
async text() {
return this._body;
}
};
}
if (typeof global.Response === 'undefined') {
global.Response = class Response {
constructor(body, init) {
this.body = body;
this.status = init?.status || 200;
this.headers = init?.headers || {};
this._bodyText = typeof body === 'string' ? body : JSON.stringify(body);
}
async json() {
return JSON.parse(this._bodyText);
}
async text() {
return this._bodyText;
}
};
}
// Mock Next.js router
jest.mock('next/navigation', () => ({
useRouter() {
return {
push: jest.fn(),
replace: jest.fn(),
prefetch: jest.fn(),
back: jest.fn(),
pathname: '/',
query: {},
asPath: '/'
};
},
usePathname() {
return '/';
},
useSearchParams() {
return new URLSearchParams();
}
}));
// Mock Next.js Image component
jest.mock('next/image', () => ({
__esModule: true,
default: (props) => {
// eslint-disable-next-line @next/next/no-img-element, jsx-a11y/alt-text
return <img {...props} />;
}
}));
// Mock next-themes
jest.mock('next-themes', () => ({
useTheme: () => ({
theme: 'light',
setTheme: jest.fn(),
themes: ['light', 'dark', 'cyberpunk']
}),
ThemeProvider: ({ children }) => children
}));
// Suppress console errors in tests
const originalError = console.error;
beforeAll(() => {
console.error = (...args) => {
if (
typeof args[0] === 'string' &&
(args[0].includes('Warning:') ||
args[0].includes('Error:') ||
args[0].includes('Not implemented: HTMLFormElement.prototype.submit'))
) {
return;
}
originalError.call(console, ...args);
};
});
afterAll(() => {
console.error = originalError;
});