mirror of
https://github.com/ant-design/ant-design.git
synced 2024-12-21 13:18:04 +08:00
863f61d908
Co-authored-by: afc163 <afc163@gmail.com>
54 lines
1.5 KiB
TypeScript
54 lines
1.5 KiB
TypeScript
import * as React from 'react';
|
|
import { globSync } from 'glob';
|
|
import { renderToString } from 'react-dom/server';
|
|
|
|
import type { Options } from '../../tests/shared/demoTest';
|
|
|
|
(global as any).testConfig = {};
|
|
|
|
jest.mock('../../tests/shared/demoTest', () => {
|
|
function fakeDemoTest(name: string, option: Options = {}) {
|
|
(global as any).testConfig[name] = option;
|
|
}
|
|
|
|
fakeDemoTest.rootPropsTest = () => {};
|
|
|
|
return fakeDemoTest;
|
|
});
|
|
|
|
describe('node', () => {
|
|
beforeAll(() => {
|
|
jest.useFakeTimers().setSystemTime(new Date('2016-11-22'));
|
|
});
|
|
|
|
// Find the component exist demo test file
|
|
const files = globSync(`./components/*/__tests__/demo.test.@(j|t)s?(x)`);
|
|
|
|
files.forEach((componentTestFile) => {
|
|
const componentName = componentTestFile.match(/components\/([^/]*)\//)![1];
|
|
|
|
// Test for ssr
|
|
describe(componentName, () => {
|
|
const demoList = globSync(`./components/${componentName}/demo/*.tsx`).filter(
|
|
(file) => !file.includes('_semantic'),
|
|
);
|
|
|
|
// Use mock to get config
|
|
require(`../../${componentTestFile}`);
|
|
const option = (global as any).testConfig?.[componentName];
|
|
|
|
demoList.forEach((demoFile) => {
|
|
const skip: string[] = option?.skip || [];
|
|
const test = skip.some((skipMarkdown) => demoFile.includes(skipMarkdown)) ? it.skip : it;
|
|
|
|
test(demoFile, () => {
|
|
const Demo = require(`../../${demoFile}`).default;
|
|
expect(() => {
|
|
renderToString(<Demo />);
|
|
}).not.toThrow();
|
|
});
|
|
});
|
|
});
|
|
});
|
|
});
|