mirror of
https://github.com/shlinkio/shlink-web-client.git
synced 2025-01-10 10:17:28 +03:00
Created DuplicatedServerModal test
This commit is contained in:
parent
1f9356cc21
commit
053b38bee3
1 changed files with 56 additions and 0 deletions
56
test/servers/helpers/DuplicatedServerModal.test.tsx
Normal file
56
test/servers/helpers/DuplicatedServerModal.test.tsx
Normal file
|
@ -0,0 +1,56 @@
|
||||||
|
import { shallow, ShallowWrapper } from 'enzyme';
|
||||||
|
import { Mock } from 'ts-mockery';
|
||||||
|
import { Button } from 'reactstrap';
|
||||||
|
import { DuplicatedServerModal } from '../../../src/servers/helpers/DuplicatedServerModal';
|
||||||
|
import { ServerData } from '../../../src/servers/data';
|
||||||
|
|
||||||
|
describe('<DuplicatedServerModal />', () => {
|
||||||
|
const onDiscard = jest.fn();
|
||||||
|
const onSave = jest.fn();
|
||||||
|
let wrapper: ShallowWrapper;
|
||||||
|
const createWrapper = (serverData?: ServerData) => {
|
||||||
|
wrapper = shallow(
|
||||||
|
<DuplicatedServerModal
|
||||||
|
serverData={serverData}
|
||||||
|
isOpen={true}
|
||||||
|
toggle={jest.fn()}
|
||||||
|
onDiscard={onDiscard}
|
||||||
|
onSave={onSave}
|
||||||
|
/>,
|
||||||
|
);
|
||||||
|
|
||||||
|
return wrapper;
|
||||||
|
};
|
||||||
|
|
||||||
|
beforeEach(jest.clearAllMocks);
|
||||||
|
afterEach(() => wrapper?.unmount());
|
||||||
|
|
||||||
|
it.each([
|
||||||
|
[ undefined ],
|
||||||
|
[ Mock.of<ServerData>({ url: 'url', apiKey: 'apiKey' }) ],
|
||||||
|
])('displays provided server data', (serverData) => {
|
||||||
|
const wrapper = createWrapper(serverData);
|
||||||
|
const li = wrapper.find('li');
|
||||||
|
|
||||||
|
expect(li.first().find('b').html()).toEqual(`<b>${serverData?.url ?? ''}</b>`);
|
||||||
|
expect(li.last().find('b').html()).toEqual(`<b>${serverData?.apiKey ?? ''}</b>`);
|
||||||
|
});
|
||||||
|
|
||||||
|
it('invokes onDiscard when appropriate button is clicked', () => {
|
||||||
|
const wrapper = createWrapper();
|
||||||
|
const btn = wrapper.find(Button).first();
|
||||||
|
|
||||||
|
btn.simulate('click');
|
||||||
|
|
||||||
|
expect(onDiscard).toHaveBeenCalled();
|
||||||
|
});
|
||||||
|
|
||||||
|
it('invokes onSave when appropriate button is clicked', () => {
|
||||||
|
const wrapper = createWrapper();
|
||||||
|
const btn = wrapper.find(Button).last();
|
||||||
|
|
||||||
|
btn.simulate('click');
|
||||||
|
|
||||||
|
expect(onSave).toHaveBeenCalled();
|
||||||
|
});
|
||||||
|
});
|
Loading…
Reference in a new issue