shlink-web-client/test/short-urls/SearchBar.test.js

81 lines
2.6 KiB
JavaScript
Raw Normal View History

import React from 'react';
import { shallow } from 'enzyme';
2020-01-14 22:12:30 +03:00
import each from 'jest-each';
2018-12-18 00:32:51 +03:00
import searchBarCreator from '../../src/short-urls/SearchBar';
import SearchField from '../../src/utils/SearchField';
import Tag from '../../src/tags/helpers/Tag';
2020-01-14 22:12:30 +03:00
import DateRangeRow from '../../src/utils/DateRangeRow';
describe('<SearchBar />', () => {
let wrapper;
2019-04-19 13:41:59 +03:00
const listShortUrlsMock = jest.fn();
const SearchBar = searchBarCreator({});
afterEach(() => {
2019-04-19 13:41:59 +03:00
listShortUrlsMock.mockReset();
wrapper && wrapper.unmount();
});
it('renders a SearchField', () => {
2018-12-18 00:32:51 +03:00
wrapper = shallow(<SearchBar shortUrlsListParams={{}} />);
expect(wrapper.find(SearchField)).toHaveLength(1);
});
each([
[ '2.0.0', 1 ],
[ '1.21.2', 1 ],
[ '1.21.0', 1 ],
[ '1.20.0', 0 ],
]).it('renders a DateRangeRow when proper version is run', (version, expectedLength) => {
wrapper = shallow(<SearchBar shortUrlsListParams={{}} selectedServer={{ version }} />);
expect(wrapper.find(DateRangeRow)).toHaveLength(expectedLength);
2020-01-14 22:12:30 +03:00
});
it('renders no tags when the list of tags is empty', () => {
2018-12-18 00:32:51 +03:00
wrapper = shallow(<SearchBar shortUrlsListParams={{}} />);
expect(wrapper.find(Tag)).toHaveLength(0);
});
it('renders the proper amount of tags', () => {
const tags = [ 'foo', 'bar', 'baz' ];
2018-12-18 00:32:51 +03:00
wrapper = shallow(<SearchBar shortUrlsListParams={{ tags }} />);
expect(wrapper.find(Tag)).toHaveLength(tags.length);
});
it('updates short URLs list when search field changes', () => {
2018-12-18 00:32:51 +03:00
wrapper = shallow(<SearchBar shortUrlsListParams={{}} listShortUrls={listShortUrlsMock} />);
const searchField = wrapper.find(SearchField);
2019-04-19 13:41:59 +03:00
expect(listShortUrlsMock).not.toHaveBeenCalled();
searchField.simulate('change');
2019-04-19 13:41:59 +03:00
expect(listShortUrlsMock).toHaveBeenCalledTimes(1);
});
it('updates short URLs list when a tag is removed', () => {
wrapper = shallow(
2018-12-18 00:32:51 +03:00
<SearchBar shortUrlsListParams={{ tags: [ 'foo' ] }} listShortUrls={listShortUrlsMock} />
);
const tag = wrapper.find(Tag).first();
2019-04-19 13:41:59 +03:00
expect(listShortUrlsMock).not.toHaveBeenCalled();
tag.simulate('close');
2019-04-19 13:41:59 +03:00
expect(listShortUrlsMock).toHaveBeenCalledTimes(1);
});
2020-01-14 22:12:30 +03:00
each([ 'startDateChange', 'endDateChange' ]).it('updates short URLs list when date range changes', (event) => {
wrapper = shallow(
<SearchBar shortUrlsListParams={{}} listShortUrls={listShortUrlsMock} selectedServer={{ version: '2.0.0' }} />
);
2020-01-14 22:12:30 +03:00
const dateRange = wrapper.find(DateRangeRow);
expect(listShortUrlsMock).not.toHaveBeenCalled();
dateRange.simulate(event);
expect(listShortUrlsMock).toHaveBeenCalledTimes(1);
});
});