mirror of
https://github.com/apache/superset.git
synced 2024-09-18 03:29:38 -04:00
8437a235c9
Co-authored-by: Michael S. Molina <70410625+michael-s-molina@users.noreply.github.com>
123 lines
4.0 KiB
TypeScript
123 lines
4.0 KiB
TypeScript
/**
|
|
* Licensed to the Apache Software Foundation (ASF) under one
|
|
* or more contributor license agreements. See the NOTICE file
|
|
* distributed with this work for additional information
|
|
* regarding copyright ownership. The ASF licenses this file
|
|
* to you under the Apache License, Version 2.0 (the
|
|
* "License"); you may not use this file except in compliance
|
|
* with the License. You may obtain a copy of the License at
|
|
*
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
|
*
|
|
* Unless required by applicable law or agreed to in writing,
|
|
* software distributed under the License is distributed on an
|
|
* "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
|
|
* KIND, either express or implied. See the License for the
|
|
* specific language governing permissions and limitations
|
|
* under the License.
|
|
*/
|
|
import React from 'react';
|
|
import 'core-js/stable';
|
|
import 'regenerator-runtime/runtime';
|
|
import 'abortcontroller-polyfill/dist/abortcontroller-polyfill-only';
|
|
import 'jest-enzyme';
|
|
import jQuery from 'jquery';
|
|
import { configure } from 'enzyme';
|
|
import Adapter from 'enzyme-adapter-react-16';
|
|
// https://jestjs.io/docs/jest-object#jestmockmodulename-factory-options
|
|
// in order to mock modules in test case, so avoid absolute import module
|
|
import { configure as configureTranslation } from '../../packages/superset-ui-core/src/translation';
|
|
import { Worker } from './Worker';
|
|
import { IntersectionObserver } from './IntersectionObserver';
|
|
import { ResizeObserver } from './ResizeObserver';
|
|
import setupSupersetClient from './setupSupersetClient';
|
|
import CacheStorage from './CacheStorage';
|
|
|
|
configure({ adapter: new Adapter() });
|
|
|
|
const exposedProperties = ['window', 'navigator', 'document'];
|
|
|
|
const { defaultView } = document;
|
|
if (defaultView != null) {
|
|
Object.keys(defaultView).forEach(property => {
|
|
if (typeof global[property] === 'undefined') {
|
|
exposedProperties.push(property);
|
|
global[property] = defaultView[property];
|
|
}
|
|
});
|
|
}
|
|
|
|
const g = global as any;
|
|
g.window ??= Object.create(window);
|
|
g.window.location ??= { href: 'about:blank' };
|
|
g.window.performance ??= { now: () => new Date().getTime() };
|
|
g.window.Worker ??= Worker;
|
|
g.window.IntersectionObserver ??= IntersectionObserver;
|
|
g.window.ResizeObserver ??= ResizeObserver;
|
|
g.window.featureFlags ??= {};
|
|
g.URL.createObjectURL ??= () => '';
|
|
g.caches = new CacheStorage();
|
|
|
|
Object.defineProperty(window, 'matchMedia', {
|
|
writable: true,
|
|
value: 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(),
|
|
})),
|
|
});
|
|
|
|
g.$ = jQuery(g.window);
|
|
|
|
configureTranslation();
|
|
setupSupersetClient();
|
|
|
|
// The useTabId hook depends on BroadcastChannel. Jest has a memory leak problem when
|
|
// dealing with native modules. See https://chanind.github.io/javascript/2019/10/12/jest-tests-memory-leak.html
|
|
// and https://github.com/facebook/jest/issues/6814 for more information.
|
|
jest.mock('src/hooks/useTabId', () => ({
|
|
useTabId: () => 1,
|
|
}));
|
|
|
|
// Check https://github.com/remarkjs/react-markdown/issues/635
|
|
jest.mock('react-markdown', () => (props: any) => <>{props.children}</>);
|
|
jest.mock('rehype-sanitize', () => () => jest.fn());
|
|
jest.mock('rehype-raw', () => () => jest.fn());
|
|
|
|
// Mocks the Icon component due to its async nature
|
|
// Tests should override this when needed
|
|
jest.mock('src/components/Icons/Icon', () => ({
|
|
__esModule: true,
|
|
default: ({
|
|
fileName,
|
|
role,
|
|
'aria-label': ariaLabel,
|
|
...rest
|
|
}: {
|
|
fileName: string;
|
|
role: string;
|
|
'aria-label': React.AriaAttributes['aria-label'];
|
|
}) => (
|
|
<span
|
|
role={role ?? 'img'}
|
|
aria-label={ariaLabel || fileName.replace('_', '-')}
|
|
{...rest}
|
|
/>
|
|
),
|
|
StyledIcon: ({
|
|
role,
|
|
'aria-label': ariaLabel,
|
|
...rest
|
|
}: {
|
|
role: string;
|
|
'aria-label': React.AriaAttributes['aria-label'];
|
|
}) => <span role={role ?? 'img'} aria-label={ariaLabel} {...rest} />,
|
|
}));
|
|
|
|
process.env.WEBPACK_MODE = 'test';
|