forked from ant-design/ant-design
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathindex.test.ts
101 lines (84 loc) · 3.61 KB
/
index.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
import pkg from '../package.json';
const testDist = process.env.LIB_DIR === 'dist';
type AnyStyleObject = Record<PropertyKey, string | number>;
describe('antd dist files', () => {
// https://github.com/ant-design/ant-design/issues/1638
// https://github.com/ant-design/ant-design/issues/1968
it('exports modules correctly', () => {
// eslint-disable-next-line global-require,import/no-unresolved
const antd = testDist ? require('../dist/antd') : require('../components');
expect(Object.keys(antd)).toMatchSnapshot();
});
// https://github.com/ant-design/ant-design/issues/1970
// https://github.com/ant-design/ant-design/issues/1804
if (testDist) {
it('antd.js should export version', () => {
// eslint-disable-next-line global-require,import/no-unresolved
const antd = require('../dist/antd');
expect(antd).toBeTruthy();
expect(antd.version).toBe(pkg.version);
});
it('antd.min.js should export version', () => {
// eslint-disable-next-line global-require,import/no-unresolved
const antd = require('../dist/antd.min');
expect(antd).toBeTruthy();
expect(antd.version).toBe(pkg.version);
});
/* eslint-disable global-require,import/no-unresolved */
const defaultTheme = require('../dist/default-theme');
const darkTheme = require('../dist/dark-theme');
const compactTheme = require('../dist/compact-theme');
const { getThemeVariables } = require('../dist/theme');
/* eslint-enable global-require,import/no-unresolved */
const expectThemeWithoutDark = (theme: AnyStyleObject) => {
expect(theme['blue-3']).toBe("color(~`colorPalette('@{blue-6}', 3) `)");
expect(theme['body-background']).toBe('#fff');
};
const expectDarkTheme = (theme: AnyStyleObject) => {
expect(theme['blue-3']).toBe('mix(@blue-base, @component-background, 30%)');
expect(theme['body-background']).toBe('@black');
};
const expectThemeWithoutCompact = (theme: AnyStyleObject) => {
expect(theme['padding-lg']).toBe('24px');
expect(theme['padding-md']).toBe('16px');
};
const expectCompactTheme = (theme: AnyStyleObject) => {
expect(theme['padding-lg']).toBe('16px');
expect(theme['padding-md']).toBe('8px');
};
describe('theme variables', () => {
it('should be get default theme', () => {
expectThemeWithoutDark(defaultTheme);
expectThemeWithoutCompact(defaultTheme);
});
it('should be get dark theme', () => {
expectDarkTheme(darkTheme);
expectThemeWithoutCompact(darkTheme);
});
it('should be get compact theme', () => {
expectCompactTheme(compactTheme);
expectThemeWithoutDark(compactTheme);
});
it('shoule get default variables by getThemeVariables()', () => {
const theme = getThemeVariables();
expectThemeWithoutCompact(theme);
expectThemeWithoutDark(theme);
});
it('shoule get dark variables by getThemeVariables({ dark: true })', () => {
const theme = getThemeVariables({ dark: true });
expectDarkTheme(theme);
expectThemeWithoutCompact(theme);
});
it('shoule get compact variables by getThemeVariables({ compact: true })', () => {
const theme = getThemeVariables({ compact: true });
expectThemeWithoutDark(theme);
expectCompactTheme(theme);
});
it('shoule get compact&dark variables by getThemeVariables({ compact: true, dark: true })', () => {
const theme = getThemeVariables({ compact: true, dark: true });
expectDarkTheme(theme);
expectCompactTheme(theme);
});
});
}
});