2018-08-24 23:19:49 +02:00
|
|
|
import React from 'react';
|
|
|
|
import { shallow } from 'enzyme';
|
|
|
|
import { identity } from 'ramda';
|
|
|
|
import sinon from 'sinon';
|
2018-12-17 22:32:51 +01:00
|
|
|
import createServerConstruct from '../../src/servers/CreateServer';
|
2018-08-24 23:19:49 +02:00
|
|
|
|
|
|
|
describe('<CreateServer />', () => {
|
|
|
|
let wrapper;
|
2018-12-17 22:32:51 +01:00
|
|
|
const ImportServersBtn = () => '';
|
2018-08-24 23:19:49 +02:00
|
|
|
const createServerMock = sinon.fake();
|
|
|
|
const historyMock = {
|
|
|
|
push: sinon.fake(),
|
|
|
|
};
|
|
|
|
|
|
|
|
beforeEach(() => {
|
|
|
|
createServerMock.resetHistory();
|
|
|
|
historyMock.push.resetHistory();
|
|
|
|
|
2018-12-17 22:32:51 +01:00
|
|
|
const CreateServer = createServerConstruct(ImportServersBtn);
|
|
|
|
|
2018-08-24 23:19:49 +02:00
|
|
|
wrapper = shallow(
|
2018-12-17 20:24:31 +01:00
|
|
|
<CreateServer createServer={createServerMock} resetSelectedServer={identity} history={historyMock} />
|
2018-08-24 23:19:49 +02:00
|
|
|
);
|
|
|
|
});
|
|
|
|
afterEach(() => wrapper.unmount());
|
|
|
|
|
|
|
|
it('renders components', () => {
|
|
|
|
expect(wrapper.find('#name')).toHaveLength(1);
|
|
|
|
expect(wrapper.find('#url')).toHaveLength(1);
|
|
|
|
expect(wrapper.find('#apiKey')).toHaveLength(1);
|
|
|
|
expect(wrapper.find(ImportServersBtn)).toHaveLength(1);
|
|
|
|
expect(wrapper.find('.create-server__import-success-msg')).toHaveLength(0);
|
|
|
|
});
|
|
|
|
|
|
|
|
it('shows success message when imported is true', () => {
|
|
|
|
wrapper.setState({ serversImported: true });
|
|
|
|
expect(wrapper.find('.create-server__import-success-msg')).toHaveLength(1);
|
|
|
|
});
|
|
|
|
|
|
|
|
it('creates server and redirects to it when form is submitted', () => {
|
|
|
|
const form = wrapper.find('form');
|
2018-08-25 23:39:27 +02:00
|
|
|
|
|
|
|
form.simulate('submit', { preventDefault() {
|
|
|
|
return '';
|
|
|
|
} });
|
2018-08-24 23:19:49 +02:00
|
|
|
|
|
|
|
expect(createServerMock.callCount).toEqual(1);
|
|
|
|
expect(historyMock.push.callCount).toEqual(1);
|
|
|
|
});
|
|
|
|
|
|
|
|
it('updates state when inputs are changed', () => {
|
|
|
|
const nameInput = wrapper.find('#name');
|
|
|
|
const urlInput = wrapper.find('#url');
|
|
|
|
const apiKeyInput = wrapper.find('#apiKey');
|
|
|
|
|
|
|
|
nameInput.simulate('change', { target: { value: 'the_name' } });
|
|
|
|
urlInput.simulate('change', { target: { value: 'the_url' } });
|
|
|
|
apiKeyInput.simulate('change', { target: { value: 'the_api_key' } });
|
|
|
|
|
|
|
|
expect(wrapper.state('name')).toEqual('the_name');
|
|
|
|
expect(wrapper.state('url')).toEqual('the_url');
|
|
|
|
expect(wrapper.state('apiKey')).toEqual('the_api_key');
|
|
|
|
});
|
|
|
|
});
|