mirror of
https://github.com/shlinkio/shlink-web-client.git
synced 2025-01-11 02:37:22 +03:00
Created missing tests for settings components
This commit is contained in:
parent
dc2f30c73b
commit
b462169e1e
4 changed files with 124 additions and 2 deletions
|
@ -34,7 +34,7 @@ const RealTimeUpdates = (
|
||||||
placeholder="Immediate"
|
placeholder="Immediate"
|
||||||
disabled={!realTimeUpdates.enabled}
|
disabled={!realTimeUpdates.enabled}
|
||||||
value={intervalValue(realTimeUpdates.interval)}
|
value={intervalValue(realTimeUpdates.interval)}
|
||||||
onChange={(e) => setRealTimeUpdatesInterval(Number(e.target.value))}
|
onChange={({ target }) => setRealTimeUpdatesInterval(Number(target.value))}
|
||||||
/>
|
/>
|
||||||
{realTimeUpdates.enabled && (
|
{realTimeUpdates.enabled && (
|
||||||
<small className="form-text text-muted">
|
<small className="form-text text-muted">
|
||||||
|
|
|
@ -12,7 +12,7 @@ export const SET_SETTINGS = 'shlink/realTimeUpdates/SET_SETTINGS';
|
||||||
* optional, as old instances of the app will load partial objects from local storage until it is saved again.
|
* optional, as old instances of the app will load partial objects from local storage until it is saved again.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
interface RealTimeUpdatesSettings {
|
export interface RealTimeUpdatesSettings {
|
||||||
enabled: boolean;
|
enabled: boolean;
|
||||||
interval?: number;
|
interval?: number;
|
||||||
}
|
}
|
||||||
|
|
104
test/settings/RealTimeUpdates.test.tsx
Normal file
104
test/settings/RealTimeUpdates.test.tsx
Normal file
|
@ -0,0 +1,104 @@
|
||||||
|
import { shallow, ShallowWrapper } from 'enzyme';
|
||||||
|
import { Mock } from 'ts-mockery';
|
||||||
|
import { Input } from 'reactstrap';
|
||||||
|
import { RealTimeUpdatesSettings, Settings } from '../../src/settings/reducers/settings';
|
||||||
|
import RealTimeUpdates from '../../src/settings/RealTimeUpdates';
|
||||||
|
import ToggleSwitch from '../../src/utils/ToggleSwitch';
|
||||||
|
|
||||||
|
describe('<RealTimeUpdates />', () => {
|
||||||
|
const toggleRealTimeUpdates = jest.fn();
|
||||||
|
const setRealTimeUpdatesInterval = jest.fn();
|
||||||
|
let wrapper: ShallowWrapper;
|
||||||
|
const createWrapper = (realTimeUpdates: Partial<RealTimeUpdatesSettings> = {}) => {
|
||||||
|
const settings = Mock.of<Settings>({ realTimeUpdates });
|
||||||
|
|
||||||
|
wrapper = shallow(
|
||||||
|
<RealTimeUpdates
|
||||||
|
settings={settings}
|
||||||
|
toggleRealTimeUpdates={toggleRealTimeUpdates}
|
||||||
|
setRealTimeUpdatesInterval={setRealTimeUpdatesInterval}
|
||||||
|
/>,
|
||||||
|
);
|
||||||
|
|
||||||
|
return wrapper;
|
||||||
|
};
|
||||||
|
|
||||||
|
afterEach(jest.clearAllMocks);
|
||||||
|
afterEach(() => wrapper?.unmount());
|
||||||
|
|
||||||
|
test('enabled real time updates are rendered as expected', () => {
|
||||||
|
const wrapper = createWrapper({ enabled: true });
|
||||||
|
const toggle = wrapper.find(ToggleSwitch);
|
||||||
|
const label = wrapper.find('label');
|
||||||
|
const input = wrapper.find(Input);
|
||||||
|
const small = wrapper.find('small');
|
||||||
|
|
||||||
|
expect(toggle.prop('checked')).toEqual(true);
|
||||||
|
expect(toggle.html()).toContain('processed');
|
||||||
|
expect(toggle.html()).not.toContain('ignored');
|
||||||
|
expect(label.prop('className')).toEqual('');
|
||||||
|
expect(input.prop('disabled')).toEqual(false);
|
||||||
|
expect(small).toHaveLength(2);
|
||||||
|
});
|
||||||
|
|
||||||
|
test('disabled real time updates are rendered as expected', () => {
|
||||||
|
const wrapper = createWrapper({ enabled: false });
|
||||||
|
const toggle = wrapper.find(ToggleSwitch);
|
||||||
|
const label = wrapper.find('label');
|
||||||
|
const input = wrapper.find(Input);
|
||||||
|
const small = wrapper.find('small');
|
||||||
|
|
||||||
|
expect(toggle.prop('checked')).toEqual(false);
|
||||||
|
expect(toggle.html()).not.toContain('processed');
|
||||||
|
expect(toggle.html()).toContain('ignored');
|
||||||
|
expect(label.prop('className')).toEqual('text-muted');
|
||||||
|
expect(input.prop('disabled')).toEqual(true);
|
||||||
|
expect(small).toHaveLength(1);
|
||||||
|
});
|
||||||
|
|
||||||
|
test.each([
|
||||||
|
[ 1, 'minute' ],
|
||||||
|
[ 2, 'minutes' ],
|
||||||
|
[ 10, 'minutes' ],
|
||||||
|
[ 100, 'minutes' ],
|
||||||
|
])('expected children are shown when interval is greater than 0', (interval, minutesWord) => {
|
||||||
|
const wrapper = createWrapper({ enabled: true, interval });
|
||||||
|
const span = wrapper.find('span');
|
||||||
|
const input = wrapper.find(Input);
|
||||||
|
|
||||||
|
expect(span).toHaveLength(1);
|
||||||
|
expect(span.html()).toEqual(
|
||||||
|
`<span>Updates will be reflected in the UI every <b>${interval}</b> ${minutesWord}.</span>`,
|
||||||
|
);
|
||||||
|
expect(input.prop('value')).toEqual(`${interval}`);
|
||||||
|
});
|
||||||
|
|
||||||
|
test.each([[ undefined ], [ 0 ]])('expected children are shown when interval is 0 or undefined', (interval) => {
|
||||||
|
const wrapper = createWrapper({ enabled: true, interval });
|
||||||
|
const span = wrapper.find('span');
|
||||||
|
const small = wrapper.find('small').at(1);
|
||||||
|
const input = wrapper.find(Input);
|
||||||
|
|
||||||
|
expect(span).toHaveLength(0);
|
||||||
|
expect(small.html()).toContain('Updates will be reflected in the UI as soon as they happen.');
|
||||||
|
expect(input.prop('value')).toEqual('');
|
||||||
|
});
|
||||||
|
|
||||||
|
test('real time updates are updated on input change', () => {
|
||||||
|
const wrapper = createWrapper();
|
||||||
|
const input = wrapper.find(Input);
|
||||||
|
|
||||||
|
expect(setRealTimeUpdatesInterval).not.toHaveBeenCalled();
|
||||||
|
input.simulate('change', { target: { value: '10' } });
|
||||||
|
expect(setRealTimeUpdatesInterval).toHaveBeenCalledWith(10);
|
||||||
|
});
|
||||||
|
|
||||||
|
test('real time updates are toggled on switch change', () => {
|
||||||
|
const wrapper = createWrapper();
|
||||||
|
const toggle = wrapper.find(ToggleSwitch);
|
||||||
|
|
||||||
|
expect(toggleRealTimeUpdates).not.toHaveBeenCalled();
|
||||||
|
toggle.simulate('change');
|
||||||
|
expect(toggleRealTimeUpdates).toHaveBeenCalled();
|
||||||
|
});
|
||||||
|
});
|
18
test/settings/Settings.test.tsx
Normal file
18
test/settings/Settings.test.tsx
Normal file
|
@ -0,0 +1,18 @@
|
||||||
|
import { shallow } from 'enzyme';
|
||||||
|
import createSettings from '../../src/settings/Settings';
|
||||||
|
import NoMenuLayout from '../../src/common/NoMenuLayout';
|
||||||
|
|
||||||
|
describe('<Settings />', () => {
|
||||||
|
const Component = () => null;
|
||||||
|
const Settings = createSettings(Component, Component, Component, Component);
|
||||||
|
|
||||||
|
test('a no-menu layout is renders with the four settings sections', () => {
|
||||||
|
const wrapper = shallow(<Settings />);
|
||||||
|
const layout = wrapper.find(NoMenuLayout);
|
||||||
|
const sections = wrapper.find('SettingsSections');
|
||||||
|
|
||||||
|
expect(layout).toHaveLength(1);
|
||||||
|
expect(sections).toHaveLength(1);
|
||||||
|
expect((sections.prop('items') as any[]).flat()).toHaveLength(4); // eslint-disable-line @typescript-eslint/no-unnecessary-type-assertion
|
||||||
|
});
|
||||||
|
});
|
Loading…
Reference in a new issue