2020-08-26 20:37:36 +02:00
|
|
|
import { shallow, ShallowWrapper } from 'enzyme';
|
|
|
|
import { FormGroup } from 'reactstrap';
|
|
|
|
import { Mock } from 'ts-mockery';
|
2020-03-30 21:26:30 +02:00
|
|
|
import EditShortUrlModal from '../../../src/short-urls/helpers/EditShortUrlModal';
|
2020-08-26 20:37:36 +02:00
|
|
|
import { ShortUrl } from '../../../src/short-urls/data';
|
|
|
|
import { ShortUrlEdition } from '../../../src/short-urls/reducers/shortUrlEdition';
|
2020-12-21 17:54:05 +01:00
|
|
|
import { Result } from '../../../src/utils/Result';
|
2020-03-30 21:26:30 +02:00
|
|
|
|
|
|
|
describe('<EditShortUrlModal />', () => {
|
2020-08-26 20:37:36 +02:00
|
|
|
let wrapper: ShallowWrapper;
|
|
|
|
const editShortUrl = jest.fn(async () => Promise.resolve());
|
2020-03-30 21:26:30 +02:00
|
|
|
const toggle = jest.fn();
|
2020-08-26 20:37:36 +02:00
|
|
|
const createWrapper = (shortUrl: Partial<ShortUrl>, shortUrlEdition: Partial<ShortUrlEdition>) => {
|
2020-03-30 21:26:30 +02:00
|
|
|
wrapper = shallow(
|
|
|
|
<EditShortUrlModal
|
|
|
|
isOpen={true}
|
2020-08-26 20:37:36 +02:00
|
|
|
shortUrl={Mock.of<ShortUrl>(shortUrl)}
|
|
|
|
shortUrlEdition={Mock.of<ShortUrlEdition>(shortUrlEdition)}
|
2020-03-30 21:26:30 +02:00
|
|
|
toggle={toggle}
|
|
|
|
editShortUrl={editShortUrl}
|
2020-08-22 08:10:31 +02:00
|
|
|
/>,
|
2020-03-30 21:26:30 +02:00
|
|
|
);
|
|
|
|
|
|
|
|
return wrapper;
|
|
|
|
};
|
|
|
|
|
2020-08-26 20:37:36 +02:00
|
|
|
afterEach(() => wrapper?.unmount());
|
|
|
|
afterEach(jest.clearAllMocks);
|
2020-03-30 21:26:30 +02:00
|
|
|
|
|
|
|
it.each([
|
|
|
|
[ false, 0 ],
|
|
|
|
[ true, 1 ],
|
|
|
|
])('properly renders form with expected components', (error, expectedErrorLength) => {
|
|
|
|
const wrapper = createWrapper({}, { saving: false, error });
|
2020-12-21 17:54:05 +01:00
|
|
|
const errorElement = wrapper.find(Result).filterWhere((result) => result.prop('type') === 'error');
|
2020-03-30 21:26:30 +02:00
|
|
|
const form = wrapper.find('form');
|
|
|
|
const formGroup = form.find(FormGroup);
|
|
|
|
|
|
|
|
expect(form).toHaveLength(1);
|
|
|
|
expect(formGroup).toHaveLength(1);
|
|
|
|
expect(errorElement).toHaveLength(expectedErrorLength);
|
|
|
|
});
|
|
|
|
|
|
|
|
it.each([
|
|
|
|
[ true, 'Saving...', 'something', true ],
|
|
|
|
[ true, 'Saving...', undefined, true ],
|
|
|
|
[ false, 'Save', 'something', false ],
|
|
|
|
[ false, 'Save', undefined, true ],
|
|
|
|
])('renders submit button on expected state', (saving, expectedText, longUrl, expectedDisabled) => {
|
|
|
|
const wrapper = createWrapper({ longUrl }, { saving, error: false });
|
|
|
|
const button = wrapper.find('[color="primary"]');
|
|
|
|
|
|
|
|
expect(button.prop('disabled')).toEqual(expectedDisabled);
|
|
|
|
expect(button.html()).toContain(expectedText);
|
|
|
|
});
|
|
|
|
|
|
|
|
it('saves data when form is submit', () => {
|
|
|
|
const preventDefault = jest.fn();
|
|
|
|
const wrapper = createWrapper({}, { saving: false, error: false });
|
|
|
|
const form = wrapper.find('form');
|
|
|
|
|
|
|
|
form.simulate('submit', { preventDefault });
|
|
|
|
|
|
|
|
expect(preventDefault).toHaveBeenCalled();
|
|
|
|
expect(editShortUrl).toHaveBeenCalled();
|
|
|
|
});
|
|
|
|
|
|
|
|
it.each([
|
|
|
|
[ '[color="link"]', 'onClick' ],
|
2020-08-26 20:37:36 +02:00
|
|
|
[ 'Modal', 'toggle' ],
|
|
|
|
[ 'ModalHeader', 'toggle' ],
|
2020-03-30 21:26:30 +02:00
|
|
|
])('toggles modal with different mechanisms', (componentToFind, propToCall) => {
|
|
|
|
const wrapper = createWrapper({}, { saving: false, error: false });
|
|
|
|
const component = wrapper.find(componentToFind);
|
|
|
|
|
2020-08-26 20:37:36 +02:00
|
|
|
(component.prop(propToCall) as Function)(); // eslint-disable-line @typescript-eslint/no-unnecessary-type-assertion
|
2020-03-30 21:26:30 +02:00
|
|
|
|
|
|
|
expect(toggle).toHaveBeenCalled();
|
|
|
|
});
|
|
|
|
});
|