// Vue.config.silent = true /* 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(), })), }); } } // 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; // Vue.component('transition-group', { // props: ['tag'], // render(createElement) { // return createElement(this.tag || 'div', null, this.$slots.default); // }, // }); // Vue.prototype.$emit = function() { // const vm = this; // const args = [].slice.call(arguments, 0); // const filterEvent = []; // const eventName = args[0]; // if (args.length && vm.$listeners[eventName]) { // if (filterEvent.includes(eventName)) { // vm.$emit(eventName, ...args.slice(1)); // } else { // vm.$listeners[eventName](...args.slice(1)); // } // } // };