2022-09-09 15:51:35 +08:00
|
|
|
import glob from 'glob';
|
|
|
|
import * as React from 'react';
|
|
|
|
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;
|
|
|
|
}
|
|
|
|
|
|
|
|
return fakeDemoTest;
|
|
|
|
});
|
|
|
|
|
|
|
|
describe('node', () => {
|
|
|
|
beforeAll(() => {
|
|
|
|
jest.useFakeTimers().setSystemTime(new Date('2016-11-22'));
|
|
|
|
});
|
|
|
|
|
|
|
|
// Find the component exist demo test file
|
|
|
|
const files = glob.sync(`./components/*/__tests__/demo.test.@(j|t)s?(x)`);
|
|
|
|
|
|
|
|
files.forEach(componentTestFile => {
|
|
|
|
const componentName = componentTestFile.match(/components\/([^/]*)\//)![1];
|
|
|
|
|
|
|
|
// Test for ssr
|
|
|
|
describe(componentName, () => {
|
2022-11-09 12:28:04 +08:00
|
|
|
const demoList = glob.sync(`./components/${componentName}/demo/*.tsx`);
|
2022-09-09 15:51:35 +08:00
|
|
|
|
|
|
|
// Use mock to get config
|
|
|
|
require(`../../${componentTestFile}`); // eslint-disable-line global-require, import/no-dynamic-require
|
|
|
|
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; // eslint-disable-line global-require, import/no-dynamic-require
|
|
|
|
expect(() => {
|
|
|
|
renderToString(<Demo />);
|
|
|
|
}).not.toThrow();
|
|
|
|
});
|
|
|
|
});
|
|
|
|
});
|
|
|
|
});
|
|
|
|
});
|