import * as React from 'react';
import { fixtures } from '@strapi/admin-test-utils';
import { DesignSystemProvider } from '@strapi/design-system';
import { RBACContext, NotificationsProvider } from '@strapi/helper-plugin';
import {
  renderHook as renderHookRTL,
  render as renderRTL,
  waitFor,
  act,
  fireEvent,
  screen,
} from '@testing-library/react';
import userEvent from '@testing-library/user-event';
import PropTypes from 'prop-types';
import { IntlProvider } from 'react-intl';
import { QueryClient, QueryClientProvider } from 'react-query';
import { MemoryRouter } from 'react-router-dom';
import { server } from './server';
const Providers = ({ children, initialEntries }) => {
  const rbacContextValue = React.useMemo(
    () => ({
      allPermissions: fixtures.permissions.allPermissions,
    }),
    []
  );
  const queryClient = new QueryClient({
    defaultOptions: {
      queries: {
        retry: false,
        // no more errors on the console for tests
        onError() {},
      },
    },
  });
  return (
    // en is the default locale of the admin app.
    
      
        
          
            
              {children}
            
          
        
      
    
  );
};
Providers.defaultProps = {
  initialEntries: undefined,
};
Providers.propTypes = {
  children: PropTypes.node.isRequired,
  initialEntries: PropTypes.arrayOf(PropTypes.oneOfType([PropTypes.string, PropTypes.object])),
};
// eslint-disable-next-line react/jsx-no-useless-fragment
const fallbackWrapper = ({ children }) => <>{children}>;
const render = (ui, { renderOptions, userEventOptions, initialEntries } = {}) => {
  const { wrapper: Wrapper = fallbackWrapper, ...restOptions } = renderOptions ?? {};
  return {
    ...renderRTL(ui, {
      wrapper: ({ children }) => (
        
          {children}
        
      ),
      ...restOptions,
    }),
    user: userEvent.setup(userEventOptions),
  };
};
const renderHook = (hook, options) => {
  const { wrapper: Wrapper = fallbackWrapper, ...restOptions } = options ?? {};
  return renderHookRTL(hook, {
    wrapper: ({ children }) => (
      
        {children}
      
    ),
    ...restOptions,
  });
};
export { render, renderHook, waitFor, server, act, fireEvent, screen };