Step 8.2: Fix wiring of jest test setup to avoid import cycle issues
This commit is contained in:
parent
a987ead7d2
commit
8d2dba4102
4 changed files with 106 additions and 46 deletions
|
@ -1,53 +1,17 @@
|
|||
import { TextEncoder, TextDecoder } from 'util';
|
||||
import Adapter from "@wojtekmaj/enzyme-adapter-react-17";
|
||||
import { configure } from "enzyme";
|
||||
import "blob-polyfill"; // https://github.com/jsdom/jsdom/issues/2555
|
||||
|
||||
import * as languageHandler from "../src/languageHandler";
|
||||
import SdkConfig, { DEFAULTS } from '../src/SdkConfig';
|
||||
|
||||
languageHandler.setLanguage('en');
|
||||
languageHandler.setMissingEntryGenerator(key => key.split("|", 2)[1]);
|
||||
|
||||
// uninitialised SdkConfig causes lots of warnings in console
|
||||
// init with defaults
|
||||
SdkConfig.put(DEFAULTS);
|
||||
|
||||
// Enable the jest & enzyme mocks
|
||||
require('jest-fetch-mock').enableMocks();
|
||||
|
||||
// jest 27 removes setImmediate from jsdom
|
||||
// polyfill until setImmediate use in client can be removed
|
||||
global.setImmediate = callback => setTimeout(callback, 0);
|
||||
|
||||
// Stub ResizeObserver
|
||||
class ResizeObserver {
|
||||
observe() {} // do nothing
|
||||
unobserve() {} // do nothing
|
||||
disconnect() {} // do nothing
|
||||
}
|
||||
window.ResizeObserver = ResizeObserver;
|
||||
|
||||
// polyfilling TextEncoder as it is not available on JSDOM
|
||||
// view https://github.com/facebook/jest/issues/9983
|
||||
global.TextEncoder = TextEncoder;
|
||||
global.TextDecoder = TextDecoder;
|
||||
|
||||
configure({ adapter: new Adapter() });
|
||||
|
||||
// maplibre requires a createObjectURL mock
|
||||
global.URL.createObjectURL = jest.fn();
|
||||
|
||||
// matchMedia is not included in jsdom
|
||||
const mockMatchMedia = jest.fn().mockImplementation(query => ({
|
||||
matches: false,
|
||||
media: query,
|
||||
onchange: null,
|
||||
addListener: jest.fn(), // Deprecated
|
||||
removeListener: jest.fn(), // Deprecated
|
||||
addEventListener: jest.fn(),
|
||||
removeEventListener: jest.fn(),
|
||||
dispatchEvent: jest.fn(),
|
||||
}));
|
||||
global.matchMedia = mockMatchMedia;
|
||||
|
||||
window.HTMLElement.prototype.scrollIntoView = jest.fn();
|
||||
// Very carefully enable the mocks for everything else in
|
||||
// a specific order. We use this order to ensure we properly
|
||||
// establish an application state that actually works.
|
||||
//
|
||||
// These are also require() calls to make sure they get called
|
||||
// synchronously.
|
||||
require("./setup/setupManualMocks"); // must be first
|
||||
require("./setup/setupLanguage");
|
||||
require("./setup/setupConfig");
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue