import nock from 'nock'; import Enzyme from 'enzyme'; import Adapter from 'enzyme-adapter-react-16'; import log from 'loglevel'; import { JSDOM } from 'jsdom'; process.env.IN_TEST = true; global.chrome = { runtime: { id: 'testid', getManifest: () => ({ manifest_version: 2 }) }, }; nock.disableNetConnect(); nock.enableNetConnect('localhost'); // catch rejections that are still unhandled when tests exit const unhandledRejections = new Map(); process.on('unhandledRejection', (reason, promise) => { console.log('Unhandled rejection:', reason); unhandledRejections.set(promise, reason); }); process.on('rejectionHandled', (promise) => { console.log(`handled: ${unhandledRejections.get(promise)}`); unhandledRejections.delete(promise); }); process.on('exit', () => { if (unhandledRejections.size > 0) { console.error(`Found ${unhandledRejections.size} unhandled rejections:`); for (const reason of unhandledRejections.values()) { console.error('Unhandled rejection: ', reason); } process.exit(1); } }); Enzyme.configure({ adapter: new Adapter() }); log.setDefaultLevel(5); global.log = log; // // polyfills // // dom const jsdom = new JSDOM(); global.window = jsdom.window; // required by `trezor-connect/node_modules/whatwg-fetch` global.self = window; // required by `dom-helpers` and various other libraries global.document = window.document; // required by `react-tippy` global.navigator = window.navigator; global.Element = window.Element; // required by `react-popper` global.HTMLElement = window.HTMLElement; // Jest no longer adds the following timers so we use set/clear Timeouts global.setImmediate = global.setImmediate || ((fn, ...args) => global.setTimeout(fn, 0, ...args)); global.clearImmediate = global.clearImmediate || ((id) => global.clearTimeout(id)); // required by any components anchored on `popover-content` const popoverContent = window.document.createElement('div'); popoverContent.setAttribute('id', 'popover-content'); window.document.body.appendChild(popoverContent); // fetch // fetch is part of node js in future versions, thus triggering no-shadow // eslint-disable-next-line no-shadow const fetch = require('node-fetch'); const { Headers, Request, Response } = fetch; Object.assign(window, { fetch, Headers, Request, Response }); // localStorage window.localStorage = { removeItem: () => null, }; // used for native dark/light mode detection window.matchMedia = () => true; // override @metamask/logo window.requestAnimationFrame = () => undefined; // crypto.getRandomValues if (!window.crypto) { window.crypto = {}; } if (!window.crypto.getRandomValues) { // eslint-disable-next-line node/global-require window.crypto.getRandomValues = require('polyfill-crypto.getrandomvalues'); } // Used to test `clearClipboard` function if (!window.navigator.clipboard) { window.navigator.clipboard = {}; } if (!window.navigator.clipboard.writeText) { window.navigator.clipboard.writeText = () => undefined; }