/* eslint no-restricted-globals: ["error", { "name": "jest", "message": "jest is not available in Storybook." }] */ /** * Test stubs to mirror available global variables in Jest tests * and Storybook, avoid using the jest global as this is not * available in Storybook. * Those variables usually come from the back-end via templates. * See /wagtailadmin/templates/wagtailadmin/admin_base.html. */ const wagtailConfig = { ADMIN_API: { DOCUMENTS: '/admin/api/main/documents/', IMAGES: '/admin/api/main/images/', PAGES: '/admin/api/main/pages/', EXTRA_CHILDREN_PARAMETERS: '', }, ADMIN_URLS: { PAGES: '/admin/pages/', }, CSRF_HEADER_NAME: 'x-xsrf-token', CSRF_TOKEN: 'potato', DATE_FORMATTING: { DATE_FORMAT: 'MMM. D, YYYY', SHORT_DATE_FORMAT: 'DD/MM/YYYY', }, WAGTAIL_I18N_ENABLED: true, LOCALES: [ { code: 'en', display_name: 'English', }, { code: 'fr', display_name: 'French', }, ], ACTIVE_CONTENT_LOCALE: 'en', }; const configScript = Object.assign(document.createElement('script'), { id: 'wagtail-config', textContent: JSON.stringify(wagtailConfig), type: 'application/json', }); document.body.appendChild(configScript); global.wagtail = {}; /* use dummy content for onload handlers just so that we can verify that we've chosen the right one */ global.IMAGE_CHOOSER_MODAL_ONLOAD_HANDLERS = { type: 'image' }; global.PAGE_CHOOSER_MODAL_ONLOAD_HANDLERS = { type: 'page' }; global.EMBED_CHOOSER_MODAL_ONLOAD_HANDLERS = { type: 'embed' }; global.DOCUMENT_CHOOSER_MODAL_ONLOAD_HANDLERS = { type: 'document' }; class PageChooserModal {} global.PageChooserModal = PageChooserModal; /** Mock window.scrollTo as not provided via JSDom */ window.scrollTo = () => {}; /** Mock console.warn to filter out warnings from React due to Draftail legacy Component API usage. * Draftail/Draft-js is unlikely to support these and the warnings are not useful for unit test output. */ /* eslint-disable no-console */ const consoleWarnOriginal = console.warn; console.warn = function filterWarnings(...args) { /* eslint-enable no-console */ const [warning, component] = args; const legacyReactWarnings = [ 'Warning: componentWillMount has been renamed, and is not recommended for use.', 'Warning: componentWillReceiveProps has been renamed, and is not recommended for use.', 'Warning: componentWillUpdate has been renamed, and is not recommended for use.', ]; const ignoredComponents = ['DraftEditor', 'PluginEditor']; if ( legacyReactWarnings.some((_) => warning.includes(_)) && ignoredComponents.includes(component) ) { return; } consoleWarnOriginal.apply(console, args); };