/* * ============LICENSE_START======================================================= * Copyright (C) 2022 Nordix Foundation. * ================================================================================ * Licensed 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. * * SPDX-License-Identifier: Apache-2.0 * ============LICENSE_END========================================================= * * */ import {mount, shallow} from "enzyme"; import React from "react"; import toJson from "enzyme-to-json"; import InstantiationManagementModal from "./InstantiationManagementModal"; import {act} from "react-dom/test-utils"; import {createMemoryHistory} from "history"; import ACMService from "../../../api/ACMService"; import acmLoopList from "./testFiles/acmList.json"; import {BrowserRouter} from "react-router-dom"; const logSpy = jest.spyOn(console, 'log') const history = createMemoryHistory(); describe('Verify Instantiation Management', () => { const flushPromises = () => new Promise(setImmediate); beforeEach(() => { logSpy.mockClear(); }); it("renders without crashing", () => { shallow(); }); it("renders correctly", () => { const tree = shallow(); expect(toJson(tree)).toMatchSnapshot(); }); it('should have a close Button element', () => { const container = shallow(); const button = container.find('[variant="secondary"]').at(2); expect(button.text()).toEqual("Close"); }); it('should have a Create Instance Button element', () => { const container = shallow(); const button = container.find('[variant="primary"]').at(0); expect(button.text()).toEqual("Create Instance"); }); it('should have a Monitor Instantiations Button element', () => { const container = shallow(); const button = container.find('[variant="secondary"]').at(0); expect(button.text()).toEqual("Monitor Instantiations"); }); it('handleClose called when bottom button clicked', () => { const container = shallow(); const button = container.find('[variant="secondary"]').at(2); act(() => { button.simulate('click'); expect(logSpy).toHaveBeenCalledWith('handleClose called'); }); }); it('handleClose called when top-right button clicked', () => { const container = shallow(); act(() => { container.find('[size="xl"]').get(0).props.onHide(); expect(logSpy).toHaveBeenCalledWith('handleClose called'); }); }); it('clearErrors called when clear error message button clicked', () => { const container = shallow(); const button = container.find('[variant="secondary"]').at(1); act(() => { button.simulate('click'); expect(logSpy).toHaveBeenCalledWith('clearErrors called'); }); }); it('Check useEffect is being called', async () => { jest.resetAllMocks(); jest.spyOn(ACMService, 'getACMInstantiation') .mockImplementationOnce(async () => { return Promise.resolve({ ok: true, status: 200, text: () => "OK", json: () => { return Promise.resolve(acmLoopList); } }); }); const component = mount( ); const useEffect = jest.spyOn(React, "useEffect"); await act(async () => { await flushPromises() component.update(); await expect(useEffect).toHaveBeenCalled(); }); component.unmount(); }); it('set state gets called for setInstantiationList useEffect on success', async () => { const setInstantiationList = jest.fn(); const setDeleteInstantiation = true; const history = createMemoryHistory(); jest .spyOn(global, 'fetch') .mockImplementation(() => Promise.resolve({ ok: true, status: 200, text: () => "OK", json: () => acmLoopList }) ) mount( ); act(async () => { expect(setInstantiationList).toHaveBeenCalledTimes(1); expect(setDeleteInstantiation).toHaveBeenCalledTimes(1); }); }); });