/* * SPDX-License-Identifier: Apache-2.0 * * The OpenSearch Contributors require contributions made to * this file be licensed under the Apache-2.0 license or a * compatible open source license. * * Any modifications Copyright OpenSearch Contributors. See * GitHub history for details. */ /* * Licensed to Elasticsearch B.V. under one or more contributor * license agreements. See the NOTICE file distributed with * this work for additional information regarding copyright * ownership. Elasticsearch B.V. 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 { act } from 'react-dom/test-utils'; import { mount } from 'enzyme'; import { mountWithIntl } from 'test_utils/enzyme_helpers'; import { AppContainer } from './app_container'; import { Mounter, AppMountParameters, AppStatus } from '../types'; import { createMemoryHistory } from 'history'; import { ScopedHistory } from '../scoped_history'; describe('AppContainer', () => { const appId = 'someApp'; const setAppLeaveHandler = jest.fn(); const setAppActionMenu = jest.fn(); const setIsMounting = jest.fn(); beforeEach(() => { setAppLeaveHandler.mockClear(); setIsMounting.mockClear(); }); const flushPromises = async () => { await new Promise(async (resolve) => { setImmediate(() => resolve()); }); }; const createResolver = (): [Promise, () => void] => { let resolve: () => void | undefined; const promise = new Promise((r) => { resolve = r; }); return [promise, resolve!]; }; const createMounter = (promise: Promise): Mounter => ({ appBasePath: '/base-path', appRoute: '/some-route', unmountBeforeMounting: false, exactRoute: false, mount: async ({ element }: AppMountParameters) => { await promise; const container = document.createElement('div'); container.innerHTML = 'some-content'; element.appendChild(container); return () => container.remove(); }, }); it('should hide the "not found" page before mounting the route', async () => { const [waitPromise, resolvePromise] = createResolver(); const mounter = createMounter(waitPromise); const wrapper = mountWithIntl( // Create a history using the appPath as the current location new ScopedHistory(createMemoryHistory({ initialEntries: [appPath] }), appPath) } /> ); expect(wrapper.text()).toContain('Application Not Found'); wrapper.setProps({ appId, setAppLeaveHandler, mounter, appStatus: AppStatus.accessible, }); wrapper.update(); expect(wrapper.text()).toEqual(''); await act(async () => { resolvePromise(); await flushPromises(); wrapper.update(); }); expect(wrapper.text()).toContain('some-content'); }); it('should call setIsMounting while mounting', async () => { const [waitPromise, resolvePromise] = createResolver(); const mounter = createMounter(waitPromise); const wrapper = mount( // Create a history using the appPath as the current location new ScopedHistory(createMemoryHistory({ initialEntries: [appPath] }), appPath) } /> ); expect(setIsMounting).toHaveBeenCalledTimes(1); expect(setIsMounting).toHaveBeenLastCalledWith(true); await act(async () => { resolvePromise(); await flushPromises(); wrapper.update(); }); expect(setIsMounting).toHaveBeenCalledTimes(2); expect(setIsMounting).toHaveBeenLastCalledWith(false); }); it('should call setIsMounting(false) if mounting throws', async () => { const [waitPromise, resolvePromise] = createResolver(); const mounter = { appBasePath: '/base-path/some-route', appRoute: '/some-route', unmountBeforeMounting: false, exactRoute: false, mount: async ({ element }: AppMountParameters) => { await waitPromise; throw new Error(`Mounting failed!`); }, }; const wrapper = mount( // Create a history using the appPath as the current location new ScopedHistory(createMemoryHistory({ initialEntries: [appPath] }), appPath) } /> ); expect(setIsMounting).toHaveBeenCalledTimes(1); expect(setIsMounting).toHaveBeenLastCalledWith(true); // await expect( await act(async () => { resolvePromise(); await flushPromises(); wrapper.update(); }); // ).rejects.toThrow(); expect(setIsMounting).toHaveBeenCalledTimes(2); expect(setIsMounting).toHaveBeenLastCalledWith(false); }); });