2018-05-18 06:30:17 +00:00
|
|
|
// Vue.config.silent = true
|
2018-05-17 02:40:50 +00:00
|
|
|
|
2018-05-13 15:11:51 +00:00
|
|
|
/* eslint-disable global-require */
|
|
|
|
if (typeof window !== 'undefined') {
|
|
|
|
global.window.resizeTo = (width, height) => {
|
2019-01-12 03:33:27 +00:00
|
|
|
global.window.innerWidth = width || global.window.innerWidth;
|
|
|
|
global.window.innerHeight = height || global.window.innerHeight;
|
|
|
|
global.window.dispatchEvent(new Event('resize'));
|
|
|
|
};
|
|
|
|
global.window.scrollTo = () => {};
|
2020-08-30 14:23:36 +00:00
|
|
|
if (!window.matchMedia) {
|
|
|
|
Object.defineProperty(global.window, 'matchMedia', {
|
|
|
|
value: jest.fn(query => ({
|
|
|
|
matches: query.includes('max-width'),
|
|
|
|
addListener: jest.fn(),
|
|
|
|
removeListener: jest.fn(),
|
|
|
|
})),
|
|
|
|
});
|
|
|
|
}
|
2018-05-13 15:11:51 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
// The built-in requestAnimationFrame and cancelAnimationFrame not working with jest.runFakeTimes()
|
|
|
|
// https://github.com/facebook/jest/issues/5147
|
2019-01-12 03:33:27 +00:00
|
|
|
global.requestAnimationFrame = function(cb) {
|
|
|
|
return setTimeout(cb, 0);
|
|
|
|
};
|
2018-05-13 15:11:51 +00:00
|
|
|
|
2019-01-12 03:33:27 +00:00
|
|
|
global.cancelAnimationFrame = function(cb) {
|
|
|
|
return clearTimeout(cb, 0);
|
|
|
|
};
|
2018-05-13 15:11:51 +00:00
|
|
|
|
2019-01-12 03:33:27 +00:00
|
|
|
const mockMath = Object.create(global.Math);
|
|
|
|
mockMath.random = () => 0.5;
|
|
|
|
global.Math = mockMath;
|