import { config } from '@vue/test-utils'; config.global.stubs = { transition: false, 'transition-group': false, }; /* 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 = () => {}; if (!window.matchMedia) { Object.defineProperty(global.window, 'matchMedia', { value: jest.fn(query => ({ matches: query.includes('max-width'), addListener: jest.fn(), removeListener: jest.fn(), })), }); } } global.ResizeObserver = require('resize-observer-polyfill'); // The built-in requestAnimationFrame and cancelAnimationFrame not working with jest.runFakeTimes() // https://github.com/facebook/jest/issues/5147 global.requestAnimationFrame = function (cb) { return setTimeout(cb, 0); }; global.cancelAnimationFrame = function (cb) { return clearTimeout(cb, 0); }; const mockMath = Object.create(global.Math); mockMath.random = () => 0.5; global.Math = mockMath;