mirror of
https://github.com/shlinkio/shlink-web-client.git
synced 2025-01-07 08:47:28 +03:00
84 lines
2.9 KiB
TypeScript
84 lines
2.9 KiB
TypeScript
import { shallow, ShallowWrapper } from 'enzyme';
|
|
import { Mock } from 'ts-mockery';
|
|
import { DropdownItem } from 'reactstrap';
|
|
import { ServerWithId } from '../../src/servers/data';
|
|
import { ManageServersRowDropdown as createManageServersRowDropdown } from '../../src/servers/ManageServersRowDropdown';
|
|
|
|
describe('<ManageServersRowDropdown />', () => {
|
|
const DeleteServerModal = () => null;
|
|
const ManageServersRowDropdown = createManageServersRowDropdown(DeleteServerModal);
|
|
const setAutoConnect = jest.fn();
|
|
let wrapper: ShallowWrapper;
|
|
const createWrapper = (autoConnect = false) => {
|
|
const server = Mock.of<ServerWithId>({ id: 'abc123', autoConnect });
|
|
|
|
wrapper = shallow(<ManageServersRowDropdown setAutoConnect={setAutoConnect} server={server} />);
|
|
|
|
return wrapper;
|
|
};
|
|
|
|
afterEach(jest.clearAllMocks);
|
|
|
|
it('renders expected amount of dropdown items', () => {
|
|
const wrapper = createWrapper();
|
|
const items = wrapper.find(DropdownItem);
|
|
|
|
expect(items).toHaveLength(5);
|
|
expect(items.find('[divider]')).toHaveLength(1);
|
|
expect(items.at(0).prop('to')).toEqual('/server/abc123');
|
|
expect(items.at(1).prop('to')).toEqual('/server/abc123/edit');
|
|
});
|
|
|
|
it('allows toggling auto-connect', () => {
|
|
const wrapper = createWrapper();
|
|
|
|
expect(setAutoConnect).not.toHaveBeenCalled();
|
|
wrapper.find(DropdownItem).at(2).simulate('click');
|
|
expect(setAutoConnect).toHaveBeenCalledWith(expect.objectContaining({ id: 'abc123' }), true);
|
|
});
|
|
|
|
it('renders a modal', () => {
|
|
const wrapper = createWrapper();
|
|
const modal = wrapper.find(DeleteServerModal);
|
|
|
|
expect(modal).toHaveLength(1);
|
|
expect(modal.prop('redirectHome')).toEqual(false);
|
|
expect(modal.prop('server')).toEqual(expect.objectContaining({ id: 'abc123' }));
|
|
expect(modal.prop('isOpen')).toEqual(false);
|
|
});
|
|
|
|
it('allows toggling the modal', () => {
|
|
const wrapper = createWrapper();
|
|
const modalToggle = wrapper.find(DropdownItem).last();
|
|
|
|
expect(wrapper.find(DeleteServerModal).prop('isOpen')).toEqual(false);
|
|
|
|
modalToggle.simulate('click');
|
|
expect(wrapper.find(DeleteServerModal).prop('isOpen')).toEqual(true);
|
|
|
|
(wrapper.find(DeleteServerModal).prop('toggle') as Function)();
|
|
expect(wrapper.find(DeleteServerModal).prop('isOpen')).toEqual(false);
|
|
});
|
|
|
|
it('can be toggled', () => {
|
|
const wrapper = createWrapper();
|
|
|
|
expect(wrapper.prop('isOpen')).toEqual(false);
|
|
|
|
(wrapper.prop('toggle') as Function)();
|
|
expect(wrapper.prop('isOpen')).toEqual(true);
|
|
|
|
(wrapper.prop('toggle') as Function)();
|
|
expect(wrapper.prop('isOpen')).toEqual(false);
|
|
});
|
|
|
|
it.each([
|
|
[true, 'Do not auto-connect'],
|
|
[false, 'Auto-connect'],
|
|
])('shows different auto-connect toggle text depending on current server status', (autoConnect, expectedText) => {
|
|
const wrapper = createWrapper(autoConnect);
|
|
const item = wrapper.find(DropdownItem).at(2);
|
|
|
|
expect(item.html()).toContain(expectedText);
|
|
});
|
|
});
|