mirror of
https://github.com/ant-design/ant-design.git
synced 2025-01-18 14:13:37 +08:00
c6c0662b97
* docs: Cascader displayRender data * ts: clean up * test: Update rc-resize-observer version * test: fix resize related test case * chore: fix ts error * test: Fix resize logic
63 lines
2.3 KiB
JavaScript
63 lines
2.3 KiB
JavaScript
const React = require('react');
|
|
const { _rs: onLibResize } = require('rc-resize-observer/lib/utils/observerUtil');
|
|
const { _rs: onEsResize } = require('rc-resize-observer/es/utils/observerUtil');
|
|
|
|
// eslint-disable-next-line no-console
|
|
console.log('Current React Version:', React.version);
|
|
|
|
// jest.mock('react', () => ({
|
|
// ...jest.requireActual('react'),
|
|
// useLayoutEffect: jest.requireActual('react').useEffect,
|
|
// }));
|
|
|
|
/* eslint-disable global-require */
|
|
if (typeof window !== 'undefined') {
|
|
global.window.resizeTo = (width, height) => {
|
|
global.window.innerWidth = width || global.window.innerWidth;
|
|
global.window.innerHeight = height || global.window.innerHeight;
|
|
global.window.dispatchEvent(new Event('resize'));
|
|
};
|
|
global.window.scrollTo = () => {};
|
|
// ref: https://github.com/ant-design/ant-design/issues/18774
|
|
if (!window.matchMedia) {
|
|
Object.defineProperty(global.window, 'matchMedia', {
|
|
value: jest.fn(query => ({
|
|
matches: query.includes('max-width'),
|
|
addListener: jest.fn(),
|
|
removeListener: jest.fn(),
|
|
})),
|
|
});
|
|
}
|
|
|
|
// Fix css-animation or rc-motion deps on these
|
|
// https://github.com/react-component/motion/blob/9c04ef1a210a4f3246c9becba6e33ea945e00669/src/util/motion.ts#L27-L35
|
|
// https://github.com/yiminghe/css-animation/blob/a5986d73fd7dfce75665337f39b91483d63a4c8c/src/Event.js#L44
|
|
window.AnimationEvent = window.AnimationEvent || (() => {});
|
|
window.TransitionEvent = window.TransitionEvent || (() => {});
|
|
}
|
|
|
|
const Enzyme = require('enzyme');
|
|
|
|
const Adapter =
|
|
process.env.REACT === '16'
|
|
? require('enzyme-adapter-react-16') // eslint-disable-line import/no-extraneous-dependencies,import/no-unresolved
|
|
: require('@wojtekmaj/enzyme-adapter-react-17');
|
|
|
|
Enzyme.configure({ adapter: new Adapter() });
|
|
|
|
Object.assign(Enzyme.ReactWrapper.prototype, {
|
|
findObserver(index = 0) {
|
|
return this.find('ResizeObserver').at(index);
|
|
},
|
|
triggerResize(index = 0) {
|
|
const target = this.findObserver(index).getDOMNode();
|
|
const originGetBoundingClientRect = target.getBoundingClientRect;
|
|
|
|
target.getBoundingClientRect = () => ({ width: 510, height: 903 });
|
|
onLibResize([{ target }]);
|
|
onEsResize([{ target }]);
|
|
|
|
target.getBoundingClientRect = originGetBoundingClientRect;
|
|
},
|
|
});
|