mirror of
https://github.com/shlinkio/shlink-web-client.git
synced 2025-01-11 10:47:27 +03:00
Created EditDomainRedirectsModal test
This commit is contained in:
parent
13785c7beb
commit
74ac122787
4 changed files with 91 additions and 20 deletions
|
@ -1,7 +1,7 @@
|
||||||
import { FC, useState } from 'react';
|
import { FC, useState } from 'react';
|
||||||
import { Button, Modal, ModalBody, ModalFooter, ModalHeader } from 'reactstrap';
|
import { Button, Modal, ModalBody, ModalFooter, ModalHeader } from 'reactstrap';
|
||||||
import { ShlinkDomain, ShlinkDomainRedirects } from '../../api/types';
|
import { ShlinkDomain, ShlinkDomainRedirects } from '../../api/types';
|
||||||
import { FormGroupContainer } from '../../utils/FormGroupContainer';
|
import { FormGroupContainer, FormGroupContainerProps } from '../../utils/FormGroupContainer';
|
||||||
import { handleEventPreventingDefault, nonEmptyValueOrNull } from '../../utils/utils';
|
import { handleEventPreventingDefault, nonEmptyValueOrNull } from '../../utils/utils';
|
||||||
import { InfoTooltip } from '../../utils/InfoTooltip';
|
import { InfoTooltip } from '../../utils/InfoTooltip';
|
||||||
|
|
||||||
|
@ -12,19 +12,14 @@ interface EditDomainRedirectsModalProps {
|
||||||
editDomainRedirects: (domain: string, redirects: Partial<ShlinkDomainRedirects>) => Promise<void>;
|
editDomainRedirects: (domain: string, redirects: Partial<ShlinkDomainRedirects>) => Promise<void>;
|
||||||
}
|
}
|
||||||
|
|
||||||
const FormGroup: FC<{ value: string; onChange: (newValue: string) => void; isLast?: boolean }> = (
|
const FormGroup: FC<FormGroupContainerProps & { isLast?: boolean }> = ({ isLast, ...rest }) => (
|
||||||
{ value, onChange, isLast, children },
|
|
||||||
) => (
|
|
||||||
<FormGroupContainer
|
<FormGroupContainer
|
||||||
value={value}
|
{...rest}
|
||||||
required={false}
|
required={false}
|
||||||
type="url"
|
type="url"
|
||||||
placeholder="No redirect"
|
placeholder="No redirect"
|
||||||
className={isLast ? 'mb-0' : ''}
|
className={isLast ? 'mb-0' : ''}
|
||||||
onChange={onChange}
|
/>
|
||||||
>
|
|
||||||
{children}
|
|
||||||
</FormGroupContainer>
|
|
||||||
);
|
);
|
||||||
|
|
||||||
export const EditDomainRedirectsModal: FC<EditDomainRedirectsModalProps> = (
|
export const EditDomainRedirectsModal: FC<EditDomainRedirectsModalProps> = (
|
||||||
|
|
|
@ -1,5 +1,5 @@
|
||||||
import { FC, ReactNode, useEffect, useState } from 'react';
|
import { FC, ReactNode, useEffect, useState } from 'react';
|
||||||
import { FormGroupContainer } from '../../utils/FormGroupContainer';
|
import { FormGroupContainer, FormGroupContainerProps } from '../../utils/FormGroupContainer';
|
||||||
import { handleEventPreventingDefault } from '../../utils/utils';
|
import { handleEventPreventingDefault } from '../../utils/utils';
|
||||||
import { ServerData } from '../data';
|
import { ServerData } from '../data';
|
||||||
import { SimpleCard } from '../../utils/SimpleCard';
|
import { SimpleCard } from '../../utils/SimpleCard';
|
||||||
|
@ -11,6 +11,9 @@ interface ServerFormProps {
|
||||||
title?: ReactNode;
|
title?: ReactNode;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
const FormGroup: FC<FormGroupContainerProps> = (props) =>
|
||||||
|
<FormGroupContainer {...props} labelClassName="create-server__label" />;
|
||||||
|
|
||||||
export const ServerForm: FC<ServerFormProps> = ({ onSubmit, initialValues, children, title }) => {
|
export const ServerForm: FC<ServerFormProps> = ({ onSubmit, initialValues, children, title }) => {
|
||||||
const [ name, setName ] = useState('');
|
const [ name, setName ] = useState('');
|
||||||
const [ url, setUrl ] = useState('');
|
const [ url, setUrl ] = useState('');
|
||||||
|
@ -26,15 +29,9 @@ export const ServerForm: FC<ServerFormProps> = ({ onSubmit, initialValues, child
|
||||||
return (
|
return (
|
||||||
<form className="server-form" onSubmit={handleSubmit}>
|
<form className="server-form" onSubmit={handleSubmit}>
|
||||||
<SimpleCard className="mb-3" title={title}>
|
<SimpleCard className="mb-3" title={title}>
|
||||||
<FormGroupContainer labelClassName="create-server__label" value={name} onChange={setName}>
|
<FormGroup value={name} onChange={setName}>Name</FormGroup>
|
||||||
Name
|
<FormGroup type="url" value={url} onChange={setUrl}>URL</FormGroup>
|
||||||
</FormGroupContainer>
|
<FormGroup value={apiKey} onChange={setApiKey}>APIkey</FormGroup>
|
||||||
<FormGroupContainer labelClassName="create-server__label" type="url" value={url} onChange={setUrl}>
|
|
||||||
URL
|
|
||||||
</FormGroupContainer>
|
|
||||||
<FormGroupContainer labelClassName="create-server__label" value={apiKey} onChange={setApiKey}>API
|
|
||||||
key
|
|
||||||
</FormGroupContainer>
|
|
||||||
</SimpleCard>
|
</SimpleCard>
|
||||||
|
|
||||||
<div className="text-right">{children}</div>
|
<div className="text-right">{children}</div>
|
||||||
|
|
|
@ -2,7 +2,7 @@ import { FC, useRef } from 'react';
|
||||||
import { v4 as uuid } from 'uuid';
|
import { v4 as uuid } from 'uuid';
|
||||||
import { InputType } from 'reactstrap/lib/Input';
|
import { InputType } from 'reactstrap/lib/Input';
|
||||||
|
|
||||||
interface FormGroupContainerProps {
|
export interface FormGroupContainerProps {
|
||||||
value: string;
|
value: string;
|
||||||
onChange: (newValue: string) => void;
|
onChange: (newValue: string) => void;
|
||||||
id?: string;
|
id?: string;
|
||||||
|
|
79
test/domains/helpers/EditDomainRedirectsModal.test.tsx
Normal file
79
test/domains/helpers/EditDomainRedirectsModal.test.tsx
Normal file
|
@ -0,0 +1,79 @@
|
||||||
|
import { shallow, ShallowWrapper } from 'enzyme';
|
||||||
|
import { Mock } from 'ts-mockery';
|
||||||
|
import { Button, ModalHeader } from 'reactstrap';
|
||||||
|
import { ShlinkDomain } from '../../../src/api/types';
|
||||||
|
import { EditDomainRedirectsModal } from '../../../src/domains/helpers/EditDomainRedirectsModal';
|
||||||
|
import { InfoTooltip } from '../../../src/utils/InfoTooltip';
|
||||||
|
|
||||||
|
describe('<EditDomainRedirectsModal />', () => {
|
||||||
|
let wrapper: ShallowWrapper;
|
||||||
|
const editDomainRedirects = jest.fn().mockResolvedValue(undefined);
|
||||||
|
const toggle = jest.fn();
|
||||||
|
const domain = Mock.of<ShlinkDomain>({ domain: 'foo.com' });
|
||||||
|
|
||||||
|
beforeEach(() => {
|
||||||
|
wrapper = shallow(
|
||||||
|
<EditDomainRedirectsModal domain={domain} isOpen toggle={toggle} editDomainRedirects={editDomainRedirects} />,
|
||||||
|
);
|
||||||
|
});
|
||||||
|
|
||||||
|
afterEach(jest.clearAllMocks);
|
||||||
|
afterEach(() => wrapper?.unmount());
|
||||||
|
|
||||||
|
it('renders domain in header', () => {
|
||||||
|
const header = wrapper.find(ModalHeader);
|
||||||
|
|
||||||
|
expect(header.html()).toContain('foo.com');
|
||||||
|
});
|
||||||
|
|
||||||
|
it('expected amount of form groups and tooltips', () => {
|
||||||
|
const formGroups = wrapper.find('FormGroup');
|
||||||
|
const tooltips = wrapper.find(InfoTooltip);
|
||||||
|
|
||||||
|
expect(formGroups).toHaveLength(3);
|
||||||
|
expect(tooltips).toHaveLength(3);
|
||||||
|
});
|
||||||
|
|
||||||
|
it('has different handlers to toggle the modal', () => {
|
||||||
|
expect(toggle).not.toHaveBeenCalled();
|
||||||
|
|
||||||
|
(wrapper.prop('toggle') as Function)(); // eslint-disable-line @typescript-eslint/no-unnecessary-type-assertion
|
||||||
|
(wrapper.find(ModalHeader).prop('toggle') as Function)();
|
||||||
|
wrapper.find(Button).first().simulate('click');
|
||||||
|
|
||||||
|
expect(toggle).toHaveBeenCalledTimes(3);
|
||||||
|
});
|
||||||
|
|
||||||
|
it('saves expected values when form is submitted', () => {
|
||||||
|
const formGroups = wrapper.find('FormGroup');
|
||||||
|
|
||||||
|
expect(editDomainRedirects).not.toHaveBeenCalled();
|
||||||
|
|
||||||
|
wrapper.find('form').simulate('submit', { preventDefault: jest.fn() });
|
||||||
|
expect(editDomainRedirects).toHaveBeenCalledWith('foo.com', {
|
||||||
|
baseUrlRedirect: null,
|
||||||
|
regular404Redirect: null,
|
||||||
|
invalidShortUrlRedirect: null,
|
||||||
|
});
|
||||||
|
|
||||||
|
formGroups.at(0).simulate('change', 'new_base_url');
|
||||||
|
formGroups.at(2).simulate('change', 'new_invalid_short_url');
|
||||||
|
|
||||||
|
wrapper.find('form').simulate('submit', { preventDefault: jest.fn() });
|
||||||
|
expect(editDomainRedirects).toHaveBeenCalledWith('foo.com', {
|
||||||
|
baseUrlRedirect: 'new_base_url',
|
||||||
|
regular404Redirect: null,
|
||||||
|
invalidShortUrlRedirect: 'new_invalid_short_url',
|
||||||
|
});
|
||||||
|
|
||||||
|
formGroups.at(1).simulate('change', 'new_regular_404');
|
||||||
|
formGroups.at(2).simulate('change', '');
|
||||||
|
|
||||||
|
wrapper.find('form').simulate('submit', { preventDefault: jest.fn() });
|
||||||
|
expect(editDomainRedirects).toHaveBeenCalledWith('foo.com', {
|
||||||
|
baseUrlRedirect: 'new_base_url',
|
||||||
|
regular404Redirect: 'new_regular_404',
|
||||||
|
invalidShortUrlRedirect: null,
|
||||||
|
});
|
||||||
|
});
|
||||||
|
});
|
Loading…
Reference in a new issue