mirror of
https://github.com/shlinkio/shlink-web-client.git
synced 2025-01-10 18:27:25 +03:00
Created DomainStatusIcon test
This commit is contained in:
parent
6411c6169b
commit
ecd6e6a066
2 changed files with 59 additions and 2 deletions
|
@ -29,12 +29,12 @@ export const DomainStatusIcon: FC<{ status: DomainStatus }> = ({ status }) => {
|
||||||
</span>
|
</span>
|
||||||
<UncontrolledTooltip target={(() => ref.current) as any} placement="bottom" autohide={status === 'valid'}>
|
<UncontrolledTooltip target={(() => ref.current) as any} placement="bottom" autohide={status === 'valid'}>
|
||||||
{status === 'valid' ? 'Congratulations! This domain is properly configured.' : (
|
{status === 'valid' ? 'Congratulations! This domain is properly configured.' : (
|
||||||
<>
|
<span>
|
||||||
Oops! There is some missing configuration, and short URLs shared with this domain will not work.
|
Oops! There is some missing configuration, and short URLs shared with this domain will not work.
|
||||||
<br />
|
<br />
|
||||||
Follow <ExternalLink href="https://slnk.to/multi-domain-docs">the documentation</ExternalLink> in order to
|
Follow <ExternalLink href="https://slnk.to/multi-domain-docs">the documentation</ExternalLink> in order to
|
||||||
find out what is missing.
|
find out what is missing.
|
||||||
</>
|
</span>
|
||||||
)}
|
)}
|
||||||
</UncontrolledTooltip>
|
</UncontrolledTooltip>
|
||||||
</>
|
</>
|
||||||
|
|
57
test/domains/helpers/DomainStatusIcon.test.tsx
Normal file
57
test/domains/helpers/DomainStatusIcon.test.tsx
Normal file
|
@ -0,0 +1,57 @@
|
||||||
|
import { shallow, ShallowWrapper } from 'enzyme';
|
||||||
|
import { UncontrolledTooltip } from 'reactstrap';
|
||||||
|
import { FontAwesomeIcon } from '@fortawesome/react-fontawesome';
|
||||||
|
import { faBan, faCheck, faCircleNotch } from '@fortawesome/free-solid-svg-icons';
|
||||||
|
import { DomainStatus } from '../../../src/domains/data';
|
||||||
|
import { DomainStatusIcon } from '../../../src/domains/helpers/DomainStatusIcon';
|
||||||
|
|
||||||
|
describe('<DomainStatusIcon />', () => {
|
||||||
|
let wrapper: ShallowWrapper;
|
||||||
|
const createWrapper = (status: DomainStatus) => {
|
||||||
|
wrapper = shallow(<DomainStatusIcon status={status} />);
|
||||||
|
|
||||||
|
return wrapper;
|
||||||
|
};
|
||||||
|
|
||||||
|
afterEach(() => wrapper?.unmount());
|
||||||
|
|
||||||
|
it('renders loading icon when status is "validating"', () => {
|
||||||
|
const wrapper = createWrapper('validating');
|
||||||
|
const tooltip = wrapper.find(UncontrolledTooltip);
|
||||||
|
const faIcon = wrapper.find(FontAwesomeIcon);
|
||||||
|
|
||||||
|
expect(tooltip).toHaveLength(0);
|
||||||
|
expect(faIcon).toHaveLength(1);
|
||||||
|
expect(faIcon.prop('icon')).toEqual(faCircleNotch);
|
||||||
|
expect(faIcon.prop('spin')).toEqual(true);
|
||||||
|
});
|
||||||
|
|
||||||
|
it.each([
|
||||||
|
[
|
||||||
|
'invalid' as DomainStatus,
|
||||||
|
faBan,
|
||||||
|
'Oops! There is some missing configuration, and short URLs shared with this domain will not work.',
|
||||||
|
],
|
||||||
|
[ 'valid' as DomainStatus, faCheck, 'Congratulations! This domain is properly configured.' ],
|
||||||
|
])('renders expected icon and tooltip when status is not validating', (status, expectedIcon, expectedText) => {
|
||||||
|
const wrapper = createWrapper(status);
|
||||||
|
const tooltip = wrapper.find(UncontrolledTooltip);
|
||||||
|
const faIcon = wrapper.find(FontAwesomeIcon);
|
||||||
|
const getTooltipText = (): string => {
|
||||||
|
const children = tooltip.prop('children');
|
||||||
|
|
||||||
|
if (typeof children === 'string') {
|
||||||
|
return children;
|
||||||
|
}
|
||||||
|
|
||||||
|
return tooltip.find('span').html();
|
||||||
|
};
|
||||||
|
|
||||||
|
expect(tooltip).toHaveLength(1);
|
||||||
|
expect(tooltip.prop('autohide')).toEqual(status === 'valid');
|
||||||
|
expect(getTooltipText()).toContain(expectedText);
|
||||||
|
expect(faIcon).toHaveLength(1);
|
||||||
|
expect(faIcon.prop('icon')).toEqual(expectedIcon);
|
||||||
|
expect(faIcon.prop('spin')).toEqual(false);
|
||||||
|
});
|
||||||
|
});
|
Loading…
Reference in a new issue