forked from coinbase/onchainkit
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathuseTheme.test.ts
109 lines (98 loc) · 3.71 KB
/
useTheme.test.ts
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
import { renderHook } from '@testing-library/react';
import { type Mock, afterEach, describe, expect, it, vi } from 'vitest';
import { usePreferredColorScheme } from './internal/hooks/usePreferredColorScheme';
import type { UseThemeReact } from './types';
import { useOnchainKit } from './useOnchainKit';
import { useTheme } from './useTheme';
vi.mock('./useOnchainKit');
vi.mock('./internal/hooks/usePreferredColorScheme');
describe('useTheme', () => {
afterEach(() => {
vi.restoreAllMocks();
});
const mockUseOnchainKit = (theme?: string, mode?: string) => {
(useOnchainKit as Mock).mockReturnValue({
config: {
appearance: { theme, mode },
},
});
};
const mockUsePreferredColorScheme = (preferredMode: 'light' | 'dark') => {
(usePreferredColorScheme as Mock).mockReturnValue(preferredMode);
};
it.each([
['cyberpunk', 'auto', 'light', 'cyberpunk'],
['base', 'dark', 'dark', 'base'],
['hacker', 'light', 'light', 'hacker'],
] as const)(
'should return %s theme when set, regardless of mode or system preference',
(theme, mode, preferredMode, expected) => {
mockUseOnchainKit(theme, mode);
mockUsePreferredColorScheme(preferredMode);
const { result } = renderHook(() => useTheme());
expect(result.current).toBe(expected);
},
);
it.each([
['default', 'auto', 'light', 'default-light'],
['default', 'auto', 'dark', 'default-dark'],
['default', 'light', 'dark', 'default-light'],
['default', 'dark', 'light', 'default-dark'],
['custom', 'auto', 'light', 'custom-light'],
['custom', 'auto', 'dark', 'custom-dark'],
] as const)(
'should return %s when theme is %s, mode is %s, and preferred mode is %s',
(theme, mode, preferredMode, expected) => {
mockUseOnchainKit(theme, mode);
mockUsePreferredColorScheme(preferredMode);
const { result } = renderHook(() => useTheme());
expect(result.current).toBe(expected);
},
);
it.each([
['default', undefined, 'light', 'default-light'],
['default', undefined, 'dark', 'default-dark'],
['custom', undefined, 'light', 'custom-light'],
['custom', undefined, 'dark', 'custom-dark'],
] as const)(
'should fallback to preferred mode when theme is %s and mode is undefined',
(theme, mode, preferredMode, expected) => {
mockUseOnchainKit(theme, mode);
mockUsePreferredColorScheme(preferredMode);
const { result } = renderHook(() => useTheme());
expect(result.current).toBe(expected);
},
);
it('should handle undefined appearance gracefully', () => {
(useOnchainKit as Mock).mockReturnValue({});
mockUsePreferredColorScheme('light');
const { result } = renderHook(() => useTheme());
expect(result.current).toBe('default-light');
});
it('should handle invalid mode gracefully', () => {
mockUseOnchainKit('default', 'invalid' as 'light' | 'dark' | 'auto');
mockUsePreferredColorScheme('light');
const { result } = renderHook(() => useTheme());
expect(result.current).toBe('default-light');
});
it('should handle all possible return types of UseThemeReact', () => {
const allThemes: UseThemeReact[] = [
'cyberpunk',
'base',
'hacker',
'default-light',
'default-dark',
];
for (const theme of allThemes) {
if (theme === 'cyberpunk' || theme === 'base' || theme === 'hacker') {
mockUseOnchainKit(theme, 'auto');
} else {
const [baseTheme, mode] = theme.split('-');
mockUseOnchainKit(baseTheme, mode as 'light' | 'dark');
}
mockUsePreferredColorScheme(theme.endsWith('dark') ? 'dark' : 'light');
const { result } = renderHook(() => useTheme());
expect(result.current).toBe(theme);
}
});
});