import Vue from 'vue'; // 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 = () => {}; } // 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)); } } };