import React from 'react'; import sinon from 'sinon'; import { mount } from 'enzyme'; import ConfirmDeleteNetwork from './confirm-delete-network.container'; describe('Confirm Delete Network', () => { let wrapper; const props = { hideModal: sinon.spy(), delRpcTarget: sinon.stub().resolves(), onConfirm: sinon.spy(), target: '', }; beforeEach(() => { wrapper = mount(, { context: { t: (str) => str, }, }); }); afterEach(() => { props.hideModal.resetHistory(); props.delRpcTarget.resetHistory(); props.onConfirm.resetHistory(); }); it('renders delete network modal title', () => { const modalTitle = wrapper.find('.modal-content__title'); expect(modalTitle.text()).toStrictEqual('deleteNetwork'); }); it('clicks cancel to hide modal', () => { const cancelButton = wrapper.find( '.button.btn-secondary.modal-container__footer-button', ); cancelButton.simulate('click'); expect(props.hideModal.calledOnce).toStrictEqual(true); }); it('clicks delete to delete the target and hides modal', async () => { const deleteButton = wrapper.find( '.button.btn-danger-primary.modal-container__footer-button', ); deleteButton.simulate('click'); expect(await props.delRpcTarget.calledOnce).toStrictEqual(true); expect(props.hideModal.calledOnce).toStrictEqual(true); expect(props.onConfirm.calledOnce).toStrictEqual(true); }); });